-#!/usr/bin/env python2.7\r
-# coding: utf-8\r
-from __future__ import unicode_literals, print_function\r
-import signal\r
-import platform\r
-\r
-from nhentai.cmdline import cmd_parser, banner\r
-from nhentai.parser import doujinshi_parser, search_parser, print_doujinshi, login_parser\r
-from nhentai.doujinshi import Doujinshi\r
-from nhentai.downloader import Downloader\r
-from nhentai.logger import logger\r
-from nhentai.constant import BASE_URL\r
-from nhentai.utils import generate_html, generate_cbz\r
-\r
-\r
-def main():\r
- banner()\r
- logger.info('Using mirror: {0}'.format(BASE_URL))\r
- options = cmd_parser()\r
-\r
- doujinshi_ids = []\r
- doujinshi_list = []\r
-\r
- if options.login:\r
- username, password = options.login.split(':', 1)\r
- logger.info('Login to nhentai use credential \'%s:%s\'' % (username, '*' * len(password)))\r
- for doujinshi_info in login_parser(username=username, password=password):\r
- doujinshi_list.append(Doujinshi(**doujinshi_info))\r
-\r
- if options.keyword:\r
- doujinshis = search_parser(options.keyword, options.page)\r
- print_doujinshi(doujinshis)\r
- if options.is_download:\r
- doujinshi_ids = map(lambda d: d['id'], doujinshis)\r
- else:\r
- doujinshi_ids = options.id\r
-\r
- if doujinshi_ids:\r
- for id_ in doujinshi_ids:\r
- doujinshi_info = doujinshi_parser(id_)\r
- doujinshi_list.append(Doujinshi(**doujinshi_info))\r
-\r
- if not options.is_show:\r
- downloader = Downloader(path=options.output_dir,\r
- thread=options.threads, timeout=options.timeout)\r
-\r
- for doujinshi in doujinshi_list:\r
- doujinshi.downloader = downloader\r
- doujinshi.download()\r
- if not options.is_nohtml and not options.is_cbz:\r
- generate_html(options.output_dir, doujinshi)\r
- elif options.is_cbz:\r
- generate_cbz(options.output_dir, doujinshi)\r
-\r
- if not platform.system() == 'Windows':\r
- logger.log(15, '🍻 All done.')\r
- else:\r
- logger.log(15, 'All done.')\r
-\r
- else:\r
- [doujinshi.show() for doujinshi in doujinshi_list]\r
-\r
-\r
-def signal_handler(signal, frame):\r
- logger.error('Ctrl-C signal received. Quit.')\r
- exit(1)\r
-\r
-\r
-signal.signal(signal.SIGINT, signal_handler)\r
-\r
-if __name__ == '__main__':\r
- main()\r
+#!/usr/bin/env python2.7
+# coding: utf-8
+from __future__ import unicode_literals, print_function
+import signal
+import platform
+import time
+
+from nhentai.cmdline import cmd_parser, banner
+from nhentai.parser import doujinshi_parser, search_parser, print_doujinshi, favorites_parser
+from nhentai.doujinshi import Doujinshi
+from nhentai.downloader import Downloader
+from nhentai.logger import logger
+from nhentai.constant import BASE_URL
+from nhentai.utils import generate_html, generate_cbz, generate_main_html, generate_pdf, check_cookie, signal_handler, DB
+
+
+def main():
+ banner()
+ options = cmd_parser()
+ logger.info('Using mirror: {0}'.format(BASE_URL))
+
+ from nhentai.constant import PROXY
+ # constant.PROXY will be changed after cmd_parser()
+ if PROXY:
+ logger.info('Using proxy: {0}'.format(PROXY))
+
+ # check your cookie
+ check_cookie()
+
+ doujinshis = []
+ doujinshi_ids = []
+ doujinshi_list = []
+
+ if options.favorites:
+ if not options.is_download:
+ logger.warning('You do not specify --download option')
+
+ doujinshis = favorites_parser(options.page_range)
+
+ elif options.keyword:
+ from nhentai.constant import LANGUAGE
+ if LANGUAGE:
+ logger.info('Using deafult language: {0}'.format(LANGUAGE))
+ options.keyword += ', language:{}'.format(LANGUAGE)
+ doujinshis = search_parser(options.keyword, sorting=options.sorting, page=options.page)
+
+ elif not doujinshi_ids:
+ doujinshi_ids = options.id
+
+ print_doujinshi(doujinshis)
+ if options.is_download and doujinshis:
+ doujinshi_ids = [i['id'] for i in doujinshis]
+
+ if options.is_save_download_history:
+ with DB() as db:
+ data = set(db.get_all())
+
+ doujinshi_ids = list(set(doujinshi_ids) - data)
+
+ if doujinshi_ids:
+ for i, id_ in enumerate(doujinshi_ids):
+ if options.delay:
+ time.sleep(options.delay)
+
+ doujinshi_info = doujinshi_parser(id_)
+
+ if doujinshi_info:
+ doujinshi_list.append(Doujinshi(name_format=options.name_format, **doujinshi_info))
+
+ if (i + 1) % 10 == 0:
+ logger.info('Progress: %d / %d' % (i + 1, len(doujinshi_ids)))
+
+ if not options.is_show:
+ downloader = Downloader(path=options.output_dir, size=options.threads,
+ timeout=options.timeout, delay=options.delay)
+
+ for doujinshi in doujinshi_list:
+
+ doujinshi.downloader = downloader
+ doujinshi.download()
+ if options.is_save_download_history:
+ with DB() as db:
+ db.add_one(doujinshi.id)
+
+ if not options.is_nohtml and not options.is_cbz and not options.is_pdf:
+ generate_html(options.output_dir, doujinshi)
+ elif options.is_cbz:
+ generate_cbz(options.output_dir, doujinshi, options.rm_origin_dir)
+ elif options.is_pdf:
+ generate_pdf(options.output_dir, doujinshi, options.rm_origin_dir)
+
+ if options.main_viewer:
+ generate_main_html(options.output_dir)
+
+ if not platform.system() == 'Windows':
+ logger.log(15, '🍻 All done.')
+ else:
+ logger.log(15, 'All done.')
+
+ else:
+ [doujinshi.show() for doujinshi in doujinshi_list]
+
+
+signal.signal(signal.SIGINT, signal_handler)
+
+if __name__ == '__main__':
+ main()