fix:修复被忽略的插件文件
This commit is contained in:
5
.gitignore
vendored
5
.gitignore
vendored
@@ -311,4 +311,7 @@ run_pet.bat
|
||||
# 忽略 /src/plugins 但保留特定目录
|
||||
/src/plugins/*
|
||||
!/src/plugins/doubao_pic/
|
||||
!/src/plugins/mute_action/
|
||||
!/src/plugins/mute_plugin/
|
||||
!/src/plugins/tts_plugin/
|
||||
!/src/plugins/vtb_action/
|
||||
!/src/plugins/__init__.py
|
||||
|
||||
5
src/plugins/mute_plugin/__init__.py
Normal file
5
src/plugins/mute_plugin/__init__.py
Normal file
@@ -0,0 +1,5 @@
|
||||
"""测试插件包"""
|
||||
|
||||
"""
|
||||
这是一个测试插件
|
||||
"""
|
||||
2
src/plugins/mute_plugin/actions/__init__.py
Normal file
2
src/plugins/mute_plugin/actions/__init__.py
Normal file
@@ -0,0 +1,2 @@
|
||||
"""测试插件动作模块"""
|
||||
from . import mute_action # noqa
|
||||
81
src/plugins/mute_plugin/actions/mute_action.py
Normal file
81
src/plugins/mute_plugin/actions/mute_action.py
Normal file
@@ -0,0 +1,81 @@
|
||||
from src.common.logger_manager import get_logger
|
||||
from src.chat.focus_chat.planners.actions.plugin_action import PluginAction, register_action
|
||||
from typing import Tuple
|
||||
|
||||
logger = get_logger("mute_action")
|
||||
|
||||
|
||||
@register_action
|
||||
class MuteAction(PluginAction):
|
||||
"""群聊禁言动作处理类"""
|
||||
|
||||
action_name = "mute_action"
|
||||
action_description = "在特定情境下,对某人采取禁言,让他不能说话"
|
||||
action_parameters = {
|
||||
"target": "禁言对象,必填,输入你要禁言的对象的名字",
|
||||
"duration": "禁言时长,必填,输入你要禁言的时长(秒),单位为秒,必须为数字",
|
||||
"reason": "禁言理由,可选",
|
||||
}
|
||||
action_require = [
|
||||
"当有人违反了公序良俗的内容",
|
||||
"当有人刷屏时使用",
|
||||
"当有人发了擦边,或者色情内容时使用",
|
||||
"当有人要求禁言自己时使用",
|
||||
]
|
||||
default = False # 默认动作,是否手动添加到使用集
|
||||
associated_types = ["command", "text"]
|
||||
# associated_types = ["text"]
|
||||
|
||||
async def process(self) -> Tuple[bool, str]:
|
||||
"""处理群聊禁言动作"""
|
||||
logger.info(f"{self.log_prefix} 执行禁言动作: {self.reasoning}")
|
||||
|
||||
# 获取参数
|
||||
target = self.action_data.get("target")
|
||||
duration = self.action_data.get("duration")
|
||||
reason = self.action_data.get("reason", "违反群规")
|
||||
|
||||
if not target or not duration:
|
||||
error_msg = "禁言参数不完整,需要target和duration"
|
||||
logger.error(f"{self.log_prefix} {error_msg}")
|
||||
return False, error_msg
|
||||
|
||||
# 获取用户ID
|
||||
platform, user_id = await self.get_user_id_by_person_name(target)
|
||||
|
||||
if not user_id:
|
||||
error_msg = f"未找到用户 {target} 的ID"
|
||||
await self.send_message_by_expressor(f"压根没 {target} 这个人")
|
||||
logger.error(f"{self.log_prefix} {error_msg}")
|
||||
return False, error_msg
|
||||
|
||||
# 发送表达情绪的消息
|
||||
await self.send_message_by_expressor(f"禁言{target} {duration}秒,因为{reason}")
|
||||
|
||||
try:
|
||||
# 确保duration是字符串类型
|
||||
if int(duration) < 60:
|
||||
duration = 60
|
||||
if int(duration) > 3600 * 24 * 30:
|
||||
duration = 3600 * 24 * 30
|
||||
duration_str = str(int(duration))
|
||||
|
||||
# 发送群聊禁言命令,按照新格式
|
||||
await self.send_message(
|
||||
type="command",
|
||||
data={"name": "GROUP_BAN", "args": {"qq_id": str(user_id), "duration": duration_str}},
|
||||
display_message=f"尝试禁言了 {target} {duration_str}秒",
|
||||
)
|
||||
|
||||
await self.store_action_info(
|
||||
action_build_into_prompt=False,
|
||||
action_prompt_display=f"你尝试禁言了 {target} {duration_str}秒",
|
||||
)
|
||||
|
||||
logger.info(f"{self.log_prefix} 成功发送禁言命令,用户 {target}({user_id}),时长 {duration} 秒")
|
||||
return True, f"成功禁言 {target},时长 {duration} 秒"
|
||||
|
||||
except Exception as e:
|
||||
logger.error(f"{self.log_prefix} 执行禁言动作时出错: {e}")
|
||||
await self.send_message_by_expressor(f"执行禁言动作时出错: {e}")
|
||||
return False, f"执行禁言动作时出错: {e}"
|
||||
Reference in New Issue
Block a user