mirror of
https://github.com/zhenxun-org/zhenxun_bot.git
synced 2025-12-15 06:12:53 +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>
217 lines
7.5 KiB
Python
217 lines
7.5 KiB
Python
import time
|
||
from datetime import datetime
|
||
|
||
from nonebot.plugin import PluginMetadata
|
||
from nonebot import on_message, on_request
|
||
from nonebot_plugin_session import EventSession
|
||
from nonebot_plugin_apscheduler import scheduler
|
||
from nonebot.adapters.onebot.v11 import Bot as v11Bot
|
||
from nonebot.adapters.onebot.v12 import Bot as v12Bot
|
||
from nonebot.adapters.onebot.v11 import (
|
||
ActionFailed,
|
||
GroupRequestEvent,
|
||
FriendRequestEvent,
|
||
)
|
||
|
||
from zhenxun.services.log import logger
|
||
from zhenxun.models.fg_request import FgRequest
|
||
from zhenxun.utils.platform import PlatformUtils
|
||
from zhenxun.models.friend_user import FriendUser
|
||
from zhenxun.configs.config import Config, BotConfig
|
||
from zhenxun.models.group_console import GroupConsole
|
||
from zhenxun.configs.utils import RegisterConfig, PluginExtraData
|
||
from zhenxun.utils.enum import PluginType, RequestType, RequestHandleType
|
||
|
||
base_config = Config.get("invite_manager")
|
||
|
||
__plugin_meta__ = PluginMetadata(
|
||
name="记录请求",
|
||
description="记录 好友/群组 请求",
|
||
usage="",
|
||
extra=PluginExtraData(
|
||
author="HibiKier",
|
||
version="0.1",
|
||
plugin_type=PluginType.HIDDEN,
|
||
configs=[
|
||
RegisterConfig(
|
||
module="invite_manager",
|
||
key="AUTO_ADD_FRIEND",
|
||
value=False,
|
||
help="是否自动同意好友添加",
|
||
type=bool,
|
||
default_value=False,
|
||
)
|
||
],
|
||
).dict(),
|
||
)
|
||
|
||
|
||
class Timer:
|
||
data: dict[str, float] = {} # noqa: RUF012
|
||
|
||
@classmethod
|
||
def check(cls, uid: int | str):
|
||
return True if uid not in cls.data else time.time() - cls.data[uid] > 5 * 60
|
||
|
||
@classmethod
|
||
def clear(cls):
|
||
now = time.time()
|
||
cls.data = {k: v for k, v in cls.data.items() if v - now < 5 * 60}
|
||
|
||
|
||
# TODO: 其他平台请求
|
||
|
||
friend_req = on_request(priority=5, block=True)
|
||
group_req = on_request(priority=5, block=True)
|
||
_t = on_message(priority=999, block=False, rule=lambda: False)
|
||
|
||
|
||
@friend_req.handle()
|
||
async def _(bot: v12Bot | v11Bot, event: FriendRequestEvent, session: EventSession):
|
||
if event.user_id and Timer.check(event.user_id):
|
||
logger.debug("收录好友请求...", "好友请求", target=event.user_id)
|
||
user = await bot.get_stranger_info(user_id=event.user_id)
|
||
nickname = user["nickname"]
|
||
# sex = user["sex"]
|
||
# age = str(user["age"])
|
||
comment = event.comment
|
||
if base_config.get("AUTO_ADD_FRIEND"):
|
||
logger.debug(
|
||
"已开启好友请求自动同意,成功通过该请求",
|
||
"好友请求",
|
||
target=event.user_id,
|
||
)
|
||
await bot.set_friend_add_request(flag=event.flag, approve=True)
|
||
await FriendUser.create(
|
||
user_id=str(user["user_id"]), user_name=user["nickname"]
|
||
)
|
||
else:
|
||
# 旧请求全部设置为过期
|
||
await FgRequest.filter(
|
||
request_type=RequestType.FRIEND,
|
||
user_id=str(event.user_id),
|
||
handle_type__isnull=True,
|
||
).update(handle_type=RequestHandleType.EXPIRE)
|
||
f = await FgRequest.create(
|
||
request_type=RequestType.FRIEND,
|
||
platform=session.platform,
|
||
bot_id=bot.self_id,
|
||
flag=event.flag,
|
||
user_id=event.user_id,
|
||
nickname=nickname,
|
||
comment=comment,
|
||
)
|
||
await PlatformUtils.send_superuser(
|
||
bot,
|
||
f"*****一份好友申请*****\n"
|
||
f"ID: {f.id}"
|
||
f"昵称:{nickname}({event.user_id})\n"
|
||
f"自动同意:{'√' if base_config.get('AUTO_ADD_FRIEND') else '×'}\n"
|
||
f"日期:{str(datetime.now()).split('.')[0]}\n"
|
||
f"备注:{event.comment}",
|
||
)
|
||
else:
|
||
logger.debug("好友请求五分钟内重复, 已忽略", "好友请求", target=event.user_id)
|
||
|
||
|
||
@group_req.handle()
|
||
async def _(bot: v12Bot | v11Bot, event: GroupRequestEvent, session: EventSession):
|
||
if event.sub_type != "invite":
|
||
return
|
||
if str(event.user_id) in bot.config.superusers:
|
||
try:
|
||
logger.debug(
|
||
"超级用户自动同意加入群聊",
|
||
"群聊请求",
|
||
session=event.user_id,
|
||
target=event.group_id,
|
||
)
|
||
group, _ = await GroupConsole.update_or_create(
|
||
group_id=str(event.group_id),
|
||
defaults={
|
||
"group_name": "",
|
||
"max_member_count": 0,
|
||
"member_count": 0,
|
||
"group_flag": 1,
|
||
},
|
||
)
|
||
await bot.set_group_add_request(
|
||
flag=event.flag, sub_type="invite", approve=True
|
||
)
|
||
if isinstance(bot, v11Bot):
|
||
group_info = await bot.get_group_info(group_id=event.group_id)
|
||
max_member_count = group_info["max_member_count"]
|
||
member_count = group_info["member_count"]
|
||
else:
|
||
group_info = await bot.get_group_info(group_id=str(event.group_id))
|
||
max_member_count = 0
|
||
member_count = 0
|
||
group.max_member_count = max_member_count
|
||
group.member_count = member_count
|
||
group.group_name = group_info["group_name"]
|
||
await group.save(
|
||
update_fields=["group_name", "max_member_count", "member_count"]
|
||
)
|
||
except ActionFailed as e:
|
||
logger.error(
|
||
"超级用户自动同意加入群聊发生错误",
|
||
"群聊请求",
|
||
session=event.user_id,
|
||
target=event.group_id,
|
||
e=e,
|
||
)
|
||
elif Timer.check(f"{event.user_id}:{event.group_id}"):
|
||
logger.debug(
|
||
f"收录 用户[{event.user_id}] 群聊[{event.group_id}] 群聊请求",
|
||
"群聊请求",
|
||
target=event.group_id,
|
||
)
|
||
nickname = await FriendUser.get_user_name(str(event.user_id))
|
||
await bot.send_private_msg(
|
||
user_id=event.user_id,
|
||
message=f"想要邀请我偷偷入群嘛~已经提醒{BotConfig.self_nickname}的管理员大人了\n"
|
||
"请确保已经群主或群管理沟通过!\n"
|
||
"等待管理员处理吧!",
|
||
)
|
||
# 旧请求全部设置为过期
|
||
await FgRequest.filter(
|
||
request_type=RequestType.GROUP,
|
||
user_id=str(event.user_id),
|
||
group_id=str(event.group_id),
|
||
handle_type__isnull=True,
|
||
).update(handle_type=RequestHandleType.EXPIRE)
|
||
f = await FgRequest.create(
|
||
request_type=RequestType.GROUP,
|
||
platform=session.platform,
|
||
bot_id=bot.self_id,
|
||
flag=event.flag,
|
||
user_id=str(event.user_id),
|
||
nickname=nickname,
|
||
group_id=str(event.group_id),
|
||
)
|
||
await PlatformUtils.send_superuser(
|
||
bot,
|
||
f"*****一份入群申请*****\n"
|
||
f"ID:{f.id}\n"
|
||
f"申请人:{nickname}({event.user_id})\n群聊:"
|
||
f"{event.group_id}\n邀请日期:{datetime.now().replace(microsecond=0)}",
|
||
)
|
||
else:
|
||
logger.debug(
|
||
"群聊请求五分钟内重复, 已忽略",
|
||
"群聊请求",
|
||
target=f"{event.user_id}:{event.group_id}",
|
||
)
|
||
|
||
|
||
@scheduler.scheduled_job(
|
||
"interval",
|
||
minutes=5,
|
||
)
|
||
async def _():
|
||
Timer.clear()
|
||
|
||
|
||
async def _():
|
||
Timer.clear()
|