2016-08-09 14:05:12 +02:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
|
2019-02-08 13:45:40 +01:00
|
|
|
# Copyright 2016-2019 Mike Fährmann
|
2016-08-09 14:05:12 +02:00
|
|
|
#
|
|
|
|
# This program is free software; you can redistribute it and/or modify
|
|
|
|
# it under the terms of the GNU General Public License version 2 as
|
|
|
|
# published by the Free Software Foundation.
|
|
|
|
|
2018-06-30 19:40:46 +02:00
|
|
|
"""Extract images from https://imagefap.com/"""
|
2016-08-09 14:05:12 +02:00
|
|
|
|
|
|
|
from .common import Extractor, Message
|
2018-04-20 14:53:21 +02:00
|
|
|
from .. import text
|
2016-08-10 10:27:32 +02:00
|
|
|
import json
|
2016-08-09 14:05:12 +02:00
|
|
|
|
2017-02-01 00:53:19 +01:00
|
|
|
|
2018-01-30 22:49:16 +01:00
|
|
|
class ImagefapExtractor(Extractor):
|
|
|
|
"""Base class for imagefap extractors"""
|
2016-08-09 14:05:12 +02:00
|
|
|
category = "imagefap"
|
2019-02-08 13:45:40 +01:00
|
|
|
directory_fmt = ("{category}", "{gallery_id} {title}")
|
2017-09-10 22:20:47 +02:00
|
|
|
filename_fmt = "{category}_{gallery_id}_{name}.{extension}"
|
2018-01-30 22:49:16 +01:00
|
|
|
archive_fmt = "{gallery_id}_{image_id}"
|
2018-06-30 19:40:46 +02:00
|
|
|
root = "https://www.imagefap.com"
|
2018-01-30 22:49:16 +01:00
|
|
|
|
|
|
|
|
|
|
|
class ImagefapGalleryExtractor(ImagefapExtractor):
|
|
|
|
"""Extractor for image galleries from imagefap.com"""
|
|
|
|
subcategory = "gallery"
|
2019-02-08 13:45:40 +01:00
|
|
|
pattern = (r"(?:https?://)?(?:www\.)?imagefap\.com/"
|
|
|
|
r"(?:gallery\.php\?gid=|gallery/|pictures/)(\d+)")
|
|
|
|
test = (
|
2018-06-30 19:40:46 +02:00
|
|
|
("https://www.imagefap.com/pictures/7102714", {
|
|
|
|
"url": "268995eac5d01ddecd0fe58cfa9828390dc85a84",
|
2018-10-20 18:32:25 +02:00
|
|
|
"keyword": "3b90205f434bd1e0461bdbd5d2d9c34056b50fe6",
|
2017-10-26 15:27:42 +02:00
|
|
|
"content": "694a0a57385980a6f90fbc296cadcd6c11ba2dab",
|
2017-03-09 20:34:39 +01:00
|
|
|
}),
|
2018-06-30 19:40:46 +02:00
|
|
|
("https://www.imagefap.com/gallery/5486966", {
|
|
|
|
"url": "14906b4f0b8053d1d69bc730a325acb793cbc898",
|
2018-10-20 18:32:25 +02:00
|
|
|
"keyword": "66ccb98b69cb52f89540224260641002f41f6ece",
|
2017-03-09 20:34:39 +01:00
|
|
|
}),
|
2019-02-08 13:45:40 +01:00
|
|
|
("https://www.imagefap.com/gallery.php?gid=7102714"),
|
|
|
|
)
|
2016-08-09 14:05:12 +02:00
|
|
|
|
|
|
|
def __init__(self, match):
|
2019-02-11 13:31:10 +01:00
|
|
|
ImagefapExtractor.__init__(self, match)
|
2016-08-09 14:05:12 +02:00
|
|
|
self.gid = match.group(1)
|
2016-09-12 10:20:57 +02:00
|
|
|
self.image_id = ""
|
2016-08-09 14:05:12 +02:00
|
|
|
|
|
|
|
def items(self):
|
2018-06-30 19:40:46 +02:00
|
|
|
url = "{}/pictures/{}/".format(self.root, self.gid)
|
2016-08-09 14:05:12 +02:00
|
|
|
page = self.request(url).text
|
|
|
|
data = self.get_job_metadata(page)
|
|
|
|
yield Message.Version, 1
|
|
|
|
yield Message.Directory, data
|
2017-03-09 20:34:39 +01:00
|
|
|
for url, image in self.get_images():
|
2016-08-09 14:05:12 +02:00
|
|
|
data.update(image)
|
2016-08-11 15:50:32 +02:00
|
|
|
yield Message.Url, url, data
|
2016-08-09 14:05:12 +02:00
|
|
|
|
|
|
|
def get_job_metadata(self, page):
|
|
|
|
"""Collect metadata for extractor-job"""
|
2018-10-20 18:32:25 +02:00
|
|
|
descr, pos = text.extract(
|
|
|
|
page, '<meta name="description" content="Browse ', '"')
|
|
|
|
count, pos = text.extract(page, ' 1 of ', ' pics"', pos)
|
2016-08-11 15:50:32 +02:00
|
|
|
self.image_id = text.extract(page, 'id="img_ed_', '"', pos)[0]
|
2018-10-20 18:32:25 +02:00
|
|
|
|
|
|
|
title, _, descr = descr.partition(" porn picture gallery by ")
|
|
|
|
uploader, _, tags = descr.partition(" to see hottest ")
|
|
|
|
return {
|
|
|
|
"gallery_id": text.parse_int(self.gid),
|
|
|
|
"title": text.unescape(title),
|
|
|
|
"uploader": uploader,
|
|
|
|
"tags": tags[:-11].split(", "),
|
|
|
|
"count": text.parse_int(count),
|
|
|
|
}
|
2016-08-09 14:05:12 +02:00
|
|
|
|
2017-03-09 20:34:39 +01:00
|
|
|
def get_images(self):
|
2016-08-11 15:50:32 +02:00
|
|
|
"""Collect image-urls and -metadata"""
|
2016-08-09 14:05:12 +02:00
|
|
|
num = 0
|
2018-06-30 19:40:46 +02:00
|
|
|
url = "{}/photo/{}/".format(self.root, self.image_id)
|
2016-08-11 15:50:32 +02:00
|
|
|
params = {"gid": self.gid, "idx": 0, "partial": "true"}
|
2016-08-09 14:05:12 +02:00
|
|
|
while True:
|
2016-08-11 15:50:32 +02:00
|
|
|
pos = 0
|
|
|
|
page = self.request(url, params=params).text
|
2016-09-12 10:20:57 +02:00
|
|
|
for _ in range(24):
|
2016-08-11 15:50:32 +02:00
|
|
|
imgurl, pos = text.extract(page, '<a href="', '"', pos)
|
2017-03-09 20:34:39 +01:00
|
|
|
if not imgurl:
|
|
|
|
return
|
2016-08-11 15:50:32 +02:00
|
|
|
num += 1
|
|
|
|
_, imgid, name = imgurl.rsplit("/", 2)
|
2018-10-20 18:32:25 +02:00
|
|
|
data = {"image_id": text.parse_int(imgid), "num": num}
|
2016-08-11 15:50:32 +02:00
|
|
|
yield imgurl, text.nameext_from_url(name, data)
|
|
|
|
params["idx"] += 24
|
2016-08-10 10:27:32 +02:00
|
|
|
|
|
|
|
|
2018-01-30 22:49:16 +01:00
|
|
|
class ImagefapImageExtractor(ImagefapExtractor):
|
2016-09-12 10:20:57 +02:00
|
|
|
"""Extractor for single images from imagefap.com"""
|
2016-08-10 10:27:32 +02:00
|
|
|
subcategory = "image"
|
2019-02-08 13:45:40 +01:00
|
|
|
pattern = r"(?:https?://)?(?:www\.)?imagefap\.com/photo/(\d+)"
|
|
|
|
test = ("https://www.imagefap.com/photo/1369341772/", {
|
2018-06-30 19:40:46 +02:00
|
|
|
"url": "b31ee405b61ff0450020a1bf11c0581ca9adb471",
|
2018-10-20 18:32:25 +02:00
|
|
|
"keyword": "b49940c04ed30bfc1c28ec39eb08b3be5753ce8a",
|
2019-02-08 13:45:40 +01:00
|
|
|
})
|
2016-08-10 10:27:32 +02:00
|
|
|
|
|
|
|
def __init__(self, match):
|
2019-02-11 13:31:10 +01:00
|
|
|
ImagefapExtractor.__init__(self, match)
|
2016-08-10 10:27:32 +02:00
|
|
|
self.image_id = match.group(1)
|
|
|
|
|
|
|
|
def items(self):
|
2018-10-20 18:32:25 +02:00
|
|
|
data = self.get_job_metadata()
|
2016-08-10 10:27:32 +02:00
|
|
|
yield Message.Version, 1
|
|
|
|
yield Message.Directory, data
|
2018-10-20 18:32:25 +02:00
|
|
|
yield Message.Url, data["url"], data
|
2016-08-10 10:27:32 +02:00
|
|
|
|
2018-10-20 18:32:25 +02:00
|
|
|
def get_job_metadata(self):
|
2016-08-10 10:27:32 +02:00
|
|
|
"""Collect metadata for extractor-job"""
|
2018-10-20 18:32:25 +02:00
|
|
|
url = "{}/photo/{}/".format(self.root, self.image_id)
|
|
|
|
page = self.request(url).text
|
|
|
|
info = json.loads(text.extract(
|
|
|
|
page, '<script type="application/ld+json">', '</script>')[0])
|
2016-08-10 10:27:32 +02:00
|
|
|
parts = info["contentUrl"].rsplit("/", 3)
|
|
|
|
return text.nameext_from_url(parts[3], {
|
2018-10-20 18:32:25 +02:00
|
|
|
"url": info["contentUrl"],
|
2016-08-10 10:27:32 +02:00
|
|
|
"title": text.unescape(info["name"]),
|
|
|
|
"uploader": info["author"],
|
|
|
|
"date": info["datePublished"],
|
2018-10-20 18:32:25 +02:00
|
|
|
"width": text.parse_int(info["width"]),
|
|
|
|
"height": text.parse_int(info["height"]),
|
|
|
|
"gallery_id": text.parse_int(parts[1]),
|
|
|
|
"image_id": text.parse_int(parts[2]),
|
2016-08-10 10:27:32 +02:00
|
|
|
})
|
|
|
|
|
2016-08-10 12:54:18 +02:00
|
|
|
|
2018-01-30 22:49:16 +01:00
|
|
|
class ImagefapUserExtractor(ImagefapExtractor):
|
2016-09-12 10:20:57 +02:00
|
|
|
"""Extractor for all galleries from a user at imagefap.com"""
|
2016-08-10 12:54:18 +02:00
|
|
|
subcategory = "user"
|
2017-09-26 20:50:49 +02:00
|
|
|
categorytransfer = True
|
2019-02-08 13:45:40 +01:00
|
|
|
pattern = (r"(?:https?://)?(?:www\.)?imagefap\.com/"
|
2019-02-08 12:03:10 +01:00
|
|
|
r"(?:profile(?:\.php\?user=|/)([^/?&#]+)"
|
2019-02-08 13:45:40 +01:00
|
|
|
r"|usergallery\.php\?userid=(\d+))")
|
|
|
|
test = (
|
2018-11-15 14:16:24 +01:00
|
|
|
("https://www.imagefap.com/profile/LucyRae/galleries", {
|
|
|
|
"url": "d941aa906f56a75972a7a5283030eb9a8d27a4fd",
|
|
|
|
}),
|
|
|
|
("https://www.imagefap.com/usergallery.php?userid=1862791", {
|
|
|
|
"url": "d941aa906f56a75972a7a5283030eb9a8d27a4fd",
|
|
|
|
}),
|
2019-02-08 13:45:40 +01:00
|
|
|
("https://www.imagefap.com/profile.php?user=LucyRae"),
|
|
|
|
)
|
2016-08-10 12:54:18 +02:00
|
|
|
|
|
|
|
def __init__(self, match):
|
2019-02-11 13:31:10 +01:00
|
|
|
ImagefapExtractor.__init__(self, match)
|
2019-02-08 12:03:10 +01:00
|
|
|
self.user, self.user_id = match.groups()
|
2016-08-10 12:54:18 +02:00
|
|
|
|
|
|
|
def items(self):
|
|
|
|
yield Message.Version, 1
|
2017-09-12 16:19:00 +02:00
|
|
|
for gid, name in self.get_gallery_data():
|
2018-06-30 19:40:46 +02:00
|
|
|
url = "{}/gallery/{}".format(self.root, gid)
|
2019-02-12 21:26:41 +01:00
|
|
|
data = {
|
|
|
|
"gallery_id": text.parse_int(gid),
|
|
|
|
"title": text.unescape(name),
|
|
|
|
"_extractor": ImagefapGalleryExtractor,
|
|
|
|
}
|
2017-09-12 16:19:00 +02:00
|
|
|
yield Message.Queue, url, data
|
2016-08-10 12:54:18 +02:00
|
|
|
|
2017-09-12 16:19:00 +02:00
|
|
|
def get_gallery_data(self):
|
2017-09-10 22:20:47 +02:00
|
|
|
"""Yield all gallery_ids of a specific user"""
|
2016-08-10 12:54:18 +02:00
|
|
|
folders = self.get_gallery_folders()
|
2018-06-30 19:40:46 +02:00
|
|
|
url = "{}/ajax_usergallery_folder.php".format(self.root)
|
2016-08-10 12:54:18 +02:00
|
|
|
params = {"userid": self.user_id}
|
|
|
|
for folder_id in folders:
|
|
|
|
params["id"] = folder_id
|
|
|
|
page = self.request(url, params=params).text
|
2017-09-12 16:19:00 +02:00
|
|
|
|
|
|
|
pos = 0
|
|
|
|
while True:
|
|
|
|
gid, pos = text.extract(page, '<a href="/gallery/', '"', pos)
|
|
|
|
if not gid:
|
|
|
|
break
|
|
|
|
name, pos = text.extract(page, "<b>", "<", pos)
|
|
|
|
yield gid, name
|
2016-08-10 12:54:18 +02:00
|
|
|
|
|
|
|
def get_gallery_folders(self):
|
2017-09-10 22:20:47 +02:00
|
|
|
"""Create a list of all folder_ids of a specific user"""
|
2016-08-10 12:54:18 +02:00
|
|
|
if self.user:
|
2018-06-30 19:40:46 +02:00
|
|
|
url = "{}/profile/{}/galleries".format(self.root, self.user)
|
2016-08-10 12:54:18 +02:00
|
|
|
else:
|
2018-06-30 19:40:46 +02:00
|
|
|
url = "{}/usergallery.php?userid={}".format(
|
|
|
|
self.root, self.user_id)
|
2016-08-10 12:54:18 +02:00
|
|
|
page = self.request(url).text
|
|
|
|
self.user_id, pos = text.extract(page, '?userid=', '"')
|
2017-02-01 00:53:19 +01:00
|
|
|
folders, pos = text.extract(page, ' id="tgl_all" value="', '"', pos)
|
2016-08-10 12:54:18 +02:00
|
|
|
return folders.split("|")[:-1]
|