zhenxun_bot/plugins/ban/__init__.py

84 lines
4.1 KiB
Python
Raw Normal View History

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
from util.utils import get_message_at, get_message_text, is_number
from services.log import logger
from models.group_member_info import GroupInfoUser
__plugin_name__ = 'Ban/unBan'
__plugin_usage__ = f'用法: 封禁/解封用户不是禁言是针对bot是否处理封禁用户消息\n' \
'示例:.ban @djdsk\n' \
'示例:.ban @djdsk 0(小时) 30(分钟)\n' \
'示例:.ban @sdasf 4(小时)\n' \
'示例:.unban @sdasf'
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):
if get_message_text(event.json()) in ['帮助'] or str(event.get_message()) == '':
await ban.finish(__plugin_usage__)
# 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)