zhenxun_bot/plugins/update_gocqhttp/__init__.py

75 lines
2.6 KiB
Python
Raw Normal View History

2021-05-20 19:25:51 +08:00
from nonebot import on_command
from nonebot.typing import T_State
from nonebot.adapters.cqhttp import Bot, GroupMessageEvent
from .data_source import download_gocq_lasted, upload_gocq_lasted
from services.log import logger
2021-10-03 14:24:07 +08:00
from utils.utils import scheduler, get_bot
from nonebot.permission import SUPERUSER
2021-11-04 16:11:50 +08:00
from configs.config import Config
2021-05-20 19:25:51 +08:00
from pathlib import Path
2021-11-23 21:44:59 +08:00
import os
2021-05-20 19:25:51 +08:00
2021-06-15 10:57:08 +08:00
2021-10-03 14:24:07 +08:00
__zx_plugin_name__ = "更新gocq [Superuser]"
__plugin_usage__ = """
usage
下载最新版gocq并上传至群文件
指令
更新gocq
""".strip()
__plugin_cmd__ = ["更新gocq"]
__plugin_version__ = 0.1
__plugin_author__ = "HibiKier"
2021-11-04 16:11:50 +08:00
__plugin_configs__ = {
"UPDATE_GOCQ_GROUP": {
"value": [],
"help": "需要为哪些群更新最新版gocq吗上传最新版gocq示例[434995955, 239483248]",
"default_value": [],
}
}
2021-05-20 19:25:51 +08:00
2021-10-03 14:24:07 +08:00
path = str((Path() / "resources" / "gocqhttp_file").absolute()) + "/"
2021-05-20 19:25:51 +08:00
2021-10-03 14:24:07 +08:00
lasted_gocqhttp = on_command("更新gocq", permission=SUPERUSER, priority=5, block=True)
2021-05-20 19:25:51 +08:00
@lasted_gocqhttp.handle()
async def _(bot: Bot, event: GroupMessageEvent, state: T_State):
# try:
2021-11-04 16:11:50 +08:00
if event.group_id in Config.get_config("update_gocqhttp", "UPDATE_GOCQ_GROUP"):
2021-07-30 21:21:51 +08:00
await lasted_gocqhttp.send("检测中...")
2021-06-04 18:01:33 +08:00
info = await download_gocq_lasted(path)
2021-07-30 21:21:51 +08:00
if info == "gocqhttp没有更新":
await lasted_gocqhttp.finish("gocqhttp没有更新")
2021-05-20 19:25:51 +08:00
try:
for file in os.listdir(path):
2021-06-04 18:01:33 +08:00
await upload_gocq_lasted(path, file, event.group_id)
2021-07-30 21:21:51 +08:00
logger.info(f"更新了cqhttp...{file}")
await lasted_gocqhttp.send(f"gocqhttp更新了已上传成功\n更新内容:\n{info}")
2021-05-20 19:25:51 +08:00
except Exception as e:
2021-07-30 21:21:51 +08:00
logger.error(f"更新gocq错误 e{e}")
2021-05-20 19:25:51 +08:00
# 更新gocq
@scheduler.scheduled_job(
2021-07-30 21:21:51 +08:00
"cron",
2021-05-20 19:25:51 +08:00
hour=3,
minute=1,
)
async def _():
2021-11-04 16:11:50 +08:00
if Config.get_config("update_gocqhttp", "UPDATE_GOCQ_GROUP"):
2021-05-20 19:25:51 +08:00
bot = get_bot()
try:
2021-06-04 18:01:33 +08:00
info = await download_gocq_lasted(path)
2021-07-30 21:21:51 +08:00
if info == "gocqhttp没有更新":
logger.info("gocqhttp没有更新")
2021-05-20 19:25:51 +08:00
return
2021-11-04 16:11:50 +08:00
for group in Config.get_config("update_gocqhttp", "UPDATE_GOCQ_GROUP"):
2021-05-20 19:25:51 +08:00
for file in os.listdir(path):
2021-06-04 18:01:33 +08:00
await upload_gocq_lasted(path, file, group)
2021-07-30 21:21:51 +08:00
await bot.send_group_msg(
group_id=group, message=f"gocqhttp更新了已上传成功\n更新内容:\n{info}"
)
2021-05-20 19:25:51 +08:00
except Exception as e:
2021-07-30 21:21:51 +08:00
logger.error(f"自动更新gocq出错 e:{e}")