2024-04-01 12:29:04 +08:00
|
|
|
|
import base64
|
2024-03-29 14:58:24 +08:00
|
|
|
|
from typing import Any
|
|
|
|
|
|
2024-04-03 14:59:00 +08:00
|
|
|
|
import nonebot
|
2024-03-31 06:26:01 +08:00
|
|
|
|
import pip
|
2024-03-27 00:05:51 +08:00
|
|
|
|
from git import Repo
|
2024-04-01 12:29:04 +08:00
|
|
|
|
from nonebot import Bot, require, get_driver
|
|
|
|
|
from nonebot.exception import MockApiException
|
2024-03-30 06:04:17 +08:00
|
|
|
|
from nonebot.permission import SUPERUSER
|
2024-03-24 19:15:49 +08:00
|
|
|
|
|
2024-03-29 14:58:24 +08:00
|
|
|
|
from liteyuki.utils.config import config, load_from_yaml
|
2024-03-30 06:04:17 +08:00
|
|
|
|
from liteyuki.utils.data_manager import StoredConfig, common_db
|
2024-03-27 07:57:04 +08:00
|
|
|
|
from liteyuki.utils.language import get_user_lang
|
2024-03-30 06:04:17 +08:00
|
|
|
|
from liteyuki.utils.ly_typing import T_Bot, T_MessageEvent
|
2024-03-31 06:22:53 +08:00
|
|
|
|
from liteyuki.utils.message import Markdown as md
|
2024-04-03 01:03:25 +08:00
|
|
|
|
from liteyuki.utils.reloader import Reloader
|
2024-04-06 08:48:21 +08:00
|
|
|
|
from liteyuki.utils.resource import get_loaded_resource_packs, load_resources
|
2024-03-24 19:15:49 +08:00
|
|
|
|
|
2024-04-02 20:32:28 +08:00
|
|
|
|
require("nonebot_plugin_alconna"), require("nonebot_plugin_htmlrender")
|
2024-03-29 14:58:24 +08:00
|
|
|
|
from nonebot_plugin_alconna import on_alconna, Alconna, Args, Subcommand, Arparma
|
2024-03-24 22:04:51 +08:00
|
|
|
|
|
2024-03-30 06:04:17 +08:00
|
|
|
|
driver = get_driver()
|
|
|
|
|
|
2024-04-01 23:56:03 +08:00
|
|
|
|
markdown_image = common_db.first(StoredConfig(), default=StoredConfig()).config.get("markdown_image", False)
|
2024-04-01 12:29:04 +08:00
|
|
|
|
|
2024-04-06 04:23:01 +08:00
|
|
|
|
liteyuki = on_alconna(
|
|
|
|
|
command=Alconna(
|
|
|
|
|
"liteecho",
|
2024-03-24 19:15:49 +08:00
|
|
|
|
),
|
|
|
|
|
permission=SUPERUSER
|
|
|
|
|
)
|
|
|
|
|
|
2024-03-27 00:05:51 +08:00
|
|
|
|
update_liteyuki = on_alconna(
|
2024-03-31 18:54:04 +08:00
|
|
|
|
aliases={"更新轻雪"},
|
|
|
|
|
command=Alconna(
|
|
|
|
|
"update-liteyuki"
|
2024-03-27 00:05:51 +08:00
|
|
|
|
),
|
|
|
|
|
permission=SUPERUSER
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
reload_liteyuki = on_alconna(
|
2024-03-31 18:54:04 +08:00
|
|
|
|
aliases={"重启轻雪"},
|
|
|
|
|
command=Alconna(
|
|
|
|
|
"reload-liteyuki"
|
2024-03-27 00:05:51 +08:00
|
|
|
|
),
|
|
|
|
|
permission=SUPERUSER
|
|
|
|
|
)
|
|
|
|
|
|
2024-04-06 08:48:21 +08:00
|
|
|
|
reload_resources = on_alconna(
|
|
|
|
|
aliases={"重载资源"},
|
|
|
|
|
command=Alconna(
|
|
|
|
|
"reload-resources"
|
|
|
|
|
),
|
|
|
|
|
permission=SUPERUSER
|
|
|
|
|
)
|
|
|
|
|
|
2024-03-29 14:58:24 +08:00
|
|
|
|
cmd_config = on_alconna(
|
2024-03-31 18:54:04 +08:00
|
|
|
|
aliases={"配置"},
|
|
|
|
|
command=Alconna(
|
|
|
|
|
"config",
|
2024-03-29 14:58:24 +08:00
|
|
|
|
Subcommand(
|
|
|
|
|
"set",
|
|
|
|
|
Args["key", str]["value", Any],
|
|
|
|
|
alias=["设置"],
|
|
|
|
|
|
|
|
|
|
),
|
|
|
|
|
Subcommand(
|
|
|
|
|
"get",
|
|
|
|
|
Args["key", str, None],
|
|
|
|
|
alias=["查询"]
|
|
|
|
|
)
|
|
|
|
|
),
|
|
|
|
|
permission=SUPERUSER
|
|
|
|
|
)
|
|
|
|
|
|
2024-04-01 11:37:29 +08:00
|
|
|
|
switch_image_mode = on_alconna(
|
|
|
|
|
aliases={"切换图片模式"},
|
|
|
|
|
command=Alconna(
|
|
|
|
|
"switch-image-mode"
|
|
|
|
|
),
|
|
|
|
|
permission=SUPERUSER
|
|
|
|
|
)
|
|
|
|
|
|
2024-03-24 19:15:49 +08:00
|
|
|
|
|
2024-04-06 04:23:01 +08:00
|
|
|
|
@liteyuki.handle()
|
2024-03-24 19:15:49 +08:00
|
|
|
|
async def _(bot: T_Bot):
|
2024-04-06 04:23:01 +08:00
|
|
|
|
await liteyuki.finish(f"Hello, Liteyuki!\nBot {bot.self_id}")
|
2024-03-27 00:05:51 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@update_liteyuki.handle()
|
|
|
|
|
async def _(bot: T_Bot, event: T_MessageEvent):
|
|
|
|
|
# 使用git pull更新
|
2024-03-27 07:57:04 +08:00
|
|
|
|
ulang = get_user_lang(str(event.user_id))
|
2024-03-27 00:05:51 +08:00
|
|
|
|
origins = ["origin", "origin2"]
|
|
|
|
|
repo = Repo(".")
|
2024-04-03 14:57:11 +08:00
|
|
|
|
|
|
|
|
|
# Get the current HEAD commit
|
|
|
|
|
current_head_commit = repo.head.commit
|
|
|
|
|
|
|
|
|
|
# Fetch the latest information from the cloud
|
|
|
|
|
repo.remotes.origin.fetch()
|
|
|
|
|
|
|
|
|
|
# Get the latest HEAD commit
|
|
|
|
|
new_head_commit = repo.commit('origin/main')
|
|
|
|
|
|
|
|
|
|
# If the new HEAD commit is different from the current HEAD commit, there is a new commit
|
|
|
|
|
diffs = current_head_commit.diff(new_head_commit)
|
|
|
|
|
logs = ""
|
|
|
|
|
for diff in diffs.iter_change_type('M'):
|
|
|
|
|
logs += f"\n{diff.a_path}"
|
|
|
|
|
|
2024-03-27 00:05:51 +08:00
|
|
|
|
for origin in origins:
|
|
|
|
|
try:
|
|
|
|
|
repo.remotes[origin].pull()
|
|
|
|
|
break
|
|
|
|
|
except Exception as e:
|
2024-04-03 14:59:00 +08:00
|
|
|
|
nonebot.logger.error(f"Pull from {origin} failed: {e}")
|
2024-03-27 00:05:51 +08:00
|
|
|
|
reply = "Liteyuki updated!\n"
|
2024-03-27 07:57:04 +08:00
|
|
|
|
reply += f"```\n{logs}\n```\n"
|
2024-04-05 08:48:51 +08:00
|
|
|
|
btn_restart = md.cmd(ulang.get("liteyuki.restart_now"), "reload-liteyuki")
|
2024-03-31 06:26:01 +08:00
|
|
|
|
pip.main(["install", "-r", "requirements.txt"])
|
2024-03-27 07:57:04 +08:00
|
|
|
|
reply += f"{ulang.get('liteyuki.update_restart', RESTART=btn_restart)}"
|
2024-03-31 06:22:53 +08:00
|
|
|
|
await md.send_md(reply, bot, event=event, at_sender=False)
|
2024-03-27 00:05:51 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@reload_liteyuki.handle()
|
|
|
|
|
async def _():
|
|
|
|
|
await reload_liteyuki.send("Liteyuki reloading")
|
|
|
|
|
Reloader.reload(3)
|
2024-03-29 14:58:24 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@cmd_config.handle()
|
|
|
|
|
async def _(result: Arparma, event: T_MessageEvent, bot: T_Bot):
|
|
|
|
|
ulang = get_user_lang(str(event.user_id))
|
|
|
|
|
stored_config: StoredConfig = common_db.first(StoredConfig(), default=StoredConfig())
|
|
|
|
|
if result.subcommands.get("set"):
|
|
|
|
|
key, value = result.subcommands.get("set").args.get("key"), result.subcommands.get("set").args.get("value")
|
|
|
|
|
try:
|
|
|
|
|
value = eval(value)
|
|
|
|
|
except:
|
|
|
|
|
pass
|
|
|
|
|
stored_config.config[key] = value
|
|
|
|
|
common_db.upsert(stored_config)
|
|
|
|
|
await cmd_config.finish(f"{ulang.get('liteyuki.config_set_success', KEY=key, VAL=value)}")
|
|
|
|
|
elif result.subcommands.get("get"):
|
|
|
|
|
key = result.subcommands.get("get").args.get("key")
|
|
|
|
|
file_config = load_from_yaml("config.yml")
|
|
|
|
|
reply = f"{ulang.get('liteyuki.current_config')}"
|
|
|
|
|
if key:
|
|
|
|
|
reply += f"```dotenv\n{key}={file_config.get(key, stored_config.config.get(key))}\n```"
|
|
|
|
|
else:
|
|
|
|
|
reply = f"{ulang.get('liteyuki.current_config')}"
|
|
|
|
|
reply += f"\n{ulang.get('liteyuki.static_config')}\n```dotenv"
|
|
|
|
|
for k, v in file_config.items():
|
|
|
|
|
reply += f"\n{k}={v}"
|
|
|
|
|
reply += "\n```"
|
|
|
|
|
if len(stored_config.config) > 0:
|
|
|
|
|
reply += f"\n{ulang.get('liteyuki.stored_config')}\n```dotenv"
|
|
|
|
|
for k, v in stored_config.config.items():
|
|
|
|
|
reply += f"\n{k}={v}"
|
|
|
|
|
reply += "\n```"
|
2024-03-31 06:22:53 +08:00
|
|
|
|
await md.send_md(reply, bot, event=event)
|
2024-03-30 06:04:17 +08:00
|
|
|
|
|
|
|
|
|
|
2024-04-06 08:48:21 +08:00
|
|
|
|
@reload_resources.handle()
|
|
|
|
|
async def _(event: T_MessageEvent):
|
|
|
|
|
ulang = get_user_lang(str(event.user_id))
|
|
|
|
|
load_resources()
|
|
|
|
|
await reload_resources.finish(
|
|
|
|
|
ulang.get("liteyuki.reload_resources_success",
|
|
|
|
|
NUM=len(get_loaded_resource_packs())
|
|
|
|
|
)
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
2024-04-01 11:37:29 +08:00
|
|
|
|
@switch_image_mode.handle()
|
|
|
|
|
async def _(bot: T_Bot, event: T_MessageEvent):
|
2024-04-01 12:29:04 +08:00
|
|
|
|
global markdown_image
|
2024-04-01 11:46:47 +08:00
|
|
|
|
# 切换图片模式,False以图片形式发送,True以markdown形式发送
|
2024-04-01 11:37:29 +08:00
|
|
|
|
ulang = get_user_lang(str(event.user_id))
|
|
|
|
|
stored_config: StoredConfig = common_db.first(StoredConfig(), default=StoredConfig())
|
2024-04-01 11:46:47 +08:00
|
|
|
|
stored_config.config["markdown_image"] = not stored_config.config.get("markdown_image", False)
|
2024-04-01 12:29:04 +08:00
|
|
|
|
markdown_image = stored_config.config["markdown_image"]
|
2024-04-01 11:37:29 +08:00
|
|
|
|
common_db.upsert(stored_config)
|
2024-04-01 12:29:04 +08:00
|
|
|
|
await switch_image_mode.finish(ulang.get("liteyuki.image_mode_on" if stored_config.config["markdown_image"] else "liteyuki.image_mode_off"))
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# system hook
|
|
|
|
|
|
|
|
|
|
@Bot.on_calling_api
|
|
|
|
|
async def test_for_md_image(bot: T_Bot, api: str, data: dict):
|
2024-04-01 23:56:03 +08:00
|
|
|
|
if api in ["send_msg", "send_private_msg", "send_group_msg"] and markdown_image and data.get("user_id") != bot.self_id:
|
2024-04-01 12:29:04 +08:00
|
|
|
|
if api == "send_msg" and data.get("message_type") == "private" or api == "send_private_msg":
|
|
|
|
|
session_type = "private"
|
|
|
|
|
session_id = data.get("user_id")
|
|
|
|
|
elif api == "send_msg" and data.get("message_type") == "group" or api == "send_group_msg":
|
|
|
|
|
session_type = "group"
|
|
|
|
|
session_id = data.get("group_id")
|
|
|
|
|
else:
|
|
|
|
|
return
|
|
|
|
|
if len(data.get("message", [])) == 1 and data["message"][0].get("type") == "image":
|
|
|
|
|
file: str = data["message"][0].data.get("file")
|
|
|
|
|
# file:// http:// base64://
|
|
|
|
|
if file.startswith("http"):
|
|
|
|
|
result = await md.send_md(await md.image_async(file), bot, message_type=session_type, session_id=session_id)
|
|
|
|
|
elif file.startswith("file"):
|
|
|
|
|
file = file.replace("file://", "")
|
|
|
|
|
result = await md.send_image(open(file, "rb").read(), bot, message_type=session_type, session_id=session_id)
|
|
|
|
|
elif file.startswith("base64"):
|
|
|
|
|
file_bytes = base64.b64decode(file.replace("base64://", ""))
|
|
|
|
|
result = await md.send_image(file_bytes, bot, message_type=session_type, session_id=session_id)
|
|
|
|
|
else:
|
|
|
|
|
return
|
|
|
|
|
raise MockApiException(result=result)
|
2024-04-01 11:46:47 +08:00
|
|
|
|
|
2024-04-01 11:37:29 +08:00
|
|
|
|
|
2024-03-30 06:04:17 +08:00
|
|
|
|
@driver.on_startup
|
|
|
|
|
async def on_startup():
|
2024-04-02 20:32:28 +08:00
|
|
|
|
pass
|
2024-03-30 06:04:17 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@driver.on_shutdown
|
|
|
|
|
async def on_shutdown():
|
2024-04-02 20:32:28 +08:00
|
|
|
|
pass
|