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