7.4 KiB
7.4 KiB
⚙️ 插件配置定义指南
本文档将指导你如何为你的插件定义一个健壮、规范且自带文档的配置文件。
核心理念:Schema驱动的配置
在新版插件系统中,我们引入了一套 配置Schema(模式)驱动 的机制。你不再需要手动创建和维护 config.toml 文件,而是通过在插件代码中 声明配置的结构,系统将为你完成剩下的工作。
核心优势:
- 自动化 (Automation): 如果配置文件不存在,系统会根据你的声明 自动生成 一份包含默认值和详细注释的
config.toml文件。 - 规范化 (Standardization): 所有插件的配置都遵循统一的结构,提升了可维护性。
- 自带文档 (Self-documenting): 配置文件中的每一项都包含详细的注释、类型说明、可选值和示例,极大地降低了用户的使用门槛。
- 健壮性 (Robustness): 在代码中直接定义配置的类型和默认值,减少了因配置错误导致的运行时问题。
- 易于管理 (Easy Management): 生成的配置文件可以方便地加入
.gitignore,避免将个人配置(如API Key)提交到版本库。
如何定义配置
配置的定义在你的插件主类(继承自 BasePlugin)中完成,主要通过两个类属性:
config_section_descriptions: 一个字典,用于描述配置文件的各个区段([section])。config_schema: 核心部分,一个嵌套字典,用于定义每个区段下的具体配置项。
ConfigField:配置项的基石
每个配置项都通过一个 ConfigField 对象来定义。
from src.plugin_system.base.config_types import ConfigField
@dataclass
class ConfigField:
"""配置字段定义"""
type: type # 字段类型 (例如 str, int, float, bool, list)
default: Any # 默认值
description: str # 字段描述 (将作为注释生成到配置文件中)
example: Optional[str] = None # 示例值 (可选)
required: bool = False # 是否必需 (可选, 主要用于文档提示)
choices: Optional[List[Any]] = None # 可选值列表 (可选)
完整示例
让我们以一个功能丰富的 MutePlugin 为例,看看如何定义它的配置。
1. 插件代码 (plugin.py)
# src/plugins/built_in/mute_plugin/plugin.py
# ... 其他导入 ...
from src.plugin_system import BasePlugin, register_plugin
from src.plugin_system.base.config_types import ConfigField
from typing import List, Tuple, Type
@register_plugin
class MutePlugin(BasePlugin):
"""禁言插件"""
# 插件基本信息
plugin_name = "mute_plugin"
plugin_description = "群聊禁言管理插件,提供智能禁言功能"
plugin_version = "2.0.0"
plugin_author = "MaiBot开发团队"
enable_plugin = True
config_file_name = "config.toml"
# 步骤1: 定义配置节的描述
config_section_descriptions = {
"plugin": "插件基本信息配置",
"components": "组件启用控制",
"mute": "核心禁言功能配置",
"smart_mute": "智能禁言Action的专属配置",
"logging": "日志记录相关配置"
}
# 步骤2: 使用ConfigField定义详细的配置Schema
config_schema = {
"plugin": {
"name": ConfigField(type=str, default="mute_plugin", description="插件名称", required=True),
"version": ConfigField(type=str, default="2.0.0", description="插件版本号"),
"enabled": ConfigField(type=bool, default=False, description="是否启用插件"),
"description": ConfigField(type=str, default="群聊禁言管理插件", description="插件描述", required=True)
},
"components": {
"enable_smart_mute": ConfigField(type=bool, default=True, description="是否启用智能禁言Action"),
"enable_mute_command": ConfigField(type=bool, default=False, description="是否启用禁言命令Command")
},
"mute": {
"min_duration": ConfigField(type=int, default=60, description="最短禁言时长(秒)"),
"max_duration": ConfigField(type=int, default=2592000, description="最长禁言时长(秒),默认30天"),
"templates": ConfigField(
type=list,
default=["好的,禁言 {target} {duration},理由:{reason}", "收到,对 {target} 执行禁言 {duration}"],
description="成功禁言后发送的随机消息模板"
)
},
"smart_mute": {
"keyword_sensitivity": ConfigField(
type=str,
default="normal",
description="关键词激活的敏感度",
choices=["low", "normal", "high"] # 定义可选值
),
},
"logging": {
"level": ConfigField(
type=str,
default="INFO",
description="日志记录级别",
choices=["DEBUG", "INFO", "WARNING", "ERROR"]
),
"prefix": ConfigField(type=str, default="[MutePlugin]", description="日志记录前缀", example="[MyMutePlugin]")
}
}
def get_plugin_components(self) -> List[Tuple[ComponentInfo, Type]]:
# ... 组件注册逻辑 ...
# 在这里可以通过 self.get_config() 来获取配置值
pass
2. 自动生成的配置文件 (config.toml)
当 mute_plugin 首次加载且其目录中不存在 config.toml 时,系统会自动创建以下文件:
# mute_plugin - 自动生成的配置文件
# 群聊禁言管理插件,提供智能禁言功能
# 插件基本信息配置
[plugin]
# 插件名称 (必需)
name = "mute_plugin"
# 插件版本号
version = "2.0.0"
# 是否启用插件
enabled = false
# 插件描述 (必需)
description = "群聊禁言管理插件"
# 组件启用控制
[components]
# 是否启用智能禁言Action
enable_smart_mute = true
# 是否启用禁言命令Command
enable_mute_command = false
# 核心禁言功能配置
[mute]
# 最短禁言时长(秒)
min_duration = 60
# 最长禁言时长(秒),默认30天
max_duration = 2592000
# 成功禁言后发送的随机消息模板
templates = ["好的,禁言 {target} {duration},理由:{reason}", "收到,对 {target} 执行禁言 {duration}"]
# 智能禁言Action的专属配置
[smart_mute]
# 关键词激活的敏感度
# 可选值: low, normal, high
keyword_sensitivity = "normal"
# 日志记录相关配置
[logging]
# 日志记录级别
# 可选值: DEBUG, INFO, WARNING, ERROR
level = "INFO"
# 日志记录前缀
# 示例: [MyMutePlugin]
prefix = "[MutePlugin]"
最佳实践
- 定义优于创建: 始终优先在
plugin.py中定义config_schema,而不是手动创建config.toml。 - 描述清晰: 为每个
ConfigField和config_section_descriptions编写清晰、准确的描述。这会直接成为你的插件文档的一部分。 - 提供合理默认值: 确保你的插件在默认配置下就能正常运行(或处于一个安全禁用的状态)。
- gitignore: 将
plugins/*/config.toml或src/plugins/built_in/*/config.toml加入.gitignore,以避免提交个人敏感信息。 - 访问配置: 在插件的任何地方,统一使用
self.api.get_config("section.key", "default_value")来安全地获取配置值。详细请参考 插件配置访问指南。