forked from fzls/djc_helper
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathark_lottery_special_version.py
159 lines (120 loc) · 5.51 KB
/
ark_lottery_special_version.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
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
import datetime
from multiprocessing import freeze_support
from config import AccountConfig, CommonConfig, config, load_config
from djc_helper import DjcHelper, is_new_version_ark_lottery
from log import color, logger
from main_def import (
_show_head_line,
auto_send_cards,
check_proxy,
has_any_account_in_normal_run,
show_lottery_status,
show_multiprocessing_info,
)
from pool import close_pool, get_pool, get_pool_size, init_pool
from qq_login import QQLogin
from util import change_console_window_mode_async, change_title, pause, show_unexpected_exception_message
from version import author, now_version, ver_time
def check_all_skey_and_pskey(cfg):
if not has_any_account_in_normal_run(cfg):
return
_show_head_line("启动时检查各账号skey/pskey/openid是否过期")
QQLogin(cfg.common).check_and_download_chrome_ahead()
if cfg.common.enable_multiprocessing and cfg.is_all_account_auto_login():
logger.info(color("bold_yellow") + f"已开启多进程模式({get_pool_size()}),并检测到所有账号均使用自动登录模式,将开启并行登录模式")
get_pool().starmap(
do_check_all_skey_and_pskey,
[
(_idx + 1, account_config, cfg.common)
for _idx, account_config in enumerate(cfg.account_configs)
if account_config.is_enabled()
],
)
logger.info("全部账号检查完毕")
else:
for _idx, account_config in enumerate(cfg.account_configs):
idx = _idx + 1
if not account_config.is_enabled():
# 未启用的账户的账户不走该流程
continue
do_check_all_skey_and_pskey(idx, account_config, cfg.common)
def do_check_all_skey_and_pskey(idx: int, account_config: AccountConfig, common_config: CommonConfig):
if not account_config.is_enabled():
# 未启用的账户的账户不走该流程
return None
logger.warning(color("fg_bold_yellow") + f"------------检查第{idx}个账户({account_config.name})------------")
djcHelper = DjcHelper(account_config, common_config)
djcHelper.fetch_pskey()
djcHelper.check_skey_expired()
djcHelper.get_bind_role_list(print_warning=False)
def run(cfg):
_show_head_line("开始核心逻辑")
start_time = datetime.datetime.now()
if cfg.common.enable_multiprocessing:
logger.info(f"已开启多进程模式({get_pool_size()}),将并行运行~")
get_pool().starmap(
do_run,
[
(_idx + 1, account_config, cfg.common)
for _idx, account_config in enumerate(cfg.account_configs)
if account_config.is_enabled()
],
)
else:
for idx, account_config in enumerate(cfg.account_configs):
idx += 1
if not account_config.is_enabled():
logger.info(f"第{idx}个账号({account_config.name})未启用,将跳过")
continue
do_run(idx, account_config, cfg.common)
used_time = datetime.datetime.now() - start_time
_show_head_line(f"处理总计{len(cfg.account_configs)}个账户 共耗时 {used_time}")
def do_run(idx: int, account_config: AccountConfig, common_config: CommonConfig):
_show_head_line(f"开始处理第{idx}个账户({account_config.name})")
start_time = datetime.datetime.now()
djcHelper = DjcHelper(account_config, common_config)
djcHelper.check_skey_expired()
djcHelper.get_bind_role_list()
if is_new_version_ark_lottery():
djcHelper.dnf_ark_lottery()
else:
djcHelper.ark_lottery()
used_time = datetime.datetime.now() - start_time
_show_head_line(f"处理第{idx}个账户({account_config.name}) 共耗时 {used_time}")
def main():
special_version_name = "集卡特别版"
change_title(special_version_name)
# 最大化窗口
logger.info("尝试调整窗口显示模式,打包exe可能会运行的比较慢")
change_console_window_mode_async()
logger.warning(f"开始运行DNF蚊子腿小助手 {special_version_name},ver={now_version} {ver_time},powered by {author}")
logger.warning(color("fg_bold_cyan") + "如果觉得我的小工具对你有所帮助,想要支持一下我的话,可以帮忙宣传一下或打开付费指引/支持一下.png,扫码打赏哦~")
# 读取配置信息
load_config("config.toml", "config.toml.local")
cfg = config()
if len(cfg.account_configs) == 0:
raise Exception("未找到有效的账号配置,请检查是否正确配置。")
check_proxy(cfg)
pool_size = cfg.get_enabled_account_count() if cfg.common.enable_multiprocessing else 0
init_pool(pool_size)
change_title(special_version_name, multiprocessing_pool_size=pool_size)
show_multiprocessing_info(cfg)
check_all_skey_and_pskey(cfg)
# 正式进行流程
run(cfg)
auto_send_cards(cfg)
show_lottery_status("卡片赠送完毕后展示各账号抽卡卡片以及各礼包剩余可领取信息", cfg, need_show_tips=True)
# 运行结束展示下多进程信息
show_multiprocessing_info(cfg)
if __name__ == "__main__":
freeze_support()
try:
run_start_time = datetime.datetime.now()
main()
logger.warning(color("fg_bold_yellow") + f"运行完成,共用时{datetime.datetime.now() - run_start_time}")
except Exception as e:
show_unexpected_exception_message(e)
finally:
# 暂停一下,方便看结果
pause()
close_pool()