zhenxun_bot/zhenxun/builtin_plugins/web_ui/public/data_source.py

44 lines
1.6 KiB
Python
Raw Normal View History

2024-08-23 18:41:35 +08:00
import shutil
import zipfile
from pathlib import Path
2024-08-24 19:32:52 +08:00
2024-08-23 18:41:35 +08:00
from nonebot.utils import run_sync
2024-08-24 19:32:52 +08:00
2024-08-23 18:41:35 +08:00
from zhenxun.services.log import logger
from zhenxun.utils.http_utils import AsyncHttpx
from zhenxun.utils.github_utils import parse_github_url
2024-08-23 18:41:35 +08:00
from ..config import TMP_PATH, PUBLIC_PATH, WEBUI_DIST_GITHUB_URL
COMMAND_NAME = "WebUI资源管理"
2024-08-23 18:41:35 +08:00
async def update_webui_assets():
webui_assets_path = TMP_PATH / "webui_assets.zip"
download_url = await parse_github_url(
WEBUI_DIST_GITHUB_URL
).get_archive_download_url()
2024-08-23 18:41:35 +08:00
if await AsyncHttpx.download_file(
download_url, webui_assets_path, follow_redirects=True
2024-08-23 18:41:35 +08:00
):
logger.info("下载 webui_assets 成功...", COMMAND_NAME)
2024-08-24 19:32:52 +08:00
return await _file_handle(webui_assets_path)
raise Exception("下载 webui_assets 失败", COMMAND_NAME)
2024-08-23 18:41:35 +08:00
@run_sync
def _file_handle(webui_assets_path: Path):
logger.debug("开始解压 webui_assets...", COMMAND_NAME)
if webui_assets_path.exists():
tf = zipfile.ZipFile(webui_assets_path)
tf.extractall(TMP_PATH)
logger.debug("解压 webui_assets 成功...", COMMAND_NAME)
else:
2024-08-24 19:32:52 +08:00
raise Exception("解压 webui_assets 失败,文件不存在...", COMMAND_NAME)
download_file_path = TMP_PATH / next(iter(TMP_PATH.iterdir()))
2024-08-23 18:41:35 +08:00
shutil.rmtree(PUBLIC_PATH, ignore_errors=True)
shutil.copytree(download_file_path / "dist", PUBLIC_PATH, dirs_exist_ok=True)
logger.debug("复制 webui_assets 成功...", COMMAND_NAME)
shutil.rmtree(TMP_PATH, ignore_errors=True)
return [x.name for x in PUBLIC_PATH.iterdir()]