MihoyoBBSTools/genshin.py

85 lines
4.0 KiB
Python
Raw Normal View History

import time
2021-05-23 13:24:20 +00:00
import tools
import config
import random
2021-05-23 13:24:20 +00:00
import setting
from request import http
2022-01-06 05:49:25 +00:00
from loghelper import log
2022-01-29 06:21:24 +00:00
from error import CookieError
from account import get_account_list
2021-05-23 13:24:20 +00:00
2021-10-25 14:53:34 +00:00
2022-01-06 05:49:25 +00:00
class Genshin:
2021-05-23 13:24:20 +00:00
def __init__(self) -> None:
2022-04-28 06:29:18 +00:00
self.headers = setting.headers
self.headers['DS'] = tools.get_ds(web=True, web_old=True)
self.headers['Referer'] = 'https://webstatic.mihoyo.com/bbs/event/signin-ys/index.html?bbs_auth_required=true'\
f'&act_id={setting.genshin_Act_id}&utm_source=bbs&utm_medium=mys&utm_campaign=icon'
self.headers['Cookie'] = config.config["account"]["cookie"]
self.headers['x-rpc-device_id'] = tools.get_device_id()
self.acc_List = get_account_list("hk4e_cn", self.headers)
2021-06-06 13:19:28 +00:00
if len(self.acc_List) != 0:
2022-01-06 05:49:25 +00:00
self.sign_Give = self.get_signgive()
2021-10-25 14:53:34 +00:00
# 获取已经签到奖励列表
2022-01-06 05:49:25 +00:00
def get_signgive(self) -> list:
log.info("正在获取签到奖励列表...")
2021-10-25 14:53:34 +00:00
req = http.get(setting.genshin_Signlisturl.format(setting.genshin_Act_id), headers=self.headers)
2021-05-24 08:16:52 +00:00
data = req.json()
2021-06-06 13:19:28 +00:00
if data["retcode"] != 0:
2022-01-06 05:49:25 +00:00
log.warning("获取签到奖励列表失败")
2021-10-25 14:53:34 +00:00
print(req.text)
2021-06-06 13:19:28 +00:00
return data["data"]["awards"]
2021-10-25 14:53:34 +00:00
# 判断签到
2022-01-06 05:49:25 +00:00
def is_sign(self, region: str, uid: str):
2021-08-03 02:35:55 +00:00
req = http.get(setting.genshin_Is_signurl.format(setting.genshin_Act_id, region, uid), headers=self.headers)
2021-05-24 08:16:52 +00:00
data = req.json()
2021-06-06 13:19:28 +00:00
if data["retcode"] != 0:
2022-01-06 05:49:25 +00:00
log.warning("获取账号签到信息失败!")
2021-10-25 14:53:34 +00:00
print(req.text)
config.config["games"]["cn"]["genshin"] = False
2022-01-29 06:21:24 +00:00
config.save_config()
raise CookieError("BBS Cookie Errror")
2021-06-06 13:19:28 +00:00
return data["data"]
2021-10-25 14:53:34 +00:00
# 签到
2022-01-06 05:49:25 +00:00
def sign_account(self):
return_data = "原神: "
2021-06-06 13:19:28 +00:00
if len(self.acc_List) != 0:
for i in self.acc_List:
2022-01-06 05:49:25 +00:00
log.info(f"正在为旅行者{i[0]}进行签到...")
time.sleep(random.randint(2, 8))
2022-01-06 05:49:25 +00:00
is_data = self.is_sign(region=i[2], uid=i[1])
2021-09-30 13:00:12 +00:00
if is_data["first_bind"]:
2022-01-06 05:49:25 +00:00
log.warning(f"旅行者{i[0]}是第一次绑定米游社,请先手动签到一次")
2021-05-24 08:16:52 +00:00
else:
2022-01-06 05:49:25 +00:00
sign_days = is_data["total_sign_day"] - 1
2022-02-08 05:14:30 +00:00
ok = True
2021-09-30 13:00:12 +00:00
if is_data["is_sign"]:
2022-01-06 05:49:25 +00:00
log.info(f"旅行者{i[0]}今天已经签到过了~\r\n今天获得的奖励是{tools.get_item(self.sign_Give[sign_days])}")
2022-04-28 06:42:20 +00:00
sign_days += 1
else:
time.sleep(random.randint(2, 8))
2021-08-03 02:35:55 +00:00
req = http.post(url=setting.genshin_Signurl, headers=self.headers,
2021-10-25 14:53:34 +00:00
json={'act_id': setting.genshin_Act_id, 'region': i[2], 'uid': i[1]})
data = req.json()
2021-06-06 13:19:28 +00:00
if data["retcode"] == 0:
2022-04-24 05:09:47 +00:00
log.info(f"旅行者{i[0]}签到成功~\r\n今天获得的奖励是"
2022-04-24 05:06:26 +00:00
f"{tools.get_item(self.sign_Give[0 if sign_days == 0 else sign_days + 1])}")
2022-04-28 06:42:20 +00:00
sign_days += 2
2021-06-06 13:19:28 +00:00
elif data["retcode"] == -5003:
2022-01-06 05:49:25 +00:00
log.info(f"旅行者{i[0]}今天已经签到过了~\r\n今天获得的奖励是{tools.get_item(self.sign_Give[sign_days])}")
else:
2022-01-06 05:49:25 +00:00
log.warning("账号签到失败!")
2021-10-25 14:53:34 +00:00
print(req.text)
2022-02-08 05:14:30 +00:00
ok = False
if ok:
2022-04-28 06:42:20 +00:00
return_data += f"\n{i[0]}已连续签到{sign_days}\n今天获得的奖励是{tools.get_item(self.sign_Give[sign_days-1])}"
2022-01-30 03:58:31 +00:00
else:
2022-01-30 08:17:47 +00:00
return_data += f"\n{i[0]},本次签到失败"
else:
2022-01-06 05:49:25 +00:00
log.warning("账号没有绑定任何原神账号!")
2022-01-30 03:58:31 +00:00
return_data += "\n并没有绑定任何原神账号"
return return_data