MihoyoBBSTools/tearsofthemis.py

93 lines
4.5 KiB
Python
Raw Permalink Normal View History

2022-07-19 08:30:10 +00:00
import time
import tools
import config
import random
import setting
from request import http
from loghelper import log
from error import CookieError
from account import get_account_list
2022-06-08 06:45:03 +00:00
class Tears_of_themis:
def __init__(self) -> None:
2022-08-19 00:54:54 +00:00
self.headers = {}
self.headers.update(setting.headers)
2022-08-05 04:25:10 +00:00
self.headers['DS'] = tools.get_ds(web=True)
2022-07-27 02:52:39 +00:00
self.headers['Referer'] = 'https://webstatic.mihoyo.com/bbs/event/signin/nxx/index.html?bbs_auth_required' \
'=true&bbs_presentation_style=fullscreen' \
f'act_id={setting.tearsofthemis_Act_id}'
2022-07-19 08:30:10 +00:00
self.headers['Cookie'] = config.config["account"]["cookie"]
self.headers['x-rpc-device_id'] = tools.get_device_id()
2022-09-01 00:30:19 +00:00
self.headers['User-Agent'] = tools.get_useragent()
2022-07-19 08:30:10 +00:00
self.account_list = get_account_list("nxx_cn", self.headers)
self.sign_day = 0
if len(self.account_list) != 0:
self.checkin_rewards = self.get_checkin_rewards()
def get_checkin_rewards(self) -> list:
log.info("正在获取签到奖励列表...")
req = http.get(setting.tearsofthemis_checkin_rewards, headers=self.headers)
2022-07-19 08:30:10 +00:00
data = req.json()
if data["retcode"] != 0:
log.warning("获取签到奖励列表失败")
print(req.text)
return data["data"]["awards"]
# 判断签到
def is_sign(self, region: str, uid: str) -> dict:
2022-07-27 02:52:39 +00:00
req = http.get(setting.tearsofthemis_Is_signurl.format(setting.tearsofthemis_Act_id, region, uid),
headers=self.headers)
2022-07-19 08:30:10 +00:00
data = req.json()
if data["retcode"] != 0:
log.warning("获取账号签到信息失败!")
print(req.text)
config.config["games"]["cn"]["tears_of_themis"]["auto_checkin"] = False
config.save_config()
raise CookieError("BBS Cookie Errror")
return data["data"]
# 签到
def sign_account(self) -> str:
return_data = "未定事件簿: "
if len(self.account_list) != 0:
for i in self.account_list:
if i[1] in config.config["games"]["cn"]["tears_of_themis"]["black_list"]:
continue
log.info(f"正在为未定事件簿玩家: {i[0]}进行签到...")
time.sleep(random.randint(2, 8))
is_data = self.is_sign(region=i[2], uid=i[1])
# if not is_data["is_sub"]: # 这个字段不知道干啥的,就先塞这里了
2022-07-27 02:52:39 +00:00
if False: # 算了先改成false
2022-07-19 08:30:10 +00:00
log.warning(f"旅行者{i[0]}是第一次绑定米游社,请先手动签到一次")
else:
sign_days = is_data["total_sign_day"] - 1
ok = True
if is_data["is_sign"]:
2022-07-27 02:52:39 +00:00
log.info(
f"未定事件簿玩家:{i[0]}今天已经签到过了~\r\n今天获得的奖励是{tools.get_item(self.checkin_rewards[sign_days])}")
2022-07-19 08:30:10 +00:00
sign_days += 1
else:
time.sleep(random.randint(2, 8))
2022-07-27 02:52:39 +00:00
req = http.post(url=setting.tearsofthemis_Sign_url, headers=self.headers,
2022-07-19 08:30:10 +00:00
json={'act_id': setting.tearsofthemis_Act_id, 'region': i[2], 'uid': i[1]})
data = req.json()
if data["retcode"] == 0:
log.info(f"未定事件簿玩家:{i[0]}签到成功~\r\n今天获得的奖励是"
f"{tools.get_item(self.checkin_rewards[0 if sign_days == 0 else sign_days + 1])}")
sign_days += 2
elif data["retcode"] == -5003:
2022-07-27 02:52:39 +00:00
log.info(
f"未定事件簿玩家:{i[0]}今天已经签到过了~\r\n今天获得的奖励是{tools.get_item(self.checkin_rewards[sign_days])}")
2022-07-19 08:30:10 +00:00
else:
log.warning("账号签到失败!")
ok = False
if ok:
return_data += f"\n{i[0]}已连续签到{sign_days}\n今天获得的奖励是{tools.get_item(self.checkin_rewards[sign_days - 1])}"
else:
return_data += f"\n{i[0]},本次签到失败"
else:
log.warning("账号没有绑定任何未定事件簿账号!")
return_data += "\n并没有绑定任何未定事件簿账号"
return return_data