]> git.lizzy.rs Git - nhentai.git/blobdiff - nhentai/command.py
fix format
[nhentai.git] / nhentai / command.py
index cfbf2ade42b6aae9da286ada0653f6d8f7f2a55e..a6c91d050bb598620ceb9b5dc60fba28f54535e6 100644 (file)
-#!/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
+
+import sys
+import signal
+import platform
+import time
+
+from nhentai import constant
+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, generate_metadata_file, \
+    paging, check_cookie, signal_handler, DB
+
+
+def main():
+    banner()
+
+    if sys.version_info < (3, 0, 0):
+        logger.error('nhentai now only support Python 3.x')
+        exit(1)
+
+    options = cmd_parser()
+    logger.info('Using mirror: {0}'.format(BASE_URL))
+
+    # CONFIG['proxy'] will be changed after cmd_parser()
+    if constant.CONFIG['proxy']['http']:
+        logger.info('Using proxy: {0}'.format(constant.CONFIG['proxy']['http']))
+
+    if not constant.CONFIG['template']:
+        constant.CONFIG['template'] = 'default'
+
+    logger.info('Using viewer template "{}"'.format(constant.CONFIG['template']))
+
+    # check your cookie
+    check_cookie()
+
+    doujinshis = []
+    doujinshi_ids = []
+    doujinshi_list = []
+
+    page_list = paging(options.page)
+
+    if options.favorites:
+        if not options.is_download:
+            logger.warning('You do not specify --download option')
+
+        doujinshis = favorites_parser(page=page_list)
+
+    elif options.keyword:
+        if constant.CONFIG['language']:
+            logger.info('Using default language: {0}'.format(constant.CONFIG['language']))
+            options.keyword += ' language:{}'.format(constant.CONFIG['language'])
+        doujinshis = search_parser(options.keyword, sorting=options.sorting, page=page_list,
+                                   is_page_all=options.page_all)
+
+    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 = map(int, db.get_all())
+
+        doujinshi_ids = list(set(map(int, doujinshi_ids)) - set(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:
+            if not options.dryrun:
+                doujinshi.downloader = downloader
+                doujinshi.download()
+
+            doujinshi.downloader = downloader
+            doujinshi.download()
+
+            if options.generate_metadata:
+                table = doujinshi.table
+                generate_metadata_file(options.output_dir, table, doujinshi)
+
+            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, template=constant.CONFIG['template'])
+            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()