🎨 调整请求方式

This commit is contained in:
qwerdvd 2023-09-02 11:00:36 +08:00
parent 60e5d06a2d
commit 0dd7f64434
3 changed files with 85 additions and 63 deletions

View File

@ -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)

View File

@ -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

View 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}!'