]> git.lizzy.rs Git - nhentai.git/blobdiff - nhentai/command.py
Merge branch 'master' into dev
[nhentai.git] / nhentai / command.py
index 87bc795fe0ff2af81ec203d171e900b88f4336b4..f6c48559a30d29baa4285491d6039a089b674e29 100644 (file)
 #!/usr/bin/env python2.7
 # coding: utf-8
+from __future__ import unicode_literals, print_function
 import signal
-from cmdline import cmd_parser, banner
-from parser import dojinshi_parser, search_parser, print_dojinshi
-from dojinshi import Dojinshi
-from downloader import Downloader
-from logger import logger
+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))
 
-    logger.log(15, 'nHentai: あなたも変態。 いいね?')
+    from nhentai.constant import PROXY
+    # constant.PROXY will be changed after cmd_parser()
+    if PROXY:
+        logger.info('Using proxy: {0}'.format(PROXY))
 
-    dojinshi_ids = []
-    dojinshi_list = []
+    # check your cookie
+    check_cookie()
 
-    if options.keyword:
-        dojinshis = search_parser(options.keyword, options.page)
-        print_dojinshi(dojinshis)
-        if options.is_download:
-            dojinshi_ids = map(lambda d: d['id'], dojinshis)
-    else:
-        dojinshi_ids = options.ids
+    doujinshis = []
+    doujinshi_ids = []
+    doujinshi_list = []
 
-    if dojinshi_ids:
-        for id in dojinshi_ids:
-            dojinshi_info = dojinshi_parser(id)
-            dojinshi_list.append(Dojinshi(**dojinshi_info))
-    else:
-        raise SystemExit
-
-    if options.is_download:
-        downloader = Downloader(path=options.saved_path,
-                                thread=options.threads, timeout=options.timeout)
-        for dojinshi in dojinshi_list:
-            dojinshi.downloader = downloader
-            dojinshi.download()
-    else:
-        map(lambda dojinshi: dojinshi.show(), dojinshi_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)
 
-    logger.log(15, u'🍺 All done.')
+            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]
 
-def signal_handler(signal, frame):
-    logger.error('Ctrl-C signal received. Quit.')
-    raise SystemExit
 
 signal.signal(signal.SIGINT, signal_handler)
+
 if __name__ == '__main__':
-    main()
\ No newline at end of file
+    main()