]> git.lizzy.rs Git - nhentai.git/blob - nhentai/command.py
Merge branch 'master' into dev
[nhentai.git] / nhentai / command.py
1 #!/usr/bin/env python2.7
2 # coding: utf-8
3 from __future__ import unicode_literals, print_function
4 import signal
5 import platform
6 import time
7
8 from nhentai.cmdline import cmd_parser, banner
9 from nhentai.parser import doujinshi_parser, search_parser, print_doujinshi, favorites_parser
10 from nhentai.doujinshi import Doujinshi
11 from nhentai.downloader import Downloader
12 from nhentai.logger import logger
13 from nhentai.constant import BASE_URL
14 from nhentai.utils import generate_html, generate_cbz, generate_main_html, generate_pdf, check_cookie, signal_handler, DB
15
16
17 def main():
18     banner()
19     options = cmd_parser()
20     logger.info('Using mirror: {0}'.format(BASE_URL))
21
22     from nhentai.constant import PROXY
23     # constant.PROXY will be changed after cmd_parser()
24     if PROXY:
25         logger.info('Using proxy: {0}'.format(PROXY))
26
27     # check your cookie
28     check_cookie()
29
30     doujinshis = []
31     doujinshi_ids = []
32     doujinshi_list = []
33
34     if options.favorites:
35         if not options.is_download:
36             logger.warning('You do not specify --download option')
37
38         doujinshis = favorites_parser(options.page_range)
39
40     elif options.keyword:
41         from nhentai.constant import LANGUAGE
42         if LANGUAGE:
43             logger.info('Using deafult language: {0}'.format(LANGUAGE))
44             options.keyword += ', language:{}'.format(LANGUAGE)
45         doujinshis = search_parser(options.keyword, sorting=options.sorting, page=options.page)
46
47     elif not doujinshi_ids:
48         doujinshi_ids = options.id
49
50     print_doujinshi(doujinshis)
51     if options.is_download and doujinshis:
52         doujinshi_ids = [i['id'] for i in doujinshis]
53
54         if options.is_save_download_history:
55             with DB() as db:
56                 data = set(db.get_all())
57
58             doujinshi_ids = list(set(doujinshi_ids) - data)
59
60     if doujinshi_ids:
61         for i, id_ in enumerate(doujinshi_ids):
62             if options.delay:
63                 time.sleep(options.delay)
64
65             doujinshi_info = doujinshi_parser(id_)
66
67             if doujinshi_info:
68                 doujinshi_list.append(Doujinshi(name_format=options.name_format, **doujinshi_info))
69
70             if (i + 1) % 10 == 0:
71                 logger.info('Progress: %d / %d' % (i + 1, len(doujinshi_ids)))
72
73     if not options.is_show:
74         downloader = Downloader(path=options.output_dir, size=options.threads,
75                                 timeout=options.timeout, delay=options.delay)
76
77         for doujinshi in doujinshi_list:
78
79             doujinshi.downloader = downloader
80             doujinshi.download()
81             if options.is_save_download_history:
82                 with DB() as db:
83                     db.add_one(doujinshi.id)
84
85             if not options.is_nohtml and not options.is_cbz and not options.is_pdf:
86                 generate_html(options.output_dir, doujinshi)
87             elif options.is_cbz:
88                 generate_cbz(options.output_dir, doujinshi, options.rm_origin_dir)
89             elif options.is_pdf:
90                 generate_pdf(options.output_dir, doujinshi, options.rm_origin_dir)
91
92         if options.main_viewer:
93             generate_main_html(options.output_dir)
94
95         if not platform.system() == 'Windows':
96             logger.log(15, '🍻 All done.')
97         else:
98             logger.log(15, 'All done.')
99
100     else:
101         [doujinshi.show() for doujinshi in doujinshi_list]
102
103
104 signal.signal(signal.SIGINT, signal_handler)
105
106 if __name__ == '__main__':
107     main()