mirror of
https://github.com/A-Minos/nonebot-plugin-tetris-stats.git
synced 2026-03-05 05:36:54 +08:00
* 🔥 删除现有模板 * ✨ 自动克隆模板仓库 * 🔥 删除 identicon 相关代码 * 🚚 修改静态文件路径 * ✨ 使用新模板进行渲染 * ✨ 每次渲染都获取一次模板, 以应对实时更新 * ✨ TETR.IO 绑定图使用新模板 * 🚚 修改网络路径 * ✨ TOP 绑定图使用新模板 * ✨ TOS 绑定图使用新模板 * 🐛 防止截图超时 * 🐛 Pydantic V1 会把 float 转换成 int * ✏️ 模板字段名写错了 * ✨ 兼容 Pydantic V1 * ✨ TETR.IO 查询图使用新模板 * 🐛 在查询的用户没有历史记录时不去查询更多记录
61 lines
2.3 KiB
Python
61 lines
2.3 KiB
Python
from asyncio.subprocess import PIPE, create_subprocess_exec
|
|
from shutil import rmtree
|
|
|
|
from nonebot import get_driver
|
|
from nonebot.log import logger
|
|
from nonebot_plugin_localstore import get_data_dir # type: ignore[import-untyped]
|
|
|
|
driver = get_driver()
|
|
|
|
templates_dir = get_data_dir('nonebot_plugin_tetris_stats') / 'templates'
|
|
|
|
|
|
@driver.on_startup
|
|
async def init_templates() -> None:
|
|
try:
|
|
await create_subprocess_exec('git', '--version', stdout=PIPE)
|
|
except FileNotFoundError as e:
|
|
raise RuntimeError(
|
|
'未找到 git, 请确保 git 已安装并在环境变量中\n安装步骤请参阅: https://git-scm.com/book/zh/v2/%E8%B5%B7%E6%AD%A5-%E5%AE%89%E8%A3%85-Git'
|
|
) from e
|
|
if not templates_dir.exists():
|
|
logger.info('模板仓库不存在, 正在尝试初始化...')
|
|
proc = await create_subprocess_exec(
|
|
'git',
|
|
'clone',
|
|
'-b',
|
|
'gh-pages',
|
|
'https://github.com/A-Minos/tetris-stats-templates',
|
|
templates_dir,
|
|
'--depth=1',
|
|
stdout=PIPE,
|
|
stderr=PIPE,
|
|
)
|
|
stdout, stderr = await proc.communicate()
|
|
if proc.returncode != 0:
|
|
for i in stderr.decode().splitlines():
|
|
logger.error(i)
|
|
raise RuntimeError('初始化模板仓库失败')
|
|
logger.success('模板仓库初始化成功')
|
|
return
|
|
proc = await create_subprocess_exec(
|
|
'git', 'rev-parse', '--is-inside-work-tree', stdout=PIPE, stderr=PIPE, cwd=templates_dir
|
|
)
|
|
stdout, stderr = await proc.communicate()
|
|
if proc.returncode != 0:
|
|
for i in stderr.decode().splitlines():
|
|
logger.error(i)
|
|
logger.warning('模板仓库状态异常, 尝试重新初始化')
|
|
rmtree(templates_dir)
|
|
await init_templates()
|
|
return
|
|
logger.info('正在更新模板仓库...')
|
|
proc = await create_subprocess_exec('git', 'pull', stdout=PIPE, stderr=PIPE, cwd=templates_dir)
|
|
stdout, stderr = await proc.communicate()
|
|
logger.info(stdout.decode().strip())
|
|
if proc.returncode != 0:
|
|
for i in stderr.decode().splitlines():
|
|
logger.error(i)
|
|
raise RuntimeError('更新模板仓库失败')
|
|
logger.success('模板仓库更新成功')
|