mirror of
https://github.com/zhenxun-org/zhenxun_bot.git
synced 2025-12-14 21:52:56 +08:00
Some checks are pending
检查bot是否运行正常 / bot check (push) Waiting to run
CodeQL Code Security Analysis / Analyze (${{ matrix.language }}) (none, javascript-typescript) (push) Waiting to run
CodeQL Code Security Analysis / Analyze (${{ matrix.language }}) (none, python) (push) Waiting to run
Sequential Lint and Type Check / ruff-call (push) Waiting to run
Sequential Lint and Type Check / pyright-call (push) Blocked by required conditions
Release Drafter / Update Release Draft (push) Waiting to run
Force Sync to Aliyun / sync (push) Waiting to run
Update Version / update-version (push) Waiting to run
* ✨ 修复一些bug - 移除不必要的定时器类,简化代码结构 - 优化好友请求处理逻辑,确保在自动同意和手动处理之间的清晰区分 - 更新缓存机制,避免重复处理相同的好友请求 - 新增判断文件是否为二进制文件的功能,提升文件处理的准确性 - 优化缓存字典的过期检查逻辑,提高性能和可读性 * ✨ 更新 get_async_client 函数,支持字符串类型的代理参数 - 修改 proxies 参数类型,允许传入字符串形式的代理地址 - 增强代理处理逻辑,将字符串代理转换为字典格式,提升灵活性和可用性
274 lines
10 KiB
Python
274 lines
10 KiB
Python
import asyncio
|
||
from datetime import datetime
|
||
import random
|
||
|
||
from nonebot import on_message, on_request
|
||
from nonebot.adapters.onebot.v11 import (
|
||
ActionFailed,
|
||
FriendRequestEvent,
|
||
GroupRequestEvent,
|
||
)
|
||
from nonebot.adapters.onebot.v11 import Bot as v11Bot
|
||
from nonebot.adapters.onebot.v12 import Bot as v12Bot
|
||
from nonebot.plugin import PluginMetadata
|
||
from nonebot_plugin_session import EventSession
|
||
|
||
from zhenxun.configs.config import BotConfig, Config
|
||
from zhenxun.configs.utils import PluginExtraData, RegisterConfig
|
||
from zhenxun.models.event_log import EventLog
|
||
from zhenxun.models.fg_request import FgRequest
|
||
from zhenxun.models.friend_user import FriendUser
|
||
from zhenxun.models.group_console import GroupConsole
|
||
from zhenxun.services.cache import CacheRoot
|
||
from zhenxun.services.log import logger
|
||
from zhenxun.utils.enum import EventLogType, PluginType, RequestHandleType, RequestType
|
||
from zhenxun.utils.platform import PlatformUtils
|
||
|
||
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,
|
||
),
|
||
RegisterConfig(
|
||
module="invite_manager",
|
||
key="AUTO_ADD_GROUP",
|
||
value=False,
|
||
help="是否自动同意邀请入群",
|
||
type=bool,
|
||
default_value=False,
|
||
),
|
||
RegisterConfig(
|
||
module="invite_manager",
|
||
key="TIP_MESSAGE_LIMIT",
|
||
value=360,
|
||
help="重复申请与退群提醒过滤时间(分钟)",
|
||
type=int,
|
||
default_value=360,
|
||
),
|
||
],
|
||
).to_dict(),
|
||
)
|
||
|
||
|
||
# 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)
|
||
|
||
|
||
cache = CacheRoot.cache_dict("REQUEST_CACHE", 60, str)
|
||
|
||
|
||
@friend_req.handle()
|
||
async def _(bot: v12Bot | v11Bot, event: FriendRequestEvent, session: EventSession):
|
||
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 asyncio.sleep(random.randint(1, 10))
|
||
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,
|
||
)
|
||
cache_key = str(event.user_id)
|
||
if not cache.get(cache_key):
|
||
cache.set(cache_key, "1")
|
||
results = await PlatformUtils.send_superuser(
|
||
bot,
|
||
f"*****一份好友申请*****\n"
|
||
f"ID: {f.id}\n"
|
||
f"昵称:{nickname}({event.user_id})\n"
|
||
f"自动同意:{'√' if base_config.get('AUTO_ADD_FRIEND') else '×'}\n"
|
||
f"日期:{datetime.now().replace(microsecond=0)}\n"
|
||
f"备注:{event.comment}",
|
||
)
|
||
if message_ids := [
|
||
str(r[1].msg_ids[0]["message_id"])
|
||
for r in results
|
||
if r[1] and r[1].msg_ids
|
||
]:
|
||
f.message_ids = ",".join(message_ids)
|
||
await f.save(update_fields=["message_ids"])
|
||
else:
|
||
tip_limit = base_config.get("TIP_MESSAGE_LIMIT") or 360
|
||
logger.debug(
|
||
f"好友请求{tip_limit}分钟内重复, 已忽略",
|
||
"好友请求",
|
||
target=cache_key,
|
||
)
|
||
|
||
|
||
@group_req.handle()
|
||
async def _(bot: v12Bot | v11Bot, event: GroupRequestEvent, session: EventSession):
|
||
# sourcery skip: low-code-quality
|
||
if event.sub_type != "invite":
|
||
return
|
||
if str(event.user_id) in bot.config.superusers or base_config.get("AUTO_ADD_GROUP"):
|
||
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,
|
||
)
|
||
if str(event.user_id) not in bot.config.superusers and base_config.get(
|
||
"AUTO_ADD_GROUP"
|
||
):
|
||
# 非超级用户邀请自动加入群组
|
||
nickname = await FriendUser.get_user_name(str(event.user_id))
|
||
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),
|
||
handle_type=RequestHandleType.APPROVE,
|
||
)
|
||
results = 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)}\n"
|
||
"注: 该请求已自动同意",
|
||
)
|
||
await asyncio.sleep(random.randint(1, 5))
|
||
await bot.send_private_msg(
|
||
user_id=event.user_id,
|
||
message=f"管理员已开启自动同意群组邀请,请不要让{BotConfig.self_nickname}受委屈哦(狠狠监控)"
|
||
"\n在群组中 群组管理员与群主 允许使用管理员帮助"
|
||
"(包括ban与功能开关等)\n请在群组中发送 '管理员帮助'",
|
||
)
|
||
elif not cache.get(f"{event.group_id}"):
|
||
cache.set(f"{event.group_id}", "1")
|
||
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),
|
||
)
|
||
kick_count = await EventLog.filter(
|
||
group_id=str(event.group_id), event_type=EventLogType.KICK_BOT
|
||
).count()
|
||
kick_message = (
|
||
f"\n该群累计踢出{BotConfig.self_nickname} <{kick_count}>次"
|
||
if kick_count
|
||
else ""
|
||
)
|
||
results = 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)}"
|
||
f"{kick_message}",
|
||
)
|
||
if message_ids := [
|
||
str(r[1].msg_ids[0]["message_id"]) for r in results if r[1] and r[1].msg_ids
|
||
]:
|
||
f.message_ids = ",".join(message_ids)
|
||
await f.save(update_fields=["message_ids"])
|
||
else:
|
||
logger.debug(
|
||
"群聊请求五分钟内重复, 已忽略",
|
||
"群聊请求",
|
||
target=f"{event.user_id}:{event.group_id}",
|
||
)
|