2021-05-25 09:45:35 +00:00
|
|
|
|
import time
|
2021-05-23 13:24:20 +00:00
|
|
|
|
import tools
|
|
|
|
|
import config
|
2021-05-25 09:45:35 +00:00
|
|
|
|
import random
|
2022-10-08 07:59:54 +00:00
|
|
|
|
import captcha
|
2021-05-23 13:24:20 +00:00
|
|
|
|
import setting
|
2022-08-18 08:36:48 +00:00
|
|
|
|
from error import *
|
2021-06-13 02:33:38 +00:00
|
|
|
|
from request import http
|
2022-01-06 05:49:25 +00:00
|
|
|
|
from loghelper import log
|
2022-04-23 00:47:10 +00:00
|
|
|
|
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-08-18 08:36:48 +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-08-18 08:36:48 +00:00
|
|
|
|
self.headers['Referer'] = 'https://webstatic.mihoyo.com/bbs/event/signin-ys/index.html?bbs_auth_required=true' \
|
2022-04-28 06:29:18 +00:00
|
|
|
|
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()
|
2022-09-01 00:30:19 +00:00
|
|
|
|
self.headers['User-Agent'] = tools.get_useragent()
|
2022-05-01 02:33:20 +00:00
|
|
|
|
self.account_list = get_account_list("hk4e_cn", self.headers)
|
|
|
|
|
if len(self.account_list) != 0:
|
|
|
|
|
self.checkin_rewards = self.get_checkin_rewards()
|
2021-05-25 09:45:35 +00:00
|
|
|
|
|
2021-10-25 14:53:34 +00:00
|
|
|
|
# 获取已经签到奖励列表
|
2022-05-01 02:33:20 +00:00
|
|
|
|
def get_checkin_rewards(self) -> list:
|
2022-01-06 05:49:25 +00:00
|
|
|
|
log.info("正在获取签到奖励列表...")
|
2022-05-01 02:33:20 +00:00
|
|
|
|
req = http.get(setting.genshin_checkin_rewards, 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-05-25 09:45:35 +00:00
|
|
|
|
|
2021-10-25 14:53:34 +00:00
|
|
|
|
# 判断签到
|
2022-04-30 01:00:07 +00:00
|
|
|
|
def is_sign(self, region: str, uid: str) -> dict:
|
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)
|
2022-04-28 07:08:27 +00:00
|
|
|
|
config.config["games"]["cn"]["genshin"]["auto_checkin"] = 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-05-25 09:45:35 +00:00
|
|
|
|
|
2022-08-18 08:36:48 +00:00
|
|
|
|
def check_in(self, account):
|
2022-10-08 07:59:54 +00:00
|
|
|
|
header = {}
|
|
|
|
|
header.update(self.headers)
|
2022-08-19 00:54:30 +00:00
|
|
|
|
for i in range(4):
|
2022-08-30 01:47:35 +00:00
|
|
|
|
if i != 0:
|
|
|
|
|
log.info(f'触发验证码,即将进行第{i}次重试,最多3次')
|
2022-10-08 07:59:54 +00:00
|
|
|
|
req = http.post(url=setting.genshin_Signurl, headers=header,
|
2022-08-18 08:36:48 +00:00
|
|
|
|
json={'act_id': setting.genshin_Act_id, 'region': account[2], 'uid': account[1]})
|
2022-08-30 01:47:35 +00:00
|
|
|
|
if req.status_code == 429:
|
|
|
|
|
time.sleep(10) # 429同ip请求次数过多,尝试sleep10s进行解决
|
|
|
|
|
log.warning(f'429 Too Many Requests ,即将进入下一次请求')
|
|
|
|
|
continue
|
2022-08-18 08:36:48 +00:00
|
|
|
|
data = req.json()
|
|
|
|
|
if data["retcode"] == 0 and data["data"]["success"] == 1:
|
2022-10-08 13:36:35 +00:00
|
|
|
|
validate = captcha.game_captcha(data["data"]["gt"], data["data"]["challenge"])
|
2022-10-08 07:59:54 +00:00
|
|
|
|
if validate is not None:
|
|
|
|
|
header["x-rpc-challenge"] = data["data"]["challenge"]
|
|
|
|
|
header["x-rpc-validate"] = validate
|
|
|
|
|
header["x-rpc-seccode"] = f'{validate}|jordan'
|
2022-08-30 01:47:35 +00:00
|
|
|
|
time.sleep(random.randint(6, 15))
|
2022-08-18 08:36:48 +00:00
|
|
|
|
else:
|
|
|
|
|
break
|
|
|
|
|
return req
|
|
|
|
|
|
2021-10-25 14:53:34 +00:00
|
|
|
|
# 签到
|
2022-04-30 01:00:07 +00:00
|
|
|
|
def sign_account(self) -> str:
|
2022-04-23 00:47:10 +00:00
|
|
|
|
return_data = "原神: "
|
2022-05-01 02:33:20 +00:00
|
|
|
|
if len(self.account_list) != 0:
|
|
|
|
|
for i in self.account_list:
|
2022-04-28 07:08:27 +00:00
|
|
|
|
if i[1] in config.config["games"]["cn"]["genshin"]["black_list"]:
|
|
|
|
|
continue
|
2022-01-06 05:49:25 +00:00
|
|
|
|
log.info(f"正在为旅行者{i[0]}进行签到...")
|
2021-08-06 00:53:51 +00:00
|
|
|
|
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-08-18 08:36:48 +00:00
|
|
|
|
ok = True
|
2022-08-18 08:40:31 +00:00
|
|
|
|
if is_data["is_sign"]:
|
2022-05-01 02:33:20 +00:00
|
|
|
|
log.info(f"旅行者{i[0]}今天已经签到过了~\r\n今天获得的奖励是{tools.get_item(self.checkin_rewards[sign_days])}")
|
2022-04-28 06:42:20 +00:00
|
|
|
|
sign_days += 1
|
2021-05-24 11:48:03 +00:00
|
|
|
|
else:
|
2021-08-06 00:53:51 +00:00
|
|
|
|
time.sleep(random.randint(2, 8))
|
2022-08-18 08:36:48 +00:00
|
|
|
|
req = self.check_in(i)
|
2022-08-30 01:47:35 +00:00
|
|
|
|
if req.status_code != 429:
|
|
|
|
|
data = req.json()
|
|
|
|
|
if data["retcode"] == 0 and data["data"]["success"] == 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:
|
|
|
|
|
log.info(
|
|
|
|
|
f"旅行者{i[0]}今天已经签到过了~\r\n今天获得的奖励是{tools.get_item(self.checkin_rewards[sign_days])}")
|
|
|
|
|
else:
|
|
|
|
|
s = "账号签到失败!"
|
|
|
|
|
if data["data"] != "" and data.get("data").get("success", -1):
|
|
|
|
|
s += "原因: 验证码\njson信息:" + req.text
|
|
|
|
|
log.warning(s)
|
|
|
|
|
ok = False
|
2021-06-06 04:16:28 +00:00
|
|
|
|
else:
|
2022-02-08 05:14:30 +00:00
|
|
|
|
ok = False
|
2022-08-30 01:50:03 +00:00
|
|
|
|
data = {}
|
2022-02-08 05:14:30 +00:00
|
|
|
|
if ok:
|
2022-08-18 08:36:48 +00:00
|
|
|
|
return_data += f"\n{i[0]}已连续签到{sign_days}天\n" \
|
|
|
|
|
f"今天获得的奖励是{tools.get_item(self.checkin_rewards[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]},本次签到失败"
|
2022-08-30 01:50:03 +00:00
|
|
|
|
if data.get("data") is not None and data.get("data").get("success", -1) == 1:
|
2022-08-11 13:27:15 +00:00
|
|
|
|
return_data += ",失败原因: 触发验证码"
|
2021-06-06 04:16:28 +00:00
|
|
|
|
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
|