mirror of
https://github.com/KimigaiiWuyi/GenshinUID.git
synced 2025-05-08 21:15:52 +08:00
✨ 支持文字版排名统计
(#493)
This commit is contained in:
parent
047a8056ce
commit
a3f6078a9f
@ -30,7 +30,7 @@ sv_get_enka = SV('面板查询', priority=10)
|
|||||||
sv_get_original_pic = SV('查看面板原图', priority=5)
|
sv_get_original_pic = SV('查看面板原图', priority=5)
|
||||||
|
|
||||||
|
|
||||||
@sv_akasha.on_fullmatch('排名统计')
|
@sv_akasha.on_command('排名统计')
|
||||||
async def sned_rank_data(bot: Bot, ev: Event):
|
async def sned_rank_data(bot: Bot, ev: Event):
|
||||||
# 获取uid
|
# 获取uid
|
||||||
uid = await get_uid(bot, ev)
|
uid = await get_uid(bot, ev)
|
||||||
|
@ -22,7 +22,7 @@ async def get_rank(uid: str) -> str:
|
|||||||
if len(rank_data) == 0:
|
if len(rank_data) == 0:
|
||||||
return '你还没有排名缓存, 请使用[强制刷新]生成/刷新数据!'
|
return '你还没有排名缓存, 请使用[强制刷新]生成/刷新数据!'
|
||||||
|
|
||||||
im_list = []
|
im_list = [f'UID {uid}']
|
||||||
|
|
||||||
for char in rank_data:
|
for char in rank_data:
|
||||||
raw_data = rank_data[char]
|
raw_data = rank_data[char]
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
MAIN_API = 'https://akasha.cv/api/filters/accounts/'
|
MAIN_API = 'https://akasha.cv/api/filters/accounts/'
|
||||||
RANK_API = 'https://akasha.cv/api/getCalculationsForUser/{}'
|
RANK_API = 'https://akasha.cv/api/getCalculationsForUser/{}'
|
||||||
DATA_API = 'https://akasha.cv/api/user/{}'
|
DATA_API = 'https://akasha.cv/api/user/{}'
|
||||||
|
REFRESH_API = 'https://akasha.cv/api/user/refresh/{}'
|
||||||
LEADERBOARD_API = (
|
LEADERBOARD_API = (
|
||||||
'https://akasha.cv/api/v2/leaderboards/categories?characterId={}'
|
'https://akasha.cv/api/v2/leaderboards/categories?characterId={}'
|
||||||
)
|
)
|
||||||
|
@ -4,7 +4,7 @@ from typing import Any, Dict, Union, Literal, Optional
|
|||||||
from gsuid_core.logger import logger
|
from gsuid_core.logger import logger
|
||||||
from aiohttp import TCPConnector, ClientSession, ContentTypeError
|
from aiohttp import TCPConnector, ClientSession, ContentTypeError
|
||||||
|
|
||||||
from .api import DATA_API, MAIN_API, RANK_API
|
from .api import DATA_API, MAIN_API, RANK_API, REFRESH_API
|
||||||
|
|
||||||
|
|
||||||
class _CvApi:
|
class _CvApi:
|
||||||
@ -15,6 +15,7 @@ class _CvApi:
|
|||||||
self.session = ClientSession(
|
self.session = ClientSession(
|
||||||
connector=TCPConnector(verify_ssl=self.ssl_verify)
|
connector=TCPConnector(verify_ssl=self.ssl_verify)
|
||||||
)
|
)
|
||||||
|
self.sessionID = None
|
||||||
|
|
||||||
async def get_session_id(self) -> str:
|
async def get_session_id(self) -> str:
|
||||||
async with self.session.get(MAIN_API) as resp:
|
async with self.session.get(MAIN_API) as resp:
|
||||||
@ -27,6 +28,7 @@ class _CvApi:
|
|||||||
sid = 'NVybrjSdSZISA0JRuKFoZIndoCfDWdA2'
|
sid = 'NVybrjSdSZISA0JRuKFoZIndoCfDWdA2'
|
||||||
sid = unquote(str(sid))
|
sid = unquote(str(sid))
|
||||||
sessionID = sid.split(".")[0].split(":")[-1]
|
sessionID = sid.split(".")[0].split(":")[-1]
|
||||||
|
self.sessionID = sessionID
|
||||||
return sessionID
|
return sessionID
|
||||||
|
|
||||||
async def get_base_data(self, uid: str) -> Union[Dict, int]:
|
async def get_base_data(self, uid: str) -> Union[Dict, int]:
|
||||||
@ -35,8 +37,17 @@ class _CvApi:
|
|||||||
DATA_API.format(uid), 'GET', self._HEADER, {'sessionID': sessionID}
|
DATA_API.format(uid), 'GET', self._HEADER, {'sessionID': sessionID}
|
||||||
)
|
)
|
||||||
|
|
||||||
|
async def get_refresh_data(self, uid: str) -> Union[Dict, int]:
|
||||||
|
return await self._cv_request(
|
||||||
|
REFRESH_API.format(uid),
|
||||||
|
'GET',
|
||||||
|
self._HEADER,
|
||||||
|
{'sessionID': self.sessionID},
|
||||||
|
)
|
||||||
|
|
||||||
async def get_rank_data(self, uid: str) -> Union[Dict, int]:
|
async def get_rank_data(self, uid: str) -> Union[Dict, int]:
|
||||||
await self.get_base_data(uid)
|
await self.get_base_data(uid)
|
||||||
|
await self.get_refresh_data(uid)
|
||||||
return await self._cv_request(
|
return await self._cv_request(
|
||||||
RANK_API.format(uid), 'GET', self._HEADER
|
RANK_API.format(uid), 'GET', self._HEADER
|
||||||
)
|
)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user