Added manga-py source
This commit is contained in:
79
manga-py-stable_1.x/manga_py/providers/mangago_me.py
Normal file
79
manga-py-stable_1.x/manga_py/providers/mangago_me.py
Normal file
@@ -0,0 +1,79 @@
|
||||
from manga_py.crypt import mangago_me
|
||||
from manga_py.fs import rename, unlink
|
||||
from manga_py.provider import Provider
|
||||
from .helpers.std import Std
|
||||
|
||||
|
||||
class MangaGoMe(Provider, Std):
|
||||
_enc_images = None
|
||||
_crypt = None
|
||||
|
||||
def get_archive_name(self) -> str:
|
||||
idx = self.get_chapter_index().split('-')
|
||||
tp = self.re.search('/(\w{1,4})/[^/]*?\d+', self.chapter)
|
||||
idx = [self.chapter_id, idx[-1]] # do not touch this!
|
||||
if tp:
|
||||
idx.append(tp.group(1))
|
||||
return self.normal_arc_name({'vol': idx})
|
||||
|
||||
def get_chapter_index(self) -> str:
|
||||
selector = r'/\w{1,4}/[^/]*?(\d+)(?:[^\d]+(\d+))?'
|
||||
idx = self.re.search(selector, self.chapter).groups()
|
||||
if idx[1] is not None:
|
||||
fmt = '{}-{}'
|
||||
return fmt.format(*idx)
|
||||
return idx[0]
|
||||
|
||||
def get_main_content(self):
|
||||
return self._get_content(self.get_url())
|
||||
|
||||
def get_manga_name(self) -> str:
|
||||
return self._get_name(r'/read-manga/([^/]+)/')
|
||||
|
||||
def get_chapters(self):
|
||||
content = self._elements('#information')
|
||||
if not content:
|
||||
return []
|
||||
chapters = content[0].cssselect('#chapter_table a.chico')
|
||||
raws = content[0].cssselect('#raws_table a.chicor')
|
||||
return chapters + raws
|
||||
|
||||
def prepare_cookies(self):
|
||||
self._crypt = mangago_me.MangaGoMe()
|
||||
self.cf_protect(self.domain)
|
||||
|
||||
def get_files(self):
|
||||
self._enc_images = {}
|
||||
content = self.http(True, {
|
||||
'referer': self.chapter,
|
||||
'cookies': self.http().cookies,
|
||||
'user_agent': self.http().user_agent
|
||||
}).get(self.chapter)
|
||||
re = self.re.search(r"imgsrcs\s*=\s*['\"](.+)['\"]", content)
|
||||
if not re:
|
||||
return []
|
||||
items = self._crypt.decrypt(re.group(1))
|
||||
return items.split(',')
|
||||
|
||||
def before_file_save(self, url, idx):
|
||||
if ~url.find('/cspiclink/'):
|
||||
self._enc_images[idx] = url
|
||||
return url
|
||||
|
||||
def after_file_save(self, _path: str, idx: int):
|
||||
url = self._enc_images.get(idx, None)
|
||||
if url is not None:
|
||||
_dst = _path[:_path.rfind('.')] + '_' + _path[_path.rfind('.'):]
|
||||
self._crypt.puzzle(_path, _dst, url)
|
||||
unlink(_path)
|
||||
rename(_dst, _path)
|
||||
|
||||
def get_cover(self):
|
||||
return self._cover_from_content('#information .cover img')
|
||||
|
||||
def book_meta(self) -> dict:
|
||||
# todo meta
|
||||
pass
|
||||
|
||||
|
||||
main = MangaGoMe
|
||||
Reference in New Issue
Block a user