2023-02-18 18:46:54 +08:00
|
|
|
|
import asyncio
|
|
|
|
|
|
import re
|
|
|
|
|
|
import time
|
|
|
|
|
|
from datetime import datetime
|
|
|
|
|
|
|
|
|
|
|
|
from nonebot import on_message, on_request
|
2022-02-19 18:20:19 +08:00
|
|
|
|
from nonebot.adapters.onebot.v11 import (
|
2022-06-07 19:57:34 +08:00
|
|
|
|
ActionFailed,
|
2023-02-18 18:46:54 +08:00
|
|
|
|
Bot,
|
2021-11-23 21:44:59 +08:00
|
|
|
|
FriendRequestEvent,
|
|
|
|
|
|
GroupRequestEvent,
|
|
|
|
|
|
MessageEvent,
|
|
|
|
|
|
)
|
2023-02-18 18:46:54 +08:00
|
|
|
|
|
2021-11-23 21:44:59 +08:00
|
|
|
|
from configs.config import NICKNAME, Config
|
2023-02-18 18:46:54 +08:00
|
|
|
|
from models.friend_user import FriendUser
|
2021-11-23 21:44:59 +08:00
|
|
|
|
from models.group_info import GroupInfo
|
2023-02-18 18:46:54 +08:00
|
|
|
|
from services.log import logger
|
|
|
|
|
|
from utils.manager import requests_manager
|
2021-11-23 21:44:59 +08:00
|
|
|
|
from utils.utils import scheduler
|
2023-02-18 18:46:54 +08:00
|
|
|
|
|
|
|
|
|
|
from .utils import time_manager
|
2021-11-23 21:44:59 +08:00
|
|
|
|
|
|
|
|
|
|
__zx_plugin_name__ = "好友群聊处理请求 [Hidden]"
|
|
|
|
|
|
__plugin_version__ = 0.1
|
|
|
|
|
|
__plugin_author__ = "HibiKier"
|
|
|
|
|
|
__plugin_configs__ = {
|
2023-02-26 22:17:26 +08:00
|
|
|
|
"AUTO_ADD_FRIEND": {
|
|
|
|
|
|
"value": False,
|
|
|
|
|
|
"help": "是否自动同意好友添加",
|
|
|
|
|
|
"default_value": False,
|
|
|
|
|
|
"type": bool,
|
|
|
|
|
|
}
|
2021-11-23 21:44:59 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
friend_req = on_request(priority=5, block=True)
|
|
|
|
|
|
group_req = on_request(priority=5, block=True)
|
2022-07-23 14:09:17 +08:00
|
|
|
|
x = on_message(priority=999, block=False, rule=lambda: False)
|
2021-11-23 21:44:59 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@friend_req.handle()
|
2022-02-19 18:20:19 +08:00
|
|
|
|
async def _(bot: Bot, event: FriendRequestEvent):
|
2023-02-18 18:46:54 +08:00
|
|
|
|
if time_manager.add_user_request(event.user_id):
|
2023-03-19 21:05:34 +08:00
|
|
|
|
logger.debug(f"收录好友请求...", "好友请求", target=event.user_id)
|
2023-02-18 18:46:54 +08:00
|
|
|
|
user = await bot.get_stranger_info(user_id=event.user_id)
|
|
|
|
|
|
nickname = user["nickname"]
|
|
|
|
|
|
sex = user["sex"]
|
|
|
|
|
|
age = str(user["age"])
|
|
|
|
|
|
comment = event.comment
|
|
|
|
|
|
await bot.send_private_msg(
|
|
|
|
|
|
user_id=int(list(bot.config.superusers)[0]),
|
|
|
|
|
|
message=f"*****一份好友申请*****\n"
|
|
|
|
|
|
f"昵称:{nickname}({event.user_id})\n"
|
|
|
|
|
|
f"自动同意:{'√' if Config.get_config('invite_manager', 'AUTO_ADD_FRIEND') else '×'}\n"
|
|
|
|
|
|
f"日期:{str(datetime.now()).split('.')[0]}\n"
|
|
|
|
|
|
f"备注:{event.comment}",
|
2021-11-23 21:44:59 +08:00
|
|
|
|
)
|
2023-02-18 18:46:54 +08:00
|
|
|
|
if Config.get_config("invite_manager", "AUTO_ADD_FRIEND"):
|
|
|
|
|
|
logger.debug(f"已开启好友请求自动同意,成功通过该请求", "好友请求", target=event.user_id)
|
|
|
|
|
|
await bot.set_friend_add_request(flag=event.flag, approve=True)
|
|
|
|
|
|
await FriendUser.create(user_id=user["user_id"], user_name=user["nickname"])
|
|
|
|
|
|
else:
|
|
|
|
|
|
requests_manager.add_request(
|
|
|
|
|
|
event.user_id,
|
|
|
|
|
|
"private",
|
|
|
|
|
|
event.flag,
|
|
|
|
|
|
nickname=nickname,
|
|
|
|
|
|
sex=sex,
|
|
|
|
|
|
age=age,
|
|
|
|
|
|
comment=comment,
|
|
|
|
|
|
)
|
|
|
|
|
|
else:
|
|
|
|
|
|
logger.debug(f"好友请求五分钟内重复, 已忽略", "好友请求", target=event.user_id)
|
2021-11-23 21:44:59 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@group_req.handle()
|
2022-02-19 18:20:19 +08:00
|
|
|
|
async def _(bot: Bot, event: GroupRequestEvent):
|
2023-02-18 18:46:54 +08:00
|
|
|
|
# 邀请
|
2021-11-23 21:44:59 +08:00
|
|
|
|
if event.sub_type == "invite":
|
|
|
|
|
|
if str(event.user_id) in bot.config.superusers:
|
|
|
|
|
|
try:
|
2023-02-18 18:46:54 +08:00
|
|
|
|
logger.debug(
|
|
|
|
|
|
f"超级用户自动同意加入群聊", "群聊请求", event.user_id, target=event.group_id
|
|
|
|
|
|
)
|
2021-11-23 21:44:59 +08:00
|
|
|
|
await bot.set_group_add_request(
|
|
|
|
|
|
flag=event.flag, sub_type="invite", approve=True
|
|
|
|
|
|
)
|
2023-02-18 18:46:54 +08:00
|
|
|
|
group_info = await bot.get_group_info(group_id=event.group_id)
|
|
|
|
|
|
await GroupInfo.update_or_create(
|
|
|
|
|
|
group_id=group_info["group_id"],
|
|
|
|
|
|
defaults={
|
|
|
|
|
|
"group_name": group_info["group_name"],
|
|
|
|
|
|
"max_member_count": group_info["max_member_count"],
|
|
|
|
|
|
"member_count": group_info["member_count"],
|
|
|
|
|
|
"group_flag": 1,
|
|
|
|
|
|
},
|
|
|
|
|
|
)
|
|
|
|
|
|
except ActionFailed as e:
|
|
|
|
|
|
logger.error(
|
|
|
|
|
|
"超级用户自动同意加入群聊发生错误",
|
|
|
|
|
|
"群聊请求",
|
|
|
|
|
|
event.user_id,
|
|
|
|
|
|
target=event.group_id,
|
|
|
|
|
|
e=e,
|
|
|
|
|
|
)
|
2021-11-23 21:44:59 +08:00
|
|
|
|
else:
|
2023-02-18 18:46:54 +08:00
|
|
|
|
if time_manager.add_group_request(event.user_id, event.group_id):
|
|
|
|
|
|
logger.debug(
|
|
|
|
|
|
f"收录 用户[{event.user_id}] 群聊[{event.group_id}] 群聊请求", "群聊请求"
|
|
|
|
|
|
)
|
|
|
|
|
|
user = await bot.get_stranger_info(user_id=event.user_id)
|
|
|
|
|
|
sex = user["sex"]
|
|
|
|
|
|
age = str(user["age"])
|
|
|
|
|
|
nickname = await FriendUser.get_user_name(event.user_id)
|
|
|
|
|
|
await bot.send_private_msg(
|
|
|
|
|
|
user_id=int(list(bot.config.superusers)[0]),
|
|
|
|
|
|
message=f"*****一份入群申请*****\n"
|
|
|
|
|
|
f"申请人:{nickname}({event.user_id})\n"
|
|
|
|
|
|
f"群聊:{event.group_id}\n"
|
|
|
|
|
|
f"邀请日期:{datetime.now().replace(microsecond=0)}",
|
|
|
|
|
|
)
|
|
|
|
|
|
await bot.send_private_msg(
|
|
|
|
|
|
user_id=event.user_id,
|
|
|
|
|
|
message=f"想要邀请我偷偷入群嘛~已经提醒{NICKNAME}的管理员大人了\n"
|
|
|
|
|
|
"请确保已经群主或群管理沟通过!\n"
|
|
|
|
|
|
"等待管理员处理吧!",
|
|
|
|
|
|
)
|
|
|
|
|
|
requests_manager.add_request(
|
|
|
|
|
|
event.user_id,
|
|
|
|
|
|
"group",
|
|
|
|
|
|
event.flag,
|
|
|
|
|
|
invite_group=event.group_id,
|
|
|
|
|
|
nickname=nickname,
|
|
|
|
|
|
sex=sex,
|
|
|
|
|
|
age=age,
|
|
|
|
|
|
)
|
|
|
|
|
|
else:
|
|
|
|
|
|
logger.debug(
|
|
|
|
|
|
f"群聊请求五分钟内重复, 已忽略",
|
|
|
|
|
|
"群聊请求",
|
|
|
|
|
|
target=f"{event.user_id}:{event.group_id}",
|
|
|
|
|
|
)
|
2021-11-23 21:44:59 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@x.handle()
|
2022-02-19 18:20:19 +08:00
|
|
|
|
async def _(event: MessageEvent):
|
2021-11-23 21:44:59 +08:00
|
|
|
|
await asyncio.sleep(0.1)
|
|
|
|
|
|
r = re.search(r'groupcode="(.*?)"', str(event.get_message()))
|
|
|
|
|
|
if r:
|
|
|
|
|
|
group_id = int(r.group(1))
|
|
|
|
|
|
else:
|
|
|
|
|
|
return
|
|
|
|
|
|
r = re.search(r'groupname="(.*?)"', str(event.get_message()))
|
|
|
|
|
|
if r:
|
|
|
|
|
|
group_name = r.group(1)
|
|
|
|
|
|
else:
|
|
|
|
|
|
group_name = "None"
|
|
|
|
|
|
requests_manager.set_group_name(group_name, group_id)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@scheduler.scheduled_job(
|
|
|
|
|
|
"interval",
|
|
|
|
|
|
minutes=5,
|
|
|
|
|
|
)
|
|
|
|
|
|
async def _():
|
2023-02-18 18:46:54 +08:00
|
|
|
|
time_manager.clear()
|