Files
2025-08-14 10:45:56 +08:00

3.9 KiB
Raw Permalink Blame History

OneBot Chatbot Framework

该项目是一个基于OneBot标准的聊天机器人后端框架采用高度可扩展的插件架构设计支持消息的模块化处理和插件热加载。

项目特点

  • 模块化设计:每个功能作为独立插件实现,易于扩展和维护
  • 插件生命周期管理:支持插件加载、注册、依赖处理和实例管理
  • 消息处理管道:分阶段处理消息,支持各阶段拦截机制
  • 会话管理:支持群组消息和私聊消息的独立管理
  • 内嵌依赖处理自动管理插件内嵌的Python依赖包
  • 兼容性设计:支持新旧版本插件并存运行

核心组件

消息处理流程 (process_message)

def process_message(uid: str, gid: str | None, message: str) -> str:
    # 1. 创建消息上下文
    ctx = MessageContext(...)
  
    # 2. 扫描并加载插件
    plugin_manager.scan_plugins()
  
    # 3. 消息处理阶段:
    #   - before_load: 加载数据前拦截点
    #   - after_load:  加载数据后处理点
    #   - after_save:  保存数据后处理点
  
    # 4. 会话数据持久化
    ctx.chat_manager.save_message(...)
  
    return ctx.response or "ok"

插件管理器 (PluginManager)

class PluginManager:
    def __init__(self):
        self._plugins = {}       # 插件类注册表
        self._active_instances = {}  # 插件实例
        self._hook_registry = {}     # 兼容旧版钩子
        self._temp_dirs = []         # 临时目录
        self._dependency_manager = DependencyManager()  # 依赖处理器

    def scan_plugins(self):
        """扫描插件目录并加载ZIP格式插件"""
  
    def load_plugin(self, zip_path: str) -> bool:
        """动态加载ZIP格式插件"""
  
    def _load_embedded_dependencies(self, plugin_dir: str) -> bool:
        """加载插件内嵌的依赖包"""
  
    def register_hook(self, hook_name: str):
        """注册兼容旧版钩子(装饰器模式)"""
  
    def cleanup(self):
        """清理临时资源"""

插件开发指南

基本插件结构

# process.py
from src.modules.plugin_modules import BasePlugin, MessageContext

class MyPlugin(BasePlugin):
    def __init__(self, ctx: MessageContext):
        super().__init__(ctx)
  
    def process(self) -> str | None:
        """核心处理方法"""
        if self.ctx.command == "help":
            return self._show_help()
  
    def before_load(self) -> str | None:
        """数据加载前拦截点"""
  
    def after_load(self) -> str | None:
        """数据加载后处理点"""
  
    def after_save(self) -> str | None:
        """数据保存后处理点"""

目录结构要求

插件应以ZIP格式打包包含以下内容

my_plugin.zip
├── process.py            # 必需 - 插件入口文件
├── requirements.txt      # 可选 - 依赖声明
└── packages/             # 可选 - 内嵌依赖包
    ├── package1/
    └── package2/

依赖声明

插件可通过两种方式声明依赖:

  1. requirements.txt 标准格式
  2. dependencies.json 自定义格式
// dependencies.json 示例
{
    "requirements": [
        "requests==2.28.2",
        "numpy>=1.25.0"
    ]
}

快速启动

  1. 为启动脚本授权(linux)

    chmod +x run.sh
    
  2. 修改配置文件list_port为接收消息推送端口send_url为消息发送地址

  3. 运行启动脚本 linux下

    ./run.sh

    windows下

    .\run.bat

设计优势

  1. 解耦设计:插件与核心系统完全解耦
  2. 安全隔离:使用临时目录加载插件
  3. 版本兼容:内建依赖版本验证机制
  4. 灵活扩展:支持多个消息处理点
  5. 新旧兼容支持传统钩子和现代OOP插件的共存

更多插件开发支持请访问聊天机器人插件开发支持