Files
2019-12-14 22:33:14 -05:00

80 lines
2.8 KiB
Python

from manga_py.crypt import MangaRockComCrypt
from manga_py.fs import rename, unlink, basename
from manga_py.provider import Provider
from .helpers.std import Std
# api example:
"""
curl 'https://api.mangarockhd.com/query/web401/manga_detail?country=Japan' --compressed --data '{"oids":{"mrs-serie-100226981":0},"sections":["basic_info","summary","artworks","sub_genres","social_stats","author","character","publisher","scanlator","other_fact","chapters","related_series","same_author","feature_collections"]}'
"""
class MangaRockCom(Provider, Std):
crypt = None
__content = ''
__api_uri = 'https://api.mangarockhd.com/query/'
def get_chapter_index(self) -> str:
return str(self.chapter_id)
def get_main_content(self):
name = self._get_name(r'/manga/([^/]+-\d+)')
return self.http_get('{}/manga/{}'.format(
self.domain,
name
))
def get_manga_name(self) -> str:
return self.text_content(self.content, 'h1')
def get_chapters(self):
idx = self._get_name('/manga/([^/]+)')
url = '{}info?oid={}&last=0&country=Japan'.format(self.__api_uri, idx)
items = self.json.loads(self.http_get(url))
return [(i.get('oid'),) for i in items.get('data', {}).get('chapters', [])][::-1]
def __get_url(self):
return '{}pages?oid={}&country=Japan'.format(self.__api_uri, self.chapter[0])
def get_files(self):
items = self.json.loads(self.http_get(self.__get_url()))
return items.get('data')
# decrypt
def after_file_save(self, _path, idx: int):
_path_wp = _path + 'wp'
with open(_path, 'rb') as file_r:
with open(_path_wp, 'wb') as file_w:
file_w.write(self.crypt.decrypt(file_r.read()))
unlink(_path)
rename(_path_wp, _path)
def save_file(self, idx=None, callback=None, url=None, in_arc_name=None):
_path, idx, _url = self._save_file_params_helper(url, idx)
in_arc_name = basename(_path) + '.webp'
return super().save_file(idx, callback, _url, in_arc_name)
def get_cover(self) -> str:
selector = 'div:not([class]) > div[class] > div[class] > div[class] > div[class] > img'
url = '{}{}'.format(self.domain, self._get_name('(/manga/[^/]+)'))
img = self._elements(selector, self.http_get(url))
if img and len(img):
return img[0].get('src')
def prepare_cookies(self):
# patch api version
v = self.re.compile(r'\bAJAX_MRAPI_VERSION\b\s*=\s*[\'"]?(web\d+)')
self.__api_uri += v.search(self.content).group(1) + '/'
self.crypt = MangaRockComCrypt()
def book_meta(self) -> dict:
# todo meta
pass
def chapter_for_json(self):
return self.get_url()
main = MangaRockCom