zhenxun_bot/zhenxun/builtin_plugins/superuser/group_manage.py

214 lines
7.1 KiB
Python
Raw Normal View History

2024-02-26 03:04:32 +08:00
from nonebot.adapters import Bot
from nonebot.adapters.onebot.v11 import Bot as v11Bot
from nonebot.params import Depends
from nonebot.permission import SUPERUSER
from nonebot.plugin import PluginMetadata
from nonebot.typing import T_State
from nonebot_plugin_alconna import (
Alconna,
Args,
Arparma,
Match,
Option,
Subcommand,
on_alconna,
store_true,
)
from nonebot_plugin_session import EventSession
2024-08-24 17:06:23 +08:00
from zhenxun.configs.config import BotConfig
2024-02-26 03:04:32 +08:00
from zhenxun.configs.utils import PluginExtraData
from zhenxun.models.group_console import GroupConsole
from zhenxun.services.log import logger
from zhenxun.utils.enum import PluginType
2024-08-11 15:57:33 +08:00
from zhenxun.utils.message import MessageUtils
2024-02-26 03:04:32 +08:00
__plugin_meta__ = PluginMetadata(
name="管理群操作",
description="管理群操作",
usage="""
群权限 | 群白名单 | 退出群 操作
退群添加/删除群白名单添加/删除群认证当在群组中这五个命令且没有指定群号时默认指定当前群组
指令:
2024-02-27 16:12:56 +08:00
格式:
group-manage modify-level [权限等级] ?[群组Id] : 修改群权限
group-manage super-handle [群组Id] [--del 删除操作] : 添加/删除群白名单
group-manage auth-handle [群组Id] [--del 删除操作] : 添加/删除群认证
group-manage del-group [群组Id] : 退出指定群
快捷:
group-manage modify-level : 修改群权限
group-manage super-handle : 添加/删除群白名单
group-manage auth-handle : 添加/删除群认证
group-manage del-group : 退群
2024-08-04 23:54:28 +08:00
2024-02-27 16:12:56 +08:00
示例:
修改群权限 7 : 在群组中修改当前群组权限为7
2024-08-04 23:54:54 +08:00
修改群权限 7 1234556 : 修改 123456 群组的权限等级为7
2024-02-27 16:12:56 +08:00
添加/删除群白名单 1234567 : 添加/删除 1234567 为群白名单
添加/删除群认证 1234567 : 添加/删除 1234567 为群认证
退群 12344566 : 退出指定群组
2024-02-26 03:04:32 +08:00
""".strip(),
extra=PluginExtraData(
author="HibiKier",
version="0.1",
plugin_type=PluginType.SUPERUSER,
).to_dict(),
2024-02-26 03:04:32 +08:00
)
_matcher = on_alconna(
Alconna(
"group-manage",
Option("--delete", action=store_true, help_text="删除"),
2024-02-26 03:04:32 +08:00
Subcommand(
"modify-level", Args["level", int]["group_id?", int], help_text="修改群权限"
),
Subcommand(
"super-handle",
Args["group_id", int],
help_text="添加/删除群白名单",
),
Subcommand(
"auth-handle",
Args["group_id", int],
2024-02-27 16:12:56 +08:00
help_text="添加/删除群认证",
2024-02-26 03:04:32 +08:00
),
Subcommand("del-group", Args["group_id", int], help_text="退出群组"),
),
permission=SUPERUSER,
priority=1,
block=True,
)
2024-02-27 16:12:56 +08:00
_matcher.shortcut(
2024-08-04 23:54:28 +08:00
r"修改群权限\s?(?P<level>-?\d+)\s?(?P<group_id>\d+)?",
2024-02-27 16:12:56 +08:00
command="group-manage",
2024-08-04 23:54:28 +08:00
arguments=["modify-level", "{level}", "{group_id}"],
2024-02-27 16:12:56 +08:00
prefix=True,
)
_matcher.shortcut(
"添加群白名单",
command="group-manage",
arguments=["super-handle", "{%0}"],
prefix=True,
)
_matcher.shortcut(
"删除群白名单",
command="group-manage",
arguments=["super-handle", "{%0}", "--delete"],
2024-02-27 16:12:56 +08:00
prefix=True,
)
_matcher.shortcut(
"添加群认证",
command="group-manage",
arguments=["auth-handle", "{%0}"],
prefix=True,
)
_matcher.shortcut(
"删除群认证",
command="group-manage",
arguments=["auth-handle", "{%0}", "--delete"],
2024-02-27 16:12:56 +08:00
prefix=True,
)
_matcher.shortcut(
"退群",
command="group-manage",
arguments=["del-group", "{%0}"],
prefix=True,
)
2024-02-27 01:14:49 +08:00
2024-02-26 03:04:32 +08:00
def CheckGroupId():
"""
检测群组id
"""
async def dependency(
session: EventSession,
group_id: Match[int],
state: T_State,
):
gid = session.id3 or session.id2
if group_id.available:
gid = group_id.result
if not gid:
2024-08-11 15:57:33 +08:00
await MessageUtils.build_message("群组id不能为空...").finish()
2024-02-26 03:04:32 +08:00
state["group_id"] = gid
return Depends(dependency)
2024-02-27 01:14:49 +08:00
@_matcher.assign("modify-level", parameterless=[CheckGroupId()])
2024-02-26 03:04:32 +08:00
async def _(session: EventSession, arparma: Arparma, state: T_State, level: int):
gid = state["group_id"]
group, _ = await GroupConsole.get_or_create(group_id=gid)
old_level = group.level
group.level = level
await group.save(update_fields=["level"])
2024-08-11 15:57:33 +08:00
await MessageUtils.build_message("群权限修改成功!").send(reply_to=True)
2024-02-26 03:04:32 +08:00
logger.info(
f"修改群权限: {old_level} -> {level}",
arparma.header_result,
session=session,
target=gid,
)
2024-02-27 01:14:49 +08:00
@_matcher.assign("super-handle", parameterless=[CheckGroupId()])
2024-02-26 03:04:32 +08:00
async def _(session: EventSession, arparma: Arparma, state: T_State):
gid = state["group_id"]
:sparkles: 引入缓存机制 (#1889) * 添加全局cache * ✨ 构建缓存,hook使用缓存 * :sparkles: 新增数据库Model方法监控 * :sparkles: 数据库添加semaphore锁 * :adhesive_bandage: 优化webapi返回数据 * :sparkles: 添加增量缓存与缓存过期 * :art: 优化检测代码结构 * :zap: 优化hook权限检测性能 * :bug: 添加新异常判断跳过权限检测 * :sparkles: 添加插件limit缓存 * :art: 代码格式优化 * :bug: 修复代码导入 * :bug: 修复刷新时检查 * :alien: Rename exception for missing database URL in initialization * :wheelchair: Update default database URL to SQLite in configuration * :wrench: Update tortoise-orm and aiocache dependencies restrictions; add optional redis and asyncpg support * :bug: 修复ban检测 * :bug: 修复所有插件关闭时缓存更新 * :bug: 尝试迁移至aiocache * :bug: 完善aiocache缓存 * :zap: 代码性能优化 * :bug: 移除获取封禁缓存时的日志记录 * :bug: 修复缓存类型声明,优化封禁用户处理逻辑 * :bug: 优化LevelUser权限更新逻辑及数据库迁移 * :sparkles: cache支持redis连接 * :rotating_light: auto fix by pre-commit hooks * :zap: :增强获取群组的安全性和准确性。同时,优化了缓存管理中的相关逻辑,确保缓存操作的一致性。 * ✨ feat(auth_limit): 将插件初始化逻辑的启动装饰器更改为优先级管理器 * 🔧 修复日志记录级别 * 🔧 更新数据库连接字符串 * 🔧 更新数据库连接字符串为内存数据库,并优化权限检查逻辑 * ✨ feat(cache): 增加缓存功能配置项,并新增数据访问层以支持缓存逻辑 * :recycle: 重构cache * ✨ feat(cache): 增强缓存管理,新增缓存字典和缓存列表功能,支持过期时间管理 * 🔧 修复Notebook类中的viewport高度设置,将其从1000调整为10 * ✨ 更新插件管理逻辑,替换缓存服务为CacheRoot并优化缓存失效处理 * ✨ 更新RegisterConfig类中的type字段 * ✨ 修复清理重复记录逻辑,确保检查记录的id属性有效性 * :zap: 超级无敌大优化,解决延迟与卡死问题 * ✨ 更新封禁功能,增加封禁时长参数和描述,优化插件信息返回结构 * ✨ 更新zhenxun_help.py中的viewport高度,将其从453调整为10,以优化页面显示效果 * ✨ 优化插件分类逻辑,增加插件ID排序,并更新插件信息返回结构 --------- Co-authored-by: BalconyJH <balconyjh@gmail.com> Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
2025-07-14 22:35:29 +08:00
group = await GroupConsole.get_group(group_id=gid)
2024-02-26 03:04:32 +08:00
if not group:
2024-08-11 15:57:33 +08:00
await MessageUtils.build_message("群组信息不存在, 请更新群组信息...").finish()
s = "删除" if arparma.find("delete") else "添加"
group.is_super = not arparma.find("delete")
2024-02-26 03:04:32 +08:00
await group.save(update_fields=["is_super"])
2024-08-11 15:57:33 +08:00
await MessageUtils.build_message(f"{s}群白名单成功!").send(reply_to=True)
2024-02-26 03:04:32 +08:00
logger.info(f"{s}群白名单", arparma.header_result, session=session, target=gid)
2024-02-27 01:14:49 +08:00
@_matcher.assign("auth-handle", parameterless=[CheckGroupId()])
2024-02-26 03:04:32 +08:00
async def _(session: EventSession, arparma: Arparma, state: T_State):
gid = state["group_id"]
await GroupConsole.update_or_create(
:sparkles: 引入缓存机制 (#1889) * 添加全局cache * ✨ 构建缓存,hook使用缓存 * :sparkles: 新增数据库Model方法监控 * :sparkles: 数据库添加semaphore锁 * :adhesive_bandage: 优化webapi返回数据 * :sparkles: 添加增量缓存与缓存过期 * :art: 优化检测代码结构 * :zap: 优化hook权限检测性能 * :bug: 添加新异常判断跳过权限检测 * :sparkles: 添加插件limit缓存 * :art: 代码格式优化 * :bug: 修复代码导入 * :bug: 修复刷新时检查 * :alien: Rename exception for missing database URL in initialization * :wheelchair: Update default database URL to SQLite in configuration * :wrench: Update tortoise-orm and aiocache dependencies restrictions; add optional redis and asyncpg support * :bug: 修复ban检测 * :bug: 修复所有插件关闭时缓存更新 * :bug: 尝试迁移至aiocache * :bug: 完善aiocache缓存 * :zap: 代码性能优化 * :bug: 移除获取封禁缓存时的日志记录 * :bug: 修复缓存类型声明,优化封禁用户处理逻辑 * :bug: 优化LevelUser权限更新逻辑及数据库迁移 * :sparkles: cache支持redis连接 * :rotating_light: auto fix by pre-commit hooks * :zap: :增强获取群组的安全性和准确性。同时,优化了缓存管理中的相关逻辑,确保缓存操作的一致性。 * ✨ feat(auth_limit): 将插件初始化逻辑的启动装饰器更改为优先级管理器 * 🔧 修复日志记录级别 * 🔧 更新数据库连接字符串 * 🔧 更新数据库连接字符串为内存数据库,并优化权限检查逻辑 * ✨ feat(cache): 增加缓存功能配置项,并新增数据访问层以支持缓存逻辑 * :recycle: 重构cache * ✨ feat(cache): 增强缓存管理,新增缓存字典和缓存列表功能,支持过期时间管理 * 🔧 修复Notebook类中的viewport高度设置,将其从1000调整为10 * ✨ 更新插件管理逻辑,替换缓存服务为CacheRoot并优化缓存失效处理 * ✨ 更新RegisterConfig类中的type字段 * ✨ 修复清理重复记录逻辑,确保检查记录的id属性有效性 * :zap: 超级无敌大优化,解决延迟与卡死问题 * ✨ 更新封禁功能,增加封禁时长参数和描述,优化插件信息返回结构 * ✨ 更新zhenxun_help.py中的viewport高度,将其从453调整为10,以优化页面显示效果 * ✨ 优化插件分类逻辑,增加插件ID排序,并更新插件信息返回结构 --------- Co-authored-by: BalconyJH <balconyjh@gmail.com> Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
2025-07-14 22:35:29 +08:00
group_id=gid,
channel_id__isnull=True,
defaults={"group_flag": 0 if arparma.find("delete") else 1},
2024-02-26 03:04:32 +08:00
)
s = "删除" if arparma.find("delete") else "添加"
2024-08-11 15:57:33 +08:00
await MessageUtils.build_message(f"{s}群认证成功!").send(reply_to=True)
2024-02-26 03:04:32 +08:00
logger.info(f"{s}群白名单", arparma.header_result, session=session, target=gid)
@_matcher.assign("del-group")
async def _(bot: Bot, session: EventSession, arparma: Arparma, group_id: int):
if isinstance(bot, v11Bot):
group_list = [g["group_id"] for g in await bot.get_group_list()]
if group_id not in group_list:
logger.debug("群组不存在", "退群", session=session, target=group_id)
2024-08-24 17:06:23 +08:00
await MessageUtils.build_message(
2024-08-24 19:32:52 +08:00
f"{BotConfig.self_nickname}未在该群组中..."
2024-08-24 17:06:23 +08:00
).finish()
2024-02-26 03:04:32 +08:00
try:
await bot.set_group_leave(group_id=group_id)
logger.info(
2024-08-24 19:32:52 +08:00
f"{BotConfig.self_nickname}退出群组成功",
2024-08-24 17:06:23 +08:00
"退群",
session=session,
target=group_id,
2024-02-26 03:04:32 +08:00
)
2024-08-11 15:57:33 +08:00
await MessageUtils.build_message(f"退出群组 {group_id} 成功!").send()
2024-02-26 03:04:32 +08:00
await GroupConsole.filter(group_id=group_id).delete()
except Exception as e:
logger.error("退出群组失败", "退群", session=session, target=group_id, e=e)
2024-08-11 15:57:33 +08:00
await MessageUtils.build_message(f"退出群组 {group_id} 失败...").send()
2024-02-26 03:04:32 +08:00
else:
# TODO: 其他平台的退群操作
await MessageUtils.build_message("暂未支持退群操作...").send()