mirror of
https://github.com/TriM-Organization/LiteyukiBot-TriM.git
synced 2024-11-28 16:24:51 +08:00
feat: 提供插件更新功能
This commit is contained in:
parent
f2fda7f92e
commit
e0dc840197
@ -30,7 +30,7 @@ class StorePlugin(LiteModel):
|
|||||||
|
|
||||||
def get_plugin_exist(plugin_name: str) -> bool:
|
def get_plugin_exist(plugin_name: str) -> bool:
|
||||||
"""
|
"""
|
||||||
获取插件是否存在
|
获取插件是否存在于加载列表
|
||||||
Args:
|
Args:
|
||||||
plugin_name:
|
plugin_name:
|
||||||
|
|
||||||
|
@ -213,7 +213,10 @@ async def _(result: Arparma, event: T_MessageEvent, bot: T_Bot, npm: Matcher):
|
|||||||
if len(rs):
|
if len(rs):
|
||||||
reply = f"{ulang.get('npm.search_result')} | {ulang.get('npm.total', TOTAL=len(rs))}\n***"
|
reply = f"{ulang.get('npm.search_result')} | {ulang.get('npm.total', TOTAL=len(rs))}\n***"
|
||||||
for storePlugin in rs[:min(max_show, len(rs))]:
|
for storePlugin in rs[:min(max_show, len(rs))]:
|
||||||
btn_install = md.btn_cmd(ulang.get("npm.install"), "npm install %s" % storePlugin.module_name)
|
btn_install_or_update = md.btn_cmd(
|
||||||
|
ulang.get("npm.update") if get_plugin_exist(storePlugin.module_name) else ulang.get("npm.install"),
|
||||||
|
"npm install %s" % storePlugin.module_name
|
||||||
|
)
|
||||||
link_page = md.btn_link(ulang.get("npm.homepage"), storePlugin.homepage)
|
link_page = md.btn_link(ulang.get("npm.homepage"), storePlugin.homepage)
|
||||||
link_pypi = md.btn_link(ulang.get("npm.pypi"), storePlugin.homepage)
|
link_pypi = md.btn_link(ulang.get("npm.pypi"), storePlugin.homepage)
|
||||||
|
|
||||||
@ -221,7 +224,7 @@ async def _(result: Arparma, event: T_MessageEvent, bot: T_Bot, npm: Matcher):
|
|||||||
f"\n> **{storePlugin.desc}**\n"
|
f"\n> **{storePlugin.desc}**\n"
|
||||||
f"\n> {ulang.get('npm.author')}: {storePlugin.author}"
|
f"\n> {ulang.get('npm.author')}: {storePlugin.author}"
|
||||||
f"\n> *{md.escape(storePlugin.module_name)}*"
|
f"\n> *{md.escape(storePlugin.module_name)}*"
|
||||||
f"\n> {btn_install} {link_page} {link_pypi}\n\n***\n")
|
f"\n> {btn_install_or_update} {link_page} {link_pypi}\n\n***\n")
|
||||||
if len(rs) > max_show:
|
if len(rs) > max_show:
|
||||||
reply += f"\n{ulang.get('npm.too_many_results', HIDE_NUM=len(rs) - max_show)}"
|
reply += f"\n{ulang.get('npm.too_many_results', HIDE_NUM=len(rs) - max_show)}"
|
||||||
else:
|
else:
|
||||||
@ -431,10 +434,12 @@ def npm_install(plugin_package_name) -> tuple[bool, str]:
|
|||||||
sys.stdout = buffer
|
sys.stdout = buffer
|
||||||
sys.stderr = buffer
|
sys.stderr = buffer
|
||||||
|
|
||||||
|
update = False
|
||||||
|
if get_plugin_exist(plugin_package_name):
|
||||||
|
update = True
|
||||||
|
|
||||||
mirrors = [
|
mirrors = [
|
||||||
"https://pypi.tuna.tsinghua.edu.cn/simple", # 清华大学
|
"https://pypi.tuna.tsinghua.edu.cn/simple", # 清华大学
|
||||||
"https://pypi.mirrors.cqupt.edu.cn/simple", # 重庆邮电大学
|
|
||||||
"https://pypi.liteyuki.icu/simple", # 轻雪代理镜像
|
|
||||||
"https://pypi.org/simple", # 官方源
|
"https://pypi.org/simple", # 官方源
|
||||||
]
|
]
|
||||||
|
|
||||||
@ -442,7 +447,10 @@ def npm_install(plugin_package_name) -> tuple[bool, str]:
|
|||||||
success = False
|
success = False
|
||||||
for mirror in mirrors:
|
for mirror in mirrors:
|
||||||
try:
|
try:
|
||||||
nonebot.logger.info(f"npm_install try mirror: {mirror}")
|
nonebot.logger.info(f"pip install try mirror: {mirror}")
|
||||||
|
if update:
|
||||||
|
result = pip.main(["install", "--upgrade", plugin_package_name, "-i", mirror])
|
||||||
|
else:
|
||||||
result = pip.main(["install", plugin_package_name, "-i", mirror])
|
result = pip.main(["install", plugin_package_name, "-i", mirror])
|
||||||
success = result == 0
|
success = result == 0
|
||||||
if success:
|
if success:
|
||||||
|
@ -120,3 +120,5 @@ liteyuki.change_priority_failed=资源包 {NAME} 优先级修改失败
|
|||||||
rpm.move_up=上移
|
rpm.move_up=上移
|
||||||
rpm.move_down=下移
|
rpm.move_down=下移
|
||||||
rpm.move_top=置顶
|
rpm.move_top=置顶
|
||||||
|
|
||||||
|
npm.update=更新
|
Loading…
Reference in New Issue
Block a user