mirror of
https://github.com/baiqwerdvd/ArknightsUID.git
synced 2025-05-08 04:55:54 +08:00
🎨 调整请求方式
This commit is contained in:
parent
60e5d06a2d
commit
0dd7f64434
@ -15,7 +15,6 @@ from ..utils.database.models import ArknightsBind
|
||||
from .sign import daily_sign, sign_in
|
||||
|
||||
SIGN_TIME = arkconfig.get_config('SignTime').data
|
||||
UID_HINT = '添加失败, 请先绑定明日方舟UID'
|
||||
|
||||
sv_sign = SV('森空岛签到')
|
||||
sv_sign_config = SV('森空岛管理', pm=2)
|
||||
|
@ -13,7 +13,7 @@ from ...models.skland.models import (
|
||||
ArknightsPlayerInfoModel,
|
||||
ArknightsUserMeModel,
|
||||
)
|
||||
from .api import ARK_PLAYER_INFO, ARK_SKD_SIGN, ARK_USER_ME
|
||||
from .api import ARK_GEN_CRED_BY_CODE, ARK_PLAYER_INFO, ARK_SKD_SIGN, ARK_USER_ME
|
||||
|
||||
proxy_url = core_plugins_config.get_config('proxy').data
|
||||
ssl_verify = core_plugins_config.get_config('MhySSLVerify').data
|
||||
@ -23,11 +23,11 @@ class BaseArkApi:
|
||||
proxy_url: str | None = proxy_url if proxy_url else None
|
||||
_HEADER: ClassVar[dict[str, str]] = {
|
||||
'Host': 'zonai.skland.com',
|
||||
'Platform': '1',
|
||||
'Origin': 'https://www.skland.com',
|
||||
'Referer': 'https://www.skland.com/',
|
||||
'content-type': 'application/json; charset=UTF-8',
|
||||
'user-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) \
|
||||
AppleWebKit/537.36 (KHTML, like Gecko) Chrome/115.0.0.0 Safari/537.36',
|
||||
'content-type': 'application/json',
|
||||
'user-agent': 'Skland/1.0.1 (com.hypergryph.skland; build:100001014; Android 33; ) Okhttp/4.11.0',
|
||||
}
|
||||
|
||||
async def _pass(self, gt: str, ch: str) -> tuple[str | None, str | None]:
|
||||
@ -50,7 +50,7 @@ class BaseArkApi:
|
||||
async def get_game_player_info(self, uid: str) -> int | ArknightsPlayerInfoModel:
|
||||
cred: str | None = await ArknightsUser.get_user_attr_by_uid(uid=uid, attr='cred')
|
||||
if cred is None:
|
||||
return -61
|
||||
return -60
|
||||
is_vaild = await self.check_cred_valid(cred)
|
||||
if isinstance(is_vaild, bool):
|
||||
await ArknightsUser.delete_user_data_by_uid(uid)
|
||||
@ -62,6 +62,8 @@ class BaseArkApi:
|
||||
params={'uid': uid},
|
||||
header=header,
|
||||
)
|
||||
if isinstance(raw_data, int):
|
||||
return raw_data
|
||||
unpack_data = self.unpack(raw_data)
|
||||
if isinstance(unpack_data, int):
|
||||
return unpack_data
|
||||
@ -71,7 +73,7 @@ class BaseArkApi:
|
||||
async def skd_sign(self, uid: str) -> int | ArknightsAttendanceModel:
|
||||
cred: str | None = await ArknightsUser.get_user_attr_by_uid(uid=uid, attr='cred')
|
||||
if cred is None:
|
||||
return -61
|
||||
return -60
|
||||
is_vaild = await self.check_cred_valid(cred)
|
||||
if isinstance(is_vaild, bool):
|
||||
await ArknightsUser.delete_user_data_by_uid(uid)
|
||||
@ -87,6 +89,8 @@ class BaseArkApi:
|
||||
},
|
||||
header=header,
|
||||
)
|
||||
if isinstance(raw_data, int):
|
||||
return raw_data
|
||||
unpack_data = self.unpack(raw_data)
|
||||
if isinstance(unpack_data, int):
|
||||
return unpack_data
|
||||
@ -96,7 +100,7 @@ class BaseArkApi:
|
||||
async def get_sign_info(self, uid: str) -> int | ArknightsAttendanceCalendarModel:
|
||||
cred: str | None = await ArknightsUser.get_user_attr_by_uid(uid=uid, attr='cred')
|
||||
if cred is None:
|
||||
return -61
|
||||
return -60
|
||||
is_vaild = await self.check_cred_valid(cred)
|
||||
if isinstance(is_vaild, bool):
|
||||
await ArknightsUser.delete_user_data_by_uid(uid)
|
||||
@ -112,6 +116,8 @@ class BaseArkApi:
|
||||
},
|
||||
header=header,
|
||||
)
|
||||
if isinstance(raw_data, int):
|
||||
return raw_data
|
||||
unpack_data = self.unpack(raw_data)
|
||||
if isinstance(unpack_data, int):
|
||||
return unpack_data
|
||||
@ -125,18 +131,28 @@ class BaseArkApi:
|
||||
if isinstance(raw_data, int):
|
||||
return False
|
||||
if 'code' in raw_data and raw_data['code'] == 10001:
|
||||
logger.info(f'cred is invalid {raw_data}')
|
||||
return False
|
||||
unpack_data = self.unpack(raw_data)
|
||||
if isinstance(unpack_data, int):
|
||||
return False
|
||||
else:
|
||||
return msgspec.convert(unpack_data, type=ArknightsUserMeModel)
|
||||
|
||||
def unpack(self, raw_data: dict | int) -> dict | int:
|
||||
if isinstance(raw_data, dict):
|
||||
return raw_data['data']
|
||||
async def check_code_valid(self, code: str) -> bool | str:
|
||||
data = {
|
||||
'kind': 1,
|
||||
'code': code
|
||||
}
|
||||
raw_data = await self._ark_request(
|
||||
ARK_GEN_CRED_BY_CODE,
|
||||
data=data
|
||||
)
|
||||
if isinstance(raw_data, int):
|
||||
return False
|
||||
else:
|
||||
return raw_data
|
||||
cred = raw_data['cred']
|
||||
return cred
|
||||
|
||||
def unpack(self, raw_data: dict) -> dict:
|
||||
return raw_data['data']
|
||||
|
||||
async def _ark_request(
|
||||
self,
|
||||
@ -152,22 +168,8 @@ class BaseArkApi:
|
||||
) as client:
|
||||
raw_data = {}
|
||||
if 'Cred' not in header:
|
||||
target_user_id = (
|
||||
data['friendUserId']
|
||||
if data and 'friendUserId' in data
|
||||
else None
|
||||
)
|
||||
Cred: str | None = await ArknightsUser.get_random_cookie(
|
||||
target_user_id if target_user_id else '18888888'
|
||||
)
|
||||
if Cred is None:
|
||||
return -61
|
||||
arkUser = await ArknightsUser.base_select_data(Cred=Cred)
|
||||
if arkUser is None:
|
||||
return -61
|
||||
header['Cred'] = Cred
|
||||
return 10001
|
||||
|
||||
for _ in range(3):
|
||||
async with client.request(
|
||||
method,
|
||||
url=url,
|
||||
@ -181,9 +183,14 @@ class BaseArkApi:
|
||||
raw_data = await resp.json()
|
||||
except ContentTypeError:
|
||||
_raw_data = await resp.text()
|
||||
raw_data = {'retcode': -999, 'data': _raw_data}
|
||||
raw_data = {'code': -999, 'data': _raw_data}
|
||||
logger.info(raw_data)
|
||||
|
||||
# 判断code
|
||||
if 'code' in raw_data and raw_data['code'] != 0:
|
||||
logger.info(raw_data)
|
||||
return raw_data
|
||||
|
||||
# 判断status
|
||||
if 'status' in raw_data and 'msg' in raw_data:
|
||||
retcode = 1
|
||||
@ -203,4 +210,4 @@ class BaseArkApi:
|
||||
return retcode
|
||||
else:
|
||||
return raw_data
|
||||
return -999
|
||||
return 10001
|
||||
|
16
ArknightsUID/utils/error_reply.py
Normal file
16
ArknightsUID/utils/error_reply.py
Normal file
@ -0,0 +1,16 @@
|
||||
UID_HINT = '添加失败, 请先绑定明日方舟UID'
|
||||
|
||||
def get_error(retcode: int | str) -> str:
|
||||
if retcode == 10001:
|
||||
return '请求体出错, 请检查具体实现代码...'
|
||||
if retcode == -10001:
|
||||
return '请求体出错, 请检查具体实现代码...'
|
||||
if retcode == -201:
|
||||
return '你的账号可能已被封禁, 请联系米游社客服...'
|
||||
if retcode == -501101:
|
||||
return '当前角色冒险等阶未达到10级, 暂时无法参加此活动...'
|
||||
if retcode == 400:
|
||||
return '[MINIGG]暂未找到此内容...'
|
||||
if retcode == -400:
|
||||
return '请输入更详细的名称...'
|
||||
return f'API报错, 错误码为{retcode}!'
|
Loading…
x
Reference in New Issue
Block a user