mirror of
https://github.com/zhenxun-org/zhenxun_bot.git
synced 2025-12-15 14:22:55 +08:00
* ✨ 父级插件加载 * ✅ 添加测试:更新与添加插件 (#1594) * ✅ 测试更新与添加插件 * ✅ Sourcery建议 * 👷 添加pytest * 🎨 优化代码 * 🐛 bug修复 * 🐛修复添加插件返回403的问题 (#1595) * 完善测试方法 * vscode测试配置 * 重构插件安装过程 * 🎨 修改readme * Update README.md * 🐛 修改bug与版本锁定 * 🐛 修复超级用户对群组功能开关 * 🐛 修复插件商店检查插件更新问题 (#1597) * 🐛 修复插件商店检查插件更新问题 * 🐛 恶意命令检测问题 * 🐛 增加插件状态检查 (#1598) * ✅ 优化测试用例 * 🐛 更改插件更新与安装逻辑 * 🐛 修复更新群组成员信息 * 🎨 代码优化 * 🚀 更新Dockerfile (#1599) * 🎨 更新requirements * ➕ 添加依赖aiocache * ⚡ 添加github镜像 * ✨ 添加仓库目录多获取渠道 * 🐛 修复测试用例 * ✨ 添加API缓存 * 🎨 采取Sourcery建议 * 🐛 文件下载逻辑修改 * 🎨 优化代码 * 🐛 修复插件开关有时出现错误 * ✨ 重构自检ui * 🐛 自检html修正 * 修复签到逻辑bug,并使代码更灵活以适应签到好感度等级配置 (#1606) * 修复签到功能已知问题 * 修复签到功能已知问题 * 修改参数名称 * 修改uid判断 --------- Co-authored-by: HibiKier <45528451+HibiKier@users.noreply.github.com> * 🎨 代码结构优化 * 🐛 私聊时修改插件时删除私聊帮助 * 🐛 过滤父插件 * 🐛 修复自检在ARM上的问题 (#1607) * 🐛 修复自检在ARM上的问题 * ✅ 优化测试 * ✨ 支持mysql,psql,sqlite随机函数 * 🔧 VSCode配置修改 * 🔧 VSCode配置修改 * ✨ 添加金币排行 Co-Authored-By: HibiKier <45528451+HibiKier@users.noreply.github.com> * 📝 修改README Co-Authored-By: HibiKier <45528451+HibiKier@users.noreply.github.com> * 🔨 提取GitHub相关操作 (#1609) * 🔨 提取GitHub相关操作 * 🔨 重构API策略 * ✨ 签到/金币排行限制最大数量 (#1616) * ✨ 签到/金币排行限制最大数量 * 🐛 修复超级用户id获取问题 * 🐛 修复路径解压与挂载 (#1619) * 🐛 修复功能少时zhenxun帮助图片排序问题 (#1620) * 🐛 签到文本适应 (#1622) * 🐛 好感度排行提供默认值 (#1624) * 🎈 优先使用github api (#1625) * ✨ 重构帮助,限制普通用户查询管理插件 (#1626) * 🐛 修复群权限与插件等级匹配 (#1627) * ✨ 当管理员尝试ban真寻时将被反杀 (#1628) * ✨ 群组发言时间检测提供开关配置 (#1630) * 🐳 chore: 支持自动修改版本号 (#1629) * 🎈 perf(github_utils): 支持github url下载遍历 (#1632) * 🎈 perf(github_utils): 支持github url下载遍历 * 🐞 fix(http_utils): 修复一些下载问题 * 🦄 refactor(http_utils): 部分重构 * chore(version): Update version to v0.2.2-e6f17c4 --------- Co-authored-by: AkashiCoin <AkashiCoin@users.noreply.github.com> * 🧪 test(auto_update): 修复测试用例 (#1633) * 🐛 修复商店商品为空时报错 (#1634) * 🐛 修复群权限与插件等级匹配 (#1635) * ✨ message_build支持AtAll (#1639) * 🎈 perf: 使用commit号下载插件 (#1641) * 🎈 perf: 使用commit号下载插件 * chore(version): Update version to v0.2.2-f9c7360 --------- Co-authored-by: AkashiCoin <AkashiCoin@users.noreply.github.com> * 🐳 chore: 修改运行检查触发路径 (#1642) * 🐳 chore: 修改运行检查触发路径 * 🐳 chore: 添加tests目录 * ✨ 重构qq群事件处理 (#1643) * 🐛 签到名称自适应 (#1644) * 🎨 更新README (#1645) * 🐛 fix(http_utils): 流式下载Content-Length错误 (#1647) * 🐛 修复群组中帮助功能状态显示问题 (#1650) * 🐛 修复群欢迎消息设置 (#1651) * 🐛 修复webui下载后首次启动错误 (#1652) * 🐛 修复webui下载后首次启动错误 * chore(version): Update version to v0.2.2-4a8ef85 --------- Co-authored-by: HibiKier <HibiKier@users.noreply.github.com> * ✨ 移除默认图片文件夹:爬 (#1653) * ✨ 安装/移除插件提供插件安装/卸载方法用于插件初始化 (#1654) * ✨ 新增超级用户与管理员帮助模板 (#1655) * ✨ 新增个人信息命令 (#1657) * ✨ 修改个人信息菜单名称 (#1658) * ✨ 新增插件商店api (#1659) * ✨ 新增插件商店api * chore(version): Update version to v0.2.2-7e15f20 --------- Co-authored-by: HibiKier <HibiKier@users.noreply.github.com> * ✨ 将cd,block,count限制复原配置文件 (#1662) * 🎨 修改README (#1663) * 🎨 修改版本号 (#1664) * 🎨 修改requirements (#1665) --------- Co-authored-by: AkashiCoin <l1040186796@gmail.com> Co-authored-by: fanyinrumeng <42991257+fanyinrumeng@users.noreply.github.com> Co-authored-by: AkashiCoin <i@loli.vet> Co-authored-by: Elaga <1728903318@qq.com> Co-authored-by: AkashiCoin <AkashiCoin@users.noreply.github.com> Co-authored-by: HibiKier <HibiKier@users.noreply.github.com>
175 lines
5.1 KiB
Python
175 lines
5.1 KiB
Python
from io import BytesIO
|
|
from pathlib import Path
|
|
|
|
import nonebot
|
|
from pydantic import BaseModel
|
|
from nonebot.adapters.onebot.v11 import Message, MessageSegment
|
|
from nonebot_plugin_alconna import At, Text, AtAll, Image, Video, Voice, UniMessage
|
|
|
|
from zhenxun.services.log import logger
|
|
from zhenxun.configs.config import BotConfig
|
|
from zhenxun.utils._build_image import BuildImage
|
|
|
|
driver = nonebot.get_driver()
|
|
|
|
MESSAGE_TYPE = (
|
|
str
|
|
| int
|
|
| float
|
|
| Path
|
|
| bytes
|
|
| BytesIO
|
|
| BuildImage
|
|
| At
|
|
| AtAll
|
|
| Image
|
|
| Text
|
|
| Voice
|
|
| Video
|
|
)
|
|
|
|
|
|
class Config(BaseModel):
|
|
image_to_bytes: bool = False
|
|
|
|
|
|
class MessageUtils:
|
|
@classmethod
|
|
def __build_message(cls, msg_list: list[MESSAGE_TYPE]) -> list[Text | Image]:
|
|
"""构造消息
|
|
|
|
参数:
|
|
msg_list: 消息列表
|
|
|
|
返回:
|
|
list[Text | Text]: 构造完成的消息列表
|
|
"""
|
|
config = nonebot.get_plugin_config(Config)
|
|
message_list = []
|
|
for msg in msg_list:
|
|
if isinstance(msg, Image | Text | At | AtAll | Video | Voice):
|
|
message_list.append(msg)
|
|
elif isinstance(msg, str | int | float):
|
|
message_list.append(Text(str(msg)))
|
|
elif isinstance(msg, Path):
|
|
if msg.exists():
|
|
if config.image_to_bytes:
|
|
logger.debug("图片转为bytes发送", "MessageUtils")
|
|
image = BuildImage.open(msg)
|
|
message_list.append(Image(raw=image.pic2bytes()))
|
|
else:
|
|
message_list.append(Image(path=msg))
|
|
else:
|
|
logger.warning(f"图片路径不存在: {msg}")
|
|
elif isinstance(msg, bytes):
|
|
message_list.append(Image(raw=msg))
|
|
elif isinstance(msg, BytesIO):
|
|
message_list.append(Image(raw=msg))
|
|
elif isinstance(msg, BuildImage):
|
|
message_list.append(Image(raw=msg.pic2bytes()))
|
|
return message_list
|
|
|
|
@classmethod
|
|
def build_message(
|
|
cls, msg_list: MESSAGE_TYPE | list[MESSAGE_TYPE | list[MESSAGE_TYPE]]
|
|
) -> UniMessage:
|
|
"""构造消息
|
|
|
|
参数:
|
|
msg_list: 消息列表
|
|
|
|
返回:
|
|
UniMessage: 构造完成的消息列表
|
|
"""
|
|
message_list = []
|
|
if not isinstance(msg_list, list):
|
|
msg_list = [msg_list]
|
|
for m in msg_list:
|
|
_data = m if isinstance(m, list) else [m]
|
|
message_list += cls.__build_message(_data) # type: ignore
|
|
return UniMessage(message_list)
|
|
|
|
@classmethod
|
|
def custom_forward_msg(
|
|
cls,
|
|
msg_list: list[str | Message],
|
|
uin: str,
|
|
name: str = f"这里是{BotConfig.self_nickname}",
|
|
) -> list[dict]:
|
|
"""生成自定义合并消息
|
|
|
|
参数:
|
|
msg_list: 消息列表
|
|
uin: 发送者 QQ
|
|
name: 自定义名称
|
|
|
|
返回:
|
|
list[dict]: 转发消息
|
|
"""
|
|
mes_list = []
|
|
for _message in msg_list:
|
|
data = {
|
|
"type": "node",
|
|
"data": {
|
|
"name": name,
|
|
"uin": f"{uin}",
|
|
"content": _message,
|
|
},
|
|
}
|
|
mes_list.append(data)
|
|
return mes_list
|
|
|
|
@classmethod
|
|
def template2forward(cls, msg_list: list[UniMessage], uni: str) -> list[dict]:
|
|
"""模板转转发消息
|
|
|
|
参数:
|
|
msg_list: 消息列表
|
|
uni: 发送者qq
|
|
|
|
返回:
|
|
list[dict]: 转发消息
|
|
"""
|
|
forward_data = []
|
|
for r_list in msg_list:
|
|
s = ""
|
|
if isinstance(r_list, UniMessage | list):
|
|
for r in r_list:
|
|
if isinstance(r, Text):
|
|
s += str(r)
|
|
elif isinstance(r, Image):
|
|
if v := r.url or r.path:
|
|
s += MessageSegment.image(v)
|
|
elif isinstance(r_list, Image):
|
|
if v := r_list.url or r_list.path:
|
|
s = MessageSegment.image(v)
|
|
else:
|
|
s = str(r_list)
|
|
forward_data.append(s)
|
|
return cls.custom_forward_msg(forward_data, uni)
|
|
|
|
@classmethod
|
|
def template2alc(cls, msg_list: list[MessageSegment]) -> list:
|
|
"""模板转alc
|
|
|
|
参数:
|
|
msg_list: 消息列表
|
|
|
|
返回:
|
|
list: alc模板
|
|
"""
|
|
forward_data = []
|
|
for msg in msg_list:
|
|
if isinstance(msg, str):
|
|
forward_data.append(Text(msg))
|
|
elif msg.type == "at":
|
|
if msg.data["qq"] == "0":
|
|
forward_data.append(AtAll())
|
|
else:
|
|
forward_data.append(At(flag="user", target=msg.data["qq"]))
|
|
elif msg.type == "image":
|
|
forward_data.append(Image(url=msg.data["file"] or msg.data["url"]))
|
|
elif msg.type == "text" and msg.data["text"]:
|
|
forward_data.append(Text(msg.data["text"]))
|
|
return forward_data
|