# -*- coding: utf-8 -*- # Copyright 2016-2017 Mike Fährmann # # 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. """Extract images from http://imagefap.com/""" from .common import Extractor, Message from .. import text, util import json class ImagefapGalleryExtractor(Extractor): """Extractor for image galleries from imagefap.com""" category = "imagefap" subcategory = "gallery" directory_fmt = ["{category}", "{gallery_id} {title}"] filename_fmt = "{category}_{gallery_id}_{name}.{extension}" pattern = [(r"(?:https?://)?(?:www\.)?imagefap\.com/" r"(?:gallery\.php\?gid=|gallery/|pictures/)(\d+)")] test = [ ("http://www.imagefap.com/pictures/7102714", { "url": "ffb1d58924fc9d6a0650006a96395a04454b85cf", "keyword": "b65c310d75269cb6dcc32c3fc1bdcf39bea45342", "content": "694a0a57385980a6f90fbc296cadcd6c11ba2dab", }), ("http://www.imagefap.com/gallery/5486966", { "url": "eace9b33be99f87f3382c87bd915cf495a865d6e", "keyword": "b84da0543c2d1f848bf5e4c2950dd4f4543a1e0c", }), ("http://www.imagefap.com/gallery.php?gid=7102714", None), ] def __init__(self, match): Extractor.__init__(self) self.gid = match.group(1) self.image_id = "" def items(self): url = "http://www.imagefap.com/pictures/" + self.gid + "/" page = self.request(url).text data = self.get_job_metadata(page) yield Message.Version, 1 yield Message.Directory, data for url, image in self.get_images(): data.update(image) yield Message.Url, url, data def get_job_metadata(self, page): """Collect metadata for extractor-job""" data, pos = text.extract_all(page, ( ("section" , 'Porn pics of ', ' (Page 1)'), ("uploader", '>Uploaded by ', ''), ("count" , ' 1 of ', ' pics"'), ), values={"gallery_id": self.gid}) self.image_id = text.extract(page, 'id="img_ed_', '"', pos)[0] data["title"] = text.unescape(data["title"]) return data def get_images(self): """Collect image-urls and -metadata""" num = 0 url = "http://www.imagefap.com/photo/" + self.image_id + "/" params = {"gid": self.gid, "idx": 0, "partial": "true"} while True: pos = 0 page = self.request(url, params=params).text for _ in range(24): imgurl, pos = text.extract(page, '', '', pos ) json_dict = json.loads(json_data) json_dict["section"] = section return json_dict class ImagefapUserExtractor(Extractor): """Extractor for all galleries from a user at imagefap.com""" category = "imagefap" subcategory = "user" categorytransfer = True pattern = [(r"(?:https?://)?(?:www\.)?imagefap\.com/" r"profile(?:\.php\?user=|/)([^/]+)"), (r"(?:https?://)?(?:www\.)?imagefap\.com/" r"usergallery\.php\?userid=(\d+)")] test = [("http://www.imagefap.com/profile/Mr%20Bad%20Example/galleries", { "url": "145e98a8648c7695c150800ff8fd578ab26c28c1", })] def __init__(self, match): Extractor.__init__(self) try: self.user_id = int(match.group(1)) self.user = None except ValueError: self.user_id = None self.user = match.group(1) def items(self): yield Message.Version, 1 for gid, name in self.get_gallery_data(): url = "http://www.imagefap.com/gallery/" + gid data = {"gallery_id": util.safe_int(gid), "title": name} yield Message.Queue, url, data def get_gallery_data(self): """Yield all gallery_ids of a specific user""" folders = self.get_gallery_folders() url = "http://www.imagefap.com/ajax_usergallery_folder.php" params = {"userid": self.user_id} for folder_id in folders: params["id"] = folder_id page = self.request(url, params=params).text pos = 0 while True: gid, pos = text.extract(page, '", "<", pos) yield gid, name def get_gallery_folders(self): """Create a list of all folder_ids of a specific user""" if self.user: url = "http://www.imagefap.com/profile/" + self.user + "/galleries" else: url = ("http://www.imagefap.com/usergallery.php?userid=" + str(self.user_id)) page = self.request(url).text self.user_id, pos = text.extract(page, '?userid=', '"') folders, pos = text.extract(page, ' id="tgl_all" value="', '"', pos) return folders.split("|")[:-1]