mirror of
https://github.com/jxxghp/MoviePilot-Plugins.git
synced 2026-05-31 23:16:48 +00:00
104 lines
5.0 KiB
Markdown
104 lines
5.0 KiB
Markdown
# 如何在插件中注册智能体工具?
|
||
|
||
返回 [README](../../README.md) | [FAQ 索引](../FAQ.md)
|
||
|
||
**(仅支持 `v2.8.0+` 版本)**
|
||
- MoviePilot的AI智能体功能支持通过插件扩展工具能力,插件可以注册自定义工具供智能体调用,实现更丰富的功能扩展。
|
||
- 1. 实现 `get_agent_tools()` 方法,返回工具类列表:
|
||
```python
|
||
def get_agent_tools(self) -> List[Type]:
|
||
"""
|
||
获取插件智能体工具
|
||
返回工具类列表,每个工具类必须继承自 MoviePilotTool
|
||
"""
|
||
return [MyCustomTool, AnotherTool]
|
||
```
|
||
|
||
- 2. 创建工具类,必须继承自 `MoviePilotTool` 并实现相关要求:
|
||
```python
|
||
from typing import Optional, Type
|
||
from pydantic import BaseModel, Field
|
||
from app.agent.tools.base import MoviePilotTool
|
||
from app.chain import ToolChain
|
||
|
||
class MyToolInput(BaseModel):
|
||
"""工具输入参数模型"""
|
||
explanation: str = Field(..., description="工具使用说明")
|
||
query: str = Field(..., description="查询内容")
|
||
limit: Optional[int] = Field(10, description="返回结果数量限制")
|
||
|
||
class MyCustomTool(MoviePilotTool):
|
||
"""自定义工具示例"""
|
||
# 工具名称,用于智能体识别和调用
|
||
name: str = "my_custom_tool"
|
||
|
||
# 工具描述,用于智能体理解工具功能,建议详细描述工具用途和使用场景
|
||
description: str = "This tool is used to perform custom operations. Use it when you need to query or process specific data."
|
||
|
||
# 输入参数模型,定义工具接收的参数及其类型和说明
|
||
args_schema: Type[BaseModel] = MyToolInput
|
||
|
||
def get_tool_message(self, **kwargs) -> Optional[str]:
|
||
"""根据订阅参数生成友好的提示消息"""
|
||
pass
|
||
|
||
async def run(self, query: str, limit: Optional[int] = None, **kwargs) -> str:
|
||
"""
|
||
实现工具的核心逻辑(异步方法)
|
||
:param query: 查询内容
|
||
:param limit: 结果数量限制
|
||
:param kwargs: 其他参数,包含 explanation(工具使用说明)
|
||
:return: 工具执行结果,返回字符串格式
|
||
"""
|
||
try:
|
||
# 获取上下文信息(系统自动注入)
|
||
session_id = self._session_id
|
||
user_id = self._user_id
|
||
channel = self._channel
|
||
source = self._source
|
||
username = self._username
|
||
|
||
# 执行工具逻辑
|
||
result = await self._perform_operation(query, limit)
|
||
|
||
# 可以通过 send_tool_message 发送消息给用户
|
||
await self.send_tool_message(f"操作完成: {result}", title="工具执行")
|
||
|
||
# 返回执行结果
|
||
return f"成功处理查询 '{query}',返回 {len(result)} 条结果"
|
||
except Exception as e:
|
||
return f"执行失败: {str(e)}"
|
||
|
||
async def _perform_operation(self, query: str, limit: int):
|
||
"""内部方法,执行具体操作"""
|
||
# 实现具体业务逻辑
|
||
pass
|
||
```
|
||
|
||
- 3. 工具类可用的上下文属性和方法:
|
||
- `self._session_id`: 当前会话ID
|
||
- `self._user_id`: 用户ID
|
||
- `self._channel`: 消息渠道(如 Telegram、Slack 等)
|
||
- `self._source`: 消息来源
|
||
- `self._username`: 用户名
|
||
- `self.send_tool_message(message: str, title: str = "")`: 发送消息给用户
|
||
- `ToolChain()`: 访问处理链功能,可调用系统其他功能
|
||
|
||
- 4. 工具类实现要求:
|
||
- **必须继承自 `app.agent.tools.base.MoviePilotTool`**
|
||
- **必须实现 `run` 方法**(异步方法),接收参数并返回字符串结果
|
||
- **必须实现 `get_tool_message` 方法**,以显示友好的工具执行提示给用户
|
||
- **必须定义 `name` 属性**(字符串),工具的唯一标识
|
||
- **必须定义 `description` 属性**(字符串),详细描述工具功能,帮助智能体理解何时使用该工具
|
||
- **可选定义 `args_schema` 属性**(Pydantic模型类),用于定义输入参数的结构和验证
|
||
|
||
- 5. 注意事项:
|
||
- 工具的描述(`description`)应该清晰明确,帮助智能体理解工具的功能和使用场景
|
||
- 工具的参数模型(`args_schema`)应该包含详细的字段描述,帮助智能体正确构造参数
|
||
- 工具执行结果应该返回有意义的字符串,便于智能体理解和向用户展示
|
||
- 工具可以通过 `send_tool_message` 方法向用户发送实时消息,提升交互体验
|
||
- 工具类在初始化时会自动注入会话和用户信息,可以通过私有属性访问
|
||
- 如果工具需要访问插件实例,需要自行通过 `PluginManager` 获取
|
||
- 工具执行时间应该尽量短,避免阻塞智能体的响应
|
||
- 建议在工具执行过程中添加适当的错误处理和日志记录
|