feat(mcp): 完整落地 MCP 服务管理
- Dockerfile 后端 stage 加 nodejs/npm,支持 stdio MCP server - 新增前端 MCP 服务管理 UI(MCPSettings.tsx),支持 stdio/sse/http 三种 transport - PluginLayout 改双 tab(技能 / MCP 服务) - i18n 补 MCP 相关 zh/en 文案 - send_file 工具的 trace_id 改可选,聊天场景退化为返回内容 - system_workflow 工具集纳入 send_file Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
This commit is contained in:
@@ -35,20 +35,25 @@ class SendFileToolData(BaseToolData):
|
||||
category: str = "system"
|
||||
|
||||
|
||||
async def send_file(filename: str, content: str, trace_id: str) -> str:
|
||||
async def send_file(filename: str, content: str, trace_id: str = "") -> str:
|
||||
"""把 agent 生成的文件作为附件发送给当前对话窗口。
|
||||
|
||||
通过 global_workflow_manager 的 pending 队列推送一条带特殊前缀的 JSON 消息,
|
||||
前端识别后渲染为可下载的文件卡片。
|
||||
工作流场景下调用方会在 deps 中注入 trace_id,工具通过 global_workflow_manager
|
||||
的 pending 队列推送一条带特殊前缀的 JSON 消息,前端识别后渲染为可下载的卡片。
|
||||
|
||||
聊天场景下 trace_id 为空时退化为直接返回文件内容字符串,由模型把内容贴到回复里。
|
||||
|
||||
Args:
|
||||
filename: 文件名(含扩展名),如 "report.md" / "main.py"
|
||||
content: 文件内容(UTF-8 文本)
|
||||
trace_id: 当前会话/工作流的 trace_id
|
||||
trace_id: 当前会话/工作流的 trace_id;为空时退化为直接返回内容
|
||||
|
||||
Returns:
|
||||
发送结果说明
|
||||
发送结果说明或文件内容
|
||||
"""
|
||||
if not trace_id:
|
||||
return f"文件 {filename} 内容如下:\n\n```\n{content}\n```"
|
||||
|
||||
payload = json.dumps(
|
||||
{"type": "file", "filename": filename, "content": content},
|
||||
ensure_ascii=False,
|
||||
|
||||
Reference in New Issue
Block a user