-
Notifications
You must be signed in to change notification settings - Fork 258
/
Copy pathPixivNovelHandler.py
118 lines (100 loc) · 4.98 KB
/
PixivNovelHandler.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
import os
import time
from colorama.ansi import Fore, Style
import PixivConstant
import PixivHelper
import PixivNovel
def process_novel(caller,
config,
novel_id,
notifier=None):
if notifier is None:
notifier = PixivHelper.dummy_notifier
msg = Fore.YELLOW + Style.BRIGHT + f'Processing Novel details: {novel_id}' + Style.RESET_ALL
PixivHelper.print_and_log('info', msg)
# check if already downloaded before and overwrite is not enabled
db_result = caller.__dbManager__.selectNovelPostByPostId(novel_id)
if db_result is not None and not config.overwrite and not config.checkLastModified and not config.alwaysCheckFileSize:
save_name = db_result[2] # save_name
PixivHelper.print_and_log('warn', f"Novel already downloaded : {save_name}")
return
novel = caller.__br__.getNovelPage(novel_id)
PixivHelper.print_and_log(None, f"Title : {novel.imageTitle}")
PixivHelper.print_and_log(None, f'Member Name : {novel.artist.artistName}')
PixivHelper.print_and_log(None, f'Member Avatar: {novel.artist.artistAvatar}')
PixivHelper.print_and_log(None, f'Member Token : {novel.artist.artistToken}')
PixivHelper.print_and_log(None, f'Member Background : {novel.artist.artistBackground}')
tags_str = ', '.join(novel.imageTags)
PixivHelper.print_and_log(None, f"Tags : {tags_str}")
PixivHelper.print_and_log(None, f"Date : {novel.worksDateDateTime}")
PixivHelper.print_and_log(None, f"Mode : {novel.imageMode}")
PixivHelper.print_and_log(None, f"Bookmark Count : {novel.bookmark_count}")
# fake the fileUrl
fileUrl = f"https://www.pixiv.net/ajax/novel/{novel_id}.html"
filename = PixivHelper.make_filename(config.filenameFormatNovel,
novel,
tagsSeparator=config.tagsSeparator,
tagsLimit=config.tagsLimit,
fileUrl=fileUrl,
bookmark=False,
searchTags="",
useTranslatedTag=config.useTranslatedTag,
tagTranslationLocale=config.tagTranslationLocale)
filename = PixivHelper.sanitize_filename(filename, config.rootDirectory)
PixivHelper.print_and_log(None, f"Filename : {filename}")
# checking logic
if os.path.exists(filename):
if config.checkLastModified:
local_timestamp = os.path.getmtime(filename)
remote_timestamp = time.mktime(novel.worksDateDateTime.timetuple())
if local_timestamp == remote_timestamp:
PixivHelper.print_and_log('warn', f"\rLocal file timestamp match with remote: {filename} => {novel.worksDateDateTime}")
return
if config.alwaysCheckFileSize:
temp_filename = filename + ".!tmp"
novel.write_content(temp_filename)
file_size = os.path.getsize(temp_filename)
old_size = os.path.getsize(filename)
result = PixivHelper.check_file_exists(config, filename, file_size, old_size)
if result == PixivConstant.PIXIVUTIL_OK:
os.rename(temp_filename, filename)
else:
os.remove(temp_filename)
else:
novel.write_content(filename)
if config.setLastModified and filename is not None and os.path.isfile(filename):
ts = time.mktime(novel.worksDateDateTime.timetuple())
os.utime(filename, (ts, ts))
caller.__dbManager__.insertNovelPost(novel, filename)
print()
def process_novel_series(caller,
config,
series_id,
start_page=1,
end_page=0,
notifier=None):
if notifier is None:
notifier = PixivHelper.dummy_notifier
msg = Fore.YELLOW + Style.BRIGHT + f'Processing Novel Series: {series_id}' + Style.RESET_ALL
PixivHelper.print_and_log('info', msg)
novel_series = caller.__br__.getNovelSeries(series_id)
PixivHelper.print_and_log(None, f'Series Name : {novel_series.series_name}')
PixivHelper.print_and_log(None, f'Total Novel : {novel_series.total}')
page = start_page
flag = True
while (flag):
PixivHelper.print_and_log(None, f"Getting page = {page}")
novel_series = caller.__br__.getNovelSeriesContent(novel_series, current_page=page)
if end_page > 0 and page > end_page:
PixivHelper.print_and_log(None, f"Page limit reached = {end_page}.")
flag = False
if (page * PixivNovel.MAX_LIMIT) >= novel_series.total:
PixivHelper.print_and_log(None, "No more novel.")
flag = False
page = page + 1
for novel in novel_series.series_list:
process_novel(caller,
config,
novel_id=novel["id"],
notifier=notifier)
print()