MihoyoBBSTools/honkai3rd.py

94 lines
4.4 KiB
Python
Raw Normal View History

import time
import tools
import config
import random
import setting
from request import http
2022-01-06 05:49:25 +00:00
from loghelper import log
2021-10-25 14:53:34 +00:00
class honkai3rd:
def __init__(self) -> None:
self.headers = {
2021-10-25 14:53:34 +00:00
'Accept': 'application/json, text/plain, */*',
2022-01-06 05:49:25 +00:00
'DS': tools.get_ds(web=True, web_old=True),
2021-10-25 14:53:34 +00:00
'Origin': 'https://webstatic.mihoyo.com',
'x-rpc-app_version': setting.mihoyobbs_Version_old,
'User-Agent': 'Mozilla/5.0 (Linux; Android 9; Unspecified Device) AppleWebKit/537.36 (KHTML, like Gecko) '
'Version/4.0 Chrome/39.0.0.0 Mobile Safari/537.36 miHoYoBBS/2.3.0',
2021-10-25 14:53:34 +00:00
'x-rpc-client_type': setting.mihoyobbs_Client_type_web,
'Referer': f'https://webstatic.mihoyo.com/bh3/event/euthenia/index.html?bbs_presentation_style=fullscreen'
f'&bbs_game_role_required=bh3_cn&bbs_auth_required=t'
f'rue&act_id={setting.honkai3rd_Act_id}&utm_source=bbs&utm_medium=mys&utm_campaign=icon',
2021-10-25 14:53:34 +00:00
'Accept-Encoding': 'gzip, deflate',
'Accept-Language': 'zh-CN,en-US;q=0.8',
'X-Requested-With': 'com.mihoyo.hyperion',
"Cookie": config.mihoyobbs_Cookies,
2022-01-06 05:49:25 +00:00
'x-rpc-device_id': tools.get_device_id()
2021-10-25 14:53:34 +00:00
}
self.acc_List = self.Getacc_list()
2021-10-25 14:53:34 +00:00
# 获取绑定的账号列表
def Getacc_list(self) -> list:
2022-01-06 05:49:25 +00:00
log.info("正在获取米哈游账号绑定的崩坏3账号列表...")
temp_List = []
req = http.get(setting.honkai3rd_Account_info_url, headers=self.headers)
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-08-03 02:58:32 +00:00
exit(1)
for i in data["data"]["list"]:
temp_List.append([i["nickname"], i["game_uid"], i["region"]])
2022-01-06 05:49:25 +00:00
log.info(f"已获取到{len(temp_List)}个崩坏3账号信息")
2021-06-06 13:19:28 +00:00
return temp_List
2021-10-25 14:53:34 +00:00
# 获取今天已经签到了的dict
2021-11-01 16:24:44 +00:00
def Get_today_item(self, raw_data: list) -> dict:
# 用range进行循环当status等于0的时候上一个就是今天签到的dict
for i in range(len(raw_data)):
2021-06-06 13:19:28 +00:00
if raw_data[i]["status"] == 0:
2021-10-25 14:53:34 +00:00
return raw_data[i - 1]
2021-06-06 13:19:28 +00:00
if raw_data[i]["status"] == 1:
return raw_data[i]
if i == int(len(raw_data) - 1) and raw_data[i]["status"] != 0:
return raw_data[i]
2021-10-25 14:53:34 +00:00
# 判断签到
def Is_sign(self, region: str, uid: str, nickname: str):
2021-08-03 02:35:55 +00:00
req = http.get(setting.honkai3rd_Is_signurl.format(setting.honkai3rd_Act_id, region, uid), headers=self.headers)
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-08-03 02:58:32 +00:00
exit(1)
today_Item = self.Get_today_item(data["data"]["sign"]["list"])
2021-06-06 13:19:28 +00:00
if today_Item["status"] == 1:
return True
else:
2022-01-06 05:49:25 +00:00
log.info(f"舰长{nickname}今天已经签到过了~\r\n今天获得的奖励是{tools.get_item(today_Item)}")
2021-06-06 13:19:28 +00:00
return False
2021-10-25 14:53:34 +00:00
# 签到
2021-08-03 02:35:55 +00:00
def Sign_acc(self):
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))
2021-10-25 14:53:34 +00:00
is_data = self.Is_sign(region=i[2], uid=i[1], nickname=i[0])
2021-09-30 13:00:12 +00:00
if is_data:
time.sleep(random.randint(2, 8))
2021-08-03 02:35:55 +00:00
req = http.post(url=setting.honkai3rd_SignUrl, headers=self.headers,
2021-10-25 14:53:34 +00:00
json={'act_id': setting.honkai3rd_Act_id, 'region': i[2], 'uid': i[1]})
data = req.json()
2021-06-06 13:19:28 +00:00
if data["retcode"] == 0:
today_Item = self.Get_today_item(data["data"]["list"])
2022-01-06 05:49:25 +00:00
log.info(f"舰长{i[0]}签到成功~\r\n今天获得的奖励是{tools.get_item(today_Item)}")
2021-06-08 12:43:30 +00:00
elif data["retcode"] == -5003:
2021-10-25 14:53:34 +00:00
# 崩坏3应为奖励列表和签到信息在一起了加上上面已经可以进行了一次判断所以这里旧不重复再次执行判断来获取内容了
2022-01-06 05:49:25 +00:00
log.info(f"舰长{i[0]}今天已经签到过了~")
else:
2022-01-06 05:49:25 +00:00
log.warning("账号签到失败!")
2021-10-25 14:53:34 +00:00
print(req.text)
else:
2022-01-06 05:49:25 +00:00
log.warning("账号没有绑定任何崩坏3账号")