mirror of
https://github.com/zhenxun-org/zhenxun_bot.git
synced 2025-12-14 21:52:56 +08:00
* ✨ feat(env): 支持git更新 * ✨ feat(aliyun): 更新阿里云URL构建逻辑,支持组织名称并优化令牌解码处理 * ✨ feat(config): 修改错误提示信息,更新基础配置文件名称为.env.example * ⚡ 插件商店支持aliyun * ✨ feat(store): 优化插件数据获取逻辑,合并插件列表和额外插件列表 * 🐛 修复非git仓库的初始化更新 * ✨ feat(update): 增强更新提示信息,添加非git源的变更文件说明 * 🎨 代码格式化 * ✨ webui与resources支持git更新 * ✨ feat(update): 更新webui路径处理逻辑 * Fix/test_runwork (#2001) * fix(test): 修复测试工作流 - 修改自动更新模块中的导入路径 - 更新插件商店模块中的插件信息获取逻辑 - 优化插件添加、更新和移除流程 - 统一插件相关错误信息的格式 - 调整测试用例以适应新的插件管理逻辑 * test(builtin_plugins): 重构插件商店相关测试 - 移除 jsd 相关测试用例,只保留 gh(GitHub)的测试 - 删除了 test_plugin_store.py 文件,清理了插件商店的测试 - 更新了 test_search_plugin.py 中的插件版本号 - 调整了 test_update_plugin.py 中的已加载插件版本 - 移除了 StoreManager 类中的 is_external 变量 - 更新了 RepoFileManager 类中的文件获取逻辑,优先使用 GitHub * ✨ feat(submodule): 添加子模块管理功能,支持子模块的初始化、更新和信息获取 * ✨ feat(update): 移除资源管理器,重构更新逻辑,支持通过ZhenxunRepoManager进行资源和Web UI的更新 * test(auto_update): 修改更新检测消息格式 (#2003) - 移除了不必要的版本号后缀(如 "-e6f17c4") - 统一了版本更新消息的格式,删除了冗余信息 * 🐛 修复web zip更新路径问题 * ⚡ 文件获取优化使用ali * Fix/test (#2008) * test: 修复bot测试 - 在 test_check_update.py 中跳过两个测试函数 - 移除 test_check.py 中的 mocked_api 参数和相关调用 - 删除 test_add_plugin.py 中的多个测试函数 - 移除 test_remove_plugin.py 中的 mocked_api 参数和相关调用 - 删除 test_search_plugin.py 中的多个测试函数 - 移除 test_update_all_plugin.py 和 test_update_plugin.py 中的 mocked_api 参数和相关调用 * 🚨 auto fix by pre-commit hooks --------- Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com> * 修复res zip更新路径问题 * 🐛 修复zhenxun更新zip占用问题 * ✨ feat(update): 优化资源更新逻辑,调整更新路径和消息处理 --------- Co-authored-by: molanp <104612722+molanp@users.noreply.github.com> Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
133 lines
4.7 KiB
Python
133 lines
4.7 KiB
Python
from nonebot.adapters import Bot
|
||
from nonebot.permission import SUPERUSER
|
||
from nonebot.plugin import PluginMetadata
|
||
from nonebot.rule import to_me
|
||
from nonebot_plugin_alconna import (
|
||
Alconna,
|
||
Args,
|
||
Match,
|
||
Option,
|
||
Query,
|
||
on_alconna,
|
||
store_true,
|
||
)
|
||
from nonebot_plugin_uninfo import Uninfo
|
||
|
||
from zhenxun.configs.utils import PluginExtraData
|
||
from zhenxun.services.log import logger
|
||
from zhenxun.utils.enum import PluginType
|
||
from zhenxun.utils.message import MessageUtils
|
||
|
||
from ._data_source import UpdateManager
|
||
|
||
__plugin_meta__ = PluginMetadata(
|
||
name="自动更新",
|
||
description="就算是真寻也会成长的",
|
||
usage="""
|
||
usage:
|
||
检查更新真寻最新版本,包括了自动更新
|
||
资源文件大小一般在130mb左右,除非必须更新一般仅更新代码文件
|
||
指令:
|
||
检查更新 [main|release|resource|webui] ?[-r] ?[-f] ?[-z] ?[-t]
|
||
main: main分支
|
||
release: 最新release
|
||
resource: 资源文件
|
||
webui: webui文件
|
||
-r: 下载资源文件,一般在更新main或release时使用
|
||
-f: 强制更新,一般用于更新main时使用(仅git更新时有效)
|
||
-s: 更新源,为 git 或 ali(默认使用ali)
|
||
-z: 下载zip文件进行更新(仅git有效)
|
||
-t: 更新方式,git或download(默认使用git)
|
||
git: 使用git pull(推荐)
|
||
download: 通过commit hash比较文件后下载更新(仅git有效)
|
||
|
||
示例:
|
||
检查更新 main
|
||
检查更新 main -r
|
||
检查更新 main -f
|
||
检查更新 release -r
|
||
检查更新 resource
|
||
检查更新 webui
|
||
""".strip(),
|
||
extra=PluginExtraData(
|
||
author="HibiKier",
|
||
version="0.1",
|
||
plugin_type=PluginType.SUPERUSER,
|
||
).to_dict(),
|
||
)
|
||
|
||
_matcher = on_alconna(
|
||
Alconna(
|
||
"检查更新",
|
||
Args["ver_type?", ["main", "release", "resource", "webui"]],
|
||
Option("-r|--resource", action=store_true, help_text="下载资源文件"),
|
||
Option("-f|--force", action=store_true, help_text="强制更新"),
|
||
Option("-s", Args["source?", ["git", "ali"]], help_text="更新源"),
|
||
Option("-z|--zip", action=store_true, help_text="下载zip文件"),
|
||
),
|
||
priority=1,
|
||
block=True,
|
||
permission=SUPERUSER,
|
||
rule=to_me(),
|
||
)
|
||
|
||
|
||
@_matcher.handle()
|
||
async def _(
|
||
bot: Bot,
|
||
session: Uninfo,
|
||
ver_type: Match[str],
|
||
resource: Query[bool] = Query("resource", False),
|
||
force: Query[bool] = Query("force", False),
|
||
source: Query[str] = Query("source", "ali"),
|
||
zip: Query[bool] = Query("zip", False),
|
||
):
|
||
result = ""
|
||
await MessageUtils.build_message("正在进行检查更新...").send(reply_to=True)
|
||
ver_type_str = ver_type.result
|
||
source_str = source.result
|
||
if ver_type_str in {"main", "release"}:
|
||
if not ver_type.available:
|
||
result += await UpdateManager.check_version()
|
||
logger.info("查看当前版本...", "检查更新", session=session)
|
||
await MessageUtils.build_message(result).finish()
|
||
try:
|
||
result += await UpdateManager.update_zhenxun(
|
||
bot,
|
||
session.user.id,
|
||
ver_type_str, # type: ignore
|
||
force.result,
|
||
source_str, # type: ignore
|
||
zip.result,
|
||
)
|
||
except Exception as e:
|
||
logger.error("版本更新失败...", "检查更新", session=session, e=e)
|
||
await MessageUtils.build_message(f"更新版本失败...e: {e}").finish()
|
||
elif ver_type.result == "webui":
|
||
if zip.result:
|
||
source_str = None
|
||
try:
|
||
result += await UpdateManager.update_webui(
|
||
source_str, # type: ignore
|
||
"test",
|
||
True,
|
||
)
|
||
except Exception as e:
|
||
logger.error("WebUI更新失败...", "检查更新", session=session, e=e)
|
||
result += "\nWebUI更新错误..."
|
||
if resource.result or ver_type.result == "resource":
|
||
try:
|
||
if zip.result:
|
||
source_str = None
|
||
result += await UpdateManager.update_resources(
|
||
source_str, # type: ignore
|
||
"main",
|
||
force.result,
|
||
)
|
||
except Exception as e:
|
||
logger.error("资源更新下载失败...", "检查更新", session=session, e=e)
|
||
result += "\n资源更新错误..."
|
||
if result:
|
||
await MessageUtils.build_message(result.strip()).finish()
|
||
await MessageUtils.build_message("更新版本失败...").finish()
|