2021-05-20 19:21:05 +08:00
|
|
|
|
from nonebot import on_command
|
|
|
|
|
|
from models.ban_user import BanUser
|
|
|
|
|
|
from models.level_user import LevelUser
|
|
|
|
|
|
from nonebot.typing import T_State
|
|
|
|
|
|
from nonebot.adapters import Bot
|
|
|
|
|
|
from nonebot.adapters.cqhttp import GroupMessageEvent
|
|
|
|
|
|
from nonebot.adapters.cqhttp.permission import GROUP
|
2021-06-30 19:50:55 +08:00
|
|
|
|
from utils.utils import get_message_at, get_message_text, is_number
|
2021-05-20 19:21:05 +08:00
|
|
|
|
from services.log import logger
|
|
|
|
|
|
from models.group_member_info import GroupInfoUser
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
__plugin_name__ = 'Ban/unBan'
|
2021-06-15 10:57:08 +08:00
|
|
|
|
__plugin_usage__ = '用法:\n' \
|
|
|
|
|
|
'(不是禁言!是针对真寻是否处理封禁用户消息)\n' \
|
|
|
|
|
|
'封禁/解封用户 [小时] [分钟]\n' \
|
|
|
|
|
|
'示例:.ban @djdsk\n' \
|
|
|
|
|
|
'示例:.ban @djdsk 0 30\n' \
|
|
|
|
|
|
'示例:.ban @sdasf 4\n' \
|
|
|
|
|
|
'示例:.unban @sdasf'
|
2021-05-20 19:21:05 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
ban = on_command(".ban", aliases={'.unban', '/ban', '/unban'}, priority=5, permission=GROUP, block=True)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@ban.handle()
|
|
|
|
|
|
async def _(bot: Bot, event: GroupMessageEvent, state: T_State):
|
|
|
|
|
|
# try:
|
|
|
|
|
|
result = ''
|
|
|
|
|
|
qq = int(get_message_at(event.json())[0])
|
|
|
|
|
|
if qq:
|
2021-05-21 09:51:09 +08:00
|
|
|
|
try:
|
|
|
|
|
|
user_name = (await GroupInfoUser.select_member_info(qq, event.group_id)).user_name
|
|
|
|
|
|
except AttributeError:
|
|
|
|
|
|
user_name = '用户'
|
2021-05-20 19:21:05 +08:00
|
|
|
|
msg = get_message_text(event.json())
|
|
|
|
|
|
if msg:
|
|
|
|
|
|
msg = msg.split(" ")
|
|
|
|
|
|
if len(msg) == 2:
|
|
|
|
|
|
if not is_number(msg[0].strip()) or not is_number(msg[1].strip()):
|
|
|
|
|
|
await ban.finish('参数必须是数字!', at_sender=True)
|
|
|
|
|
|
time = int(msg[0]) * 60 * 60 + int(msg[1]) * 60
|
|
|
|
|
|
else:
|
|
|
|
|
|
if not is_number(msg[0].strip()):
|
|
|
|
|
|
await ban.finish('参数必须是数字!', at_sender=True)
|
|
|
|
|
|
time = int(msg[0]) * 60 * 60
|
|
|
|
|
|
else:
|
|
|
|
|
|
time = -1
|
|
|
|
|
|
if state["_prefix"]["raw_command"] in [".ban", '/ban']:
|
|
|
|
|
|
if await LevelUser.get_user_level(event.user_id, event.group_id) <= await \
|
|
|
|
|
|
LevelUser.get_user_level(qq, event.group_id) and str(event.user_id) not in bot.config.superusers:
|
2021-05-21 09:52:41 +08:00
|
|
|
|
await ban.finish(f"您的权限等级比对方低或相等, {list(bot.config.nickname)[0]}不能为您使用此功能!", at_sender=True)
|
2021-05-20 19:21:05 +08:00
|
|
|
|
if await BanUser.ban(qq, await LevelUser.get_user_level(event.user_id, event.group_id), time):
|
|
|
|
|
|
logger.info(f"USER {event.user_id} GROUP {event.group_id} 将 USER {qq} 封禁 时长 {time/60} 分钟")
|
2021-05-21 09:52:41 +08:00
|
|
|
|
result = f"已经将 {user_name} 加入{list(bot.config.nickname)[0]}的黑名单了!"
|
2021-05-20 19:21:05 +08:00
|
|
|
|
if time != -1:
|
|
|
|
|
|
result += f"将在 {time/60} 分钟后解封"
|
|
|
|
|
|
else:
|
|
|
|
|
|
time = await BanUser.check_ban_time(qq)
|
|
|
|
|
|
if is_number(time):
|
|
|
|
|
|
time = abs(time)
|
|
|
|
|
|
if time < 60:
|
|
|
|
|
|
time = str(int(time)) + ' 秒'
|
|
|
|
|
|
else:
|
|
|
|
|
|
time = str(int(time / 60)) + ' 分钟'
|
|
|
|
|
|
else:
|
|
|
|
|
|
time += ' 分钟'
|
2021-05-21 09:51:09 +08:00
|
|
|
|
result = f"{user_name} 已在黑名单!预计 {time}后解封"
|
2021-05-20 19:21:05 +08:00
|
|
|
|
else:
|
|
|
|
|
|
if await BanUser.check_ban_level(qq, await LevelUser.get_user_level(event.user_id, event.group_id)) and\
|
|
|
|
|
|
str(event.user_id) not in bot.config.superusers:
|
2021-05-21 09:51:09 +08:00
|
|
|
|
await ban.finish(f"ban掉 {user_name} 的管理员权限比您高,无法进行unban", at_sender=True)
|
2021-05-20 19:21:05 +08:00
|
|
|
|
if await BanUser.unban(qq):
|
|
|
|
|
|
logger.info(f"USER {event.user_id} GROUP {event.group_id} 将 USER {qq} 解禁")
|
2021-05-21 09:51:09 +08:00
|
|
|
|
result = f"已经把 {user_name} 从黑名单中删除了!"
|
2021-05-20 19:21:05 +08:00
|
|
|
|
else:
|
2021-05-21 09:51:09 +08:00
|
|
|
|
result = f"{user_name} 不在黑名单!"
|
2021-05-20 19:21:05 +08:00
|
|
|
|
else:
|
|
|
|
|
|
await ban.finish('艾特人了吗??', at_sender=True)
|
|
|
|
|
|
# except Exception as e:
|
|
|
|
|
|
# result = 'ban/unban执行出错,确定艾特人了吗?'
|
|
|
|
|
|
# logger.error(f'ban/unban执行出错 e:{e}')
|
|
|
|
|
|
await ban.finish(result, at_sender=True)
|