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