mirror of
https://github.com/A-Minos/nonebot-plugin-tetris-stats.git
synced 2026-03-05 05:36:54 +08:00
Compare commits
4 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| d35469cdef | |||
| 0cbae117aa | |||
| 25dc57d911 | |||
| 6042417b65 |
@@ -48,7 +48,8 @@ class Player:
|
|||||||
)
|
)
|
||||||
return self._user_profile
|
return self._user_profile
|
||||||
|
|
||||||
def _parse_profile(self, original_user_profile: bytes) -> UserProfile:
|
@staticmethod
|
||||||
|
def _parse_profile(original_user_profile: bytes) -> UserProfile:
|
||||||
html = etree.HTML(original_user_profile)
|
html = etree.HTML(original_user_profile)
|
||||||
user_name = html.xpath('//div[@class="mycontent"]/h1/text()')[0].replace("'s profile", '')
|
user_name = html.xpath('//div[@class="mycontent"]/h1/text()')[0].replace("'s profile", '')
|
||||||
today = None
|
today = None
|
||||||
|
|||||||
@@ -8,12 +8,20 @@ from nonebot_plugin_session_orm import get_session_persist_id # type: ignore[im
|
|||||||
from nonebot_plugin_user import get_user
|
from nonebot_plugin_user import get_user
|
||||||
|
|
||||||
from ...db import query_bind_info, trigger
|
from ...db import query_bind_info, trigger
|
||||||
from ...utils.metrics import get_metrics
|
from ...utils.exception import FallbackError
|
||||||
|
from ...utils.host import HostPage, get_self_netloc
|
||||||
|
from ...utils.metrics import TetrisMetricsBasicWithLPM, get_metrics
|
||||||
|
from ...utils.render import render
|
||||||
|
from ...utils.render.avatar import get_avatar
|
||||||
|
from ...utils.render.schemas.base import People
|
||||||
|
from ...utils.render.schemas.top_info import Data as InfoData
|
||||||
|
from ...utils.render.schemas.top_info import Info
|
||||||
|
from ...utils.screenshot import screenshot
|
||||||
from ...utils.typing import Me
|
from ...utils.typing import Me
|
||||||
from ..constant import CANT_VERIFY_MESSAGE
|
from ..constant import CANT_VERIFY_MESSAGE
|
||||||
from . import alc
|
from . import alc
|
||||||
from .api import Player
|
from .api import Player
|
||||||
from .api.schemas.user_profile import UserProfile
|
from .api.schemas.user_profile import Data, UserProfile
|
||||||
from .constant import GAME_TYPE
|
from .constant import GAME_TYPE
|
||||||
|
|
||||||
|
|
||||||
@@ -35,8 +43,10 @@ async def _(event: Event, matcher: Matcher, target: At | Me, event_session: Even
|
|||||||
)
|
)
|
||||||
if bind is None:
|
if bind is None:
|
||||||
await matcher.finish('未查询到绑定信息')
|
await matcher.finish('未查询到绑定信息')
|
||||||
message = CANT_VERIFY_MESSAGE
|
await (
|
||||||
await (message + make_query_text(await Player(user_name=bind.game_account, trust=True).get_profile())).finish()
|
UniMessage(CANT_VERIFY_MESSAGE)
|
||||||
|
+ await make_query_result(await Player(user_name=bind.game_account, trust=True).get_profile())
|
||||||
|
).finish()
|
||||||
|
|
||||||
|
|
||||||
@alc.assign('TOP.query')
|
@alc.assign('TOP.query')
|
||||||
@@ -47,7 +57,34 @@ async def _(account: Player, event_session: EventSession):
|
|||||||
command_type='query',
|
command_type='query',
|
||||||
command_args=[],
|
command_args=[],
|
||||||
):
|
):
|
||||||
await (make_query_text(await account.get_profile())).finish()
|
await (await make_query_result(await account.get_profile())).finish()
|
||||||
|
|
||||||
|
|
||||||
|
def get_avg_metrics(data: list[Data]) -> TetrisMetricsBasicWithLPM:
|
||||||
|
total_lpm = total_apm = 0.0
|
||||||
|
for value in data:
|
||||||
|
total_lpm += value.lpm
|
||||||
|
total_apm += value.apm
|
||||||
|
num = len(data)
|
||||||
|
return get_metrics(lpm=total_lpm / num, apm=total_apm / num)
|
||||||
|
|
||||||
|
|
||||||
|
async def make_query_image(profile: UserProfile) -> bytes:
|
||||||
|
if profile.today is None or profile.total is None:
|
||||||
|
raise FallbackError
|
||||||
|
today = get_metrics(lpm=profile.today.lpm, apm=profile.today.apm)
|
||||||
|
history = get_avg_metrics(profile.total)
|
||||||
|
async with HostPage(
|
||||||
|
await render(
|
||||||
|
'v1/top/info',
|
||||||
|
Info(
|
||||||
|
user=People(avatar=get_avatar(), name=profile.user_name),
|
||||||
|
today=InfoData(pps=today.pps, lpm=today.lpm, apm=today.apm, apl=today.apl),
|
||||||
|
history=InfoData(pps=history.pps, lpm=history.lpm, apm=history.apm, apl=history.apl),
|
||||||
|
),
|
||||||
|
)
|
||||||
|
) as page_hash:
|
||||||
|
return await screenshot(f'http://{get_self_netloc()}/host/{page_hash}.html')
|
||||||
|
|
||||||
|
|
||||||
def make_query_text(profile: UserProfile) -> UniMessage:
|
def make_query_text(profile: UserProfile) -> UniMessage:
|
||||||
@@ -60,15 +97,18 @@ def make_query_text(profile: UserProfile) -> UniMessage:
|
|||||||
else:
|
else:
|
||||||
message += f'用户 {profile.user_name} 暂无24小时内统计数据'
|
message += f'用户 {profile.user_name} 暂无24小时内统计数据'
|
||||||
if profile.total is not None:
|
if profile.total is not None:
|
||||||
total_lpm = total_apm = 0.0
|
total = get_avg_metrics(profile.total)
|
||||||
for value in profile.total:
|
|
||||||
total_lpm += value.lpm
|
|
||||||
total_apm += value.apm
|
|
||||||
num = len(profile.total)
|
|
||||||
total = get_metrics(lpm=total_lpm / num, apm=total_apm / num)
|
|
||||||
message += '\n历史统计数据为: '
|
message += '\n历史统计数据为: '
|
||||||
message += f"\nL'PM: {total.lpm} ( {total.pps} pps )"
|
message += f"\nL'PM: {total.lpm} ( {total.pps} pps )"
|
||||||
message += f'\nAPM: {total.apm} ( x{total.apl} )'
|
message += f'\nAPM: {total.apm} ( x{total.apl} )'
|
||||||
else:
|
else:
|
||||||
message += '\n暂无历史统计数据'
|
message += '\n暂无历史统计数据'
|
||||||
return UniMessage(message)
|
return UniMessage(message)
|
||||||
|
|
||||||
|
|
||||||
|
async def make_query_result(profile: UserProfile) -> UniMessage:
|
||||||
|
try:
|
||||||
|
return UniMessage.image(raw=await make_query_image(profile))
|
||||||
|
except FallbackError:
|
||||||
|
...
|
||||||
|
return make_query_text(profile)
|
||||||
|
|||||||
@@ -55,7 +55,7 @@ def _():
|
|||||||
|
|
||||||
|
|
||||||
@app.get('/host/{page_hash}.html', status_code=status.HTTP_200_OK)
|
@app.get('/host/{page_hash}.html', status_code=status.HTTP_200_OK)
|
||||||
async def _(page_hash: str) -> HTMLResponse:
|
def _(page_hash: str) -> HTMLResponse:
|
||||||
if page_hash in HostPage.pages:
|
if page_hash in HostPage.pages:
|
||||||
return HTMLResponse(HostPage.pages[page_hash])
|
return HTMLResponse(HostPage.pages[page_hash])
|
||||||
return NOT_FOUND
|
return NOT_FOUND
|
||||||
|
|||||||
@@ -56,7 +56,7 @@ async def download_templates(tag: str) -> Path:
|
|||||||
return path
|
return path
|
||||||
|
|
||||||
|
|
||||||
async def unzip_templates(zip_path: Path) -> Path:
|
def unzip_templates(zip_path: Path) -> Path:
|
||||||
logger.info('开始解压模板')
|
logger.info('开始解压模板')
|
||||||
temp_path = TEMPLATES_DIR.parent / f'temp_{time_ns()}'
|
temp_path = TEMPLATES_DIR.parent / f'temp_{time_ns()}'
|
||||||
with ZipFile(zip_path) as zip_file:
|
with ZipFile(zip_path) as zip_file:
|
||||||
@@ -91,7 +91,7 @@ async def check_hash(hash_file_path: Path) -> bool:
|
|||||||
|
|
||||||
async def init_templates(tag: str) -> bool:
|
async def init_templates(tag: str) -> bool:
|
||||||
logger.info(f'开始初始化模板 {tag}')
|
logger.info(f'开始初始化模板 {tag}')
|
||||||
temp_path = await unzip_templates(await download_templates(tag))
|
temp_path = unzip_templates(await download_templates(tag))
|
||||||
if not await check_hash(temp_path / 'hash.sha256'):
|
if not await check_hash(temp_path / 'hash.sha256'):
|
||||||
rmtree(temp_path)
|
rmtree(temp_path)
|
||||||
return False
|
return False
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
[tool.poetry]
|
[tool.poetry]
|
||||||
name = 'nonebot-plugin-tetris-stats'
|
name = 'nonebot-plugin-tetris-stats'
|
||||||
version = '1.4.6'
|
version = '1.4.7'
|
||||||
description = '一款基于 NoneBot2 的用于查询 Tetris 相关游戏数据的插件'
|
description = '一款基于 NoneBot2 的用于查询 Tetris 相关游戏数据的插件'
|
||||||
authors = ['scdhh <wallfjjd@gmail.com>']
|
authors = ['scdhh <wallfjjd@gmail.com>']
|
||||||
readme = 'README.md'
|
readme = 'README.md'
|
||||||
|
|||||||
Reference in New Issue
Block a user