Files
WeKnora/docs/api/agent.md
nullkey 1c7171b2c6 docs(api): rewrite markdown to match current routes
Refs #890 #1049 #1168.

按集成方视角全量审计 17 个 API markdown 文档与 internal/router/router.go
对齐。每个端点新增参数说明小节(path/query/body 字段含义)和响应字段
含义说明(#1168 的核心诉求)。

【与代码对齐】
- 删除已下线端点:system.md 中的 /system/minio/buckets(代码中已无对
  应路由)。
- 修正路径错误:chunk.md 中 /chunks/get-by-id/:id → /chunks/by-id/:id;
  /chunks/:id/delete-question → /chunks/by-id/:id/questions;
  organization.md 中 /organizations/preview/:invite_code → :code。
- 修正字段类型:faq tag_id / entry_id 由 string 改为 int64;
  knowledge.search 响应结构纠正。
- 补齐缺失端点(move-targets、batch-delete、move/progress、pin/unpin/
  stop/continue-stream、tool-approvals、organization agent-shares 等
  30+ 条)。

【精简】
- knowledge-base.md / model.md 把重复 5 次 / 3 次的完整对象样例
  收敛为指向首次出现("字段结构同 POST /xxx 响应"),节省约 400 行
  而不损失信息(仅去重,原作者写的每个字段定义都保留可达)。
- 示例 X-API-Key 统一为 sk-xxxxx(避免读者复制看似真实的 key)。

【清理】
- 删除内部实现细节引用:mcp-service.md 中 6 处 "issue #1173"、
  organization.md 中 "RegisterOrganizationRoutes" 等。

不动 initialization.md:其中端点(KB 配置、模型连通性测试、Ollama 管理)
对集成方有实用价值,保留原作者写好的内容不删。

格式统一遵循 web-search.md 重写后的范式(路由表 + 每端点方法/路径 +
参数表 + curl + 响应 JSON + 字段说明)。
2026-05-12 13:16:58 +08:00

18 KiB
Raw Permalink Blame History

智能体Agent管理 API

返回目录

概述

智能体 API 用于管理自定义智能体Custom Agent。系统提供了内置智能体同时支持用户创建自定义智能体来满足不同的业务场景需求。

智能体的共享与跨组织分发(/agents/:id/shares 等)属于组织协作能力,文档见 组织管理 API。本文件只覆盖智能体自身的 CRUD、复制、占位符、类型预设以及推荐问题接口。

内置智能体

系统默认提供以下内置智能体:

ID 名称 描述 模式
builtin-quick-answer 快速问答 基于知识库的 RAG 问答,快速准确地回答问题 quick-answer
builtin-smart-reasoning 智能推理 ReAct 推理框架,支持多步思考和工具调用 smart-reasoning
builtin-data-analyst 数据分析师 专业数据分析智能体,支持 CSV/Excel 文件的 SQL 查询与统计分析 smart-reasoning

智能体模式

模式 说明
quick-answer RAG 模式,快速问答,直接基于知识库检索结果生成回答
smart-reasoning ReAct 模式,支持多步推理和工具调用

API 列表

方法 路径 描述
POST /agents 创建智能体
GET /agents 获取智能体列表
GET /agents/:id 获取智能体详情
PUT /agents/:id 更新智能体
DELETE /agents/:id 删除智能体
POST /agents/:id/copy 复制智能体
GET /agents/placeholders 获取占位符定义

POST /agents - 创建智能体

创建新的自定义智能体。成功返回 HTTP 201。

请求体参数:

参数 类型 必填 说明
name string 智能体名称
description string 智能体描述
avatar string 头像emoji 或图标名称)
config object 智能体配置,详见 配置参数

请求:

curl --location 'http://localhost:8080/api/v1/agents' \
--header 'X-API-Key: sk-xxxxx' \
--header 'Content-Type: application/json' \
--data '{
    "name": "我的智能体",
    "description": "自定义智能体描述",
    "avatar": "🤖",
    "config": {
        "agent_mode": "smart-reasoning",
        "system_prompt": "你是一个专业的助手...",
        "temperature": 0.7,
        "max_iterations": 10,
        "kb_selection_mode": "all",
        "web_search_enabled": true,
        "multi_turn_enabled": true,
        "history_turns": 5
    }
}'

响应:

{
    "success": true,
    "data": {
        "id": "550e8400-e29b-41d4-a716-446655440000",
        "name": "我的智能体",
        "description": "自定义智能体描述",
        "avatar": "🤖",
        "is_builtin": false,
        "tenant_id": 1,
        "created_by": "user-123",
        "config": {
            "agent_mode": "smart-reasoning",
            "system_prompt": "你是一个专业的助手...",
            "temperature": 0.7,
            "max_iterations": 10
        },
        "created_at": "2025-01-19T10:00:00Z",
        "updated_at": "2025-01-19T10:00:00Z"
    }
}

错误响应:

状态码 错误码 错误 说明
400 1000 Bad Request 请求参数错误或智能体名称为空
500 1007 Internal Server Error 服务器内部错误

GET /agents - 获取智能体列表

获取当前租户的所有智能体,包括内置智能体和自定义智能体。响应中额外返回 disabled_own_agent_ids,指示当前租户在前端对话下拉框中主动隐藏的本租户自有智能体 ID 列表(不影响其他租户)。

请求:

curl --location 'http://localhost:8080/api/v1/agents' \
--header 'X-API-Key: sk-xxxxx'

响应:

{
    "success": true,
    "data": [
        {
            "id": "builtin-quick-answer",
            "name": "快速问答",
            "description": "基于知识库的 RAG 问答,快速准确地回答问题",
            "avatar": "💬",
            "is_builtin": true,
            "tenant_id": 10000,
            "created_by": "",
            "config": {
                "agent_mode": "quick-answer",
                "temperature": 0.3,
                "max_completion_tokens": 2048,
                "kb_selection_mode": "all",
                "web_search_enabled": false,
                "multi_turn_enabled": true,
                "history_turns": 5
            },
            "created_at": "2025-12-29T20:06:01.696308+08:00",
            "updated_at": "2025-12-29T20:06:01.696308+08:00",
            "deleted_at": null
        },
        {
            "id": "550e8400-e29b-41d4-a716-446655440000",
            "name": "我的智能体",
            "is_builtin": false,
            "config": {
                "agent_mode": "smart-reasoning"
            }
        }
    ],
    "disabled_own_agent_ids": []
}

错误响应:

状态码 错误码 错误 说明
401 1001 Unauthorized 缺少租户上下文
500 1007 Internal Server Error 服务器内部错误

GET /agents/:id - 获取智能体详情

根据 ID 获取智能体的详细信息。

路径参数:

参数 类型 说明
id string 智能体 ID

请求:

curl --location 'http://localhost:8080/api/v1/agents/builtin-quick-answer' \
--header 'X-API-Key: sk-xxxxx'

响应:

{
    "success": true,
    "data": {
        "id": "builtin-quick-answer",
        "name": "快速问答",
        "description": "基于知识库的 RAG 问答,快速准确地回答问题",
        "is_builtin": true,
        "tenant_id": 1,
        "config": {
            "agent_mode": "quick-answer",
            "system_prompt": "",
            "context_template": "请根据以下参考资料回答用户问题...",
            "temperature": 0.7,
            "max_completion_tokens": 2048,
            "kb_selection_mode": "all",
            "web_search_enabled": true,
            "multi_turn_enabled": true,
            "history_turns": 5
        },
        "created_at": "2025-01-01T00:00:00Z",
        "updated_at": "2025-01-01T00:00:00Z"
    }
}

错误响应:

状态码 错误码 错误 说明
400 1000 Bad Request 智能体 ID 为空
404 1003 Not Found 智能体不存在
500 1007 Internal Server Error 服务器内部错误

PUT /agents/:id - 更新智能体

更新智能体的名称、描述、头像和配置。内置智能体不可修改。

路径参数:

参数 类型 说明
id string 智能体 ID

请求体参数:

参数 类型 必填 说明
name string 智能体名称
description string 智能体描述
avatar string 智能体头像
config object 智能体配置

请求:

curl --location --request PUT 'http://localhost:8080/api/v1/agents/550e8400-e29b-41d4-a716-446655440000' \
--header 'X-API-Key: sk-xxxxx' \
--header 'Content-Type: application/json' \
--data '{
    "name": "更新后的智能体",
    "description": "更新后的描述",
    "config": {
        "agent_mode": "smart-reasoning",
        "temperature": 0.8,
        "max_iterations": 20
    }
}'

响应:

{
    "success": true,
    "data": {
        "id": "550e8400-e29b-41d4-a716-446655440000",
        "name": "更新后的智能体",
        "description": "更新后的描述",
        "config": {
            "agent_mode": "smart-reasoning",
            "temperature": 0.8,
            "max_iterations": 20
        },
        "updated_at": "2025-01-19T11:00:00Z"
    }
}

错误响应:

状态码 错误码 错误 说明
400 1000 Bad Request 请求参数错误或智能体名称为空
403 1002 Forbidden 无法修改内置智能体
404 1003 Not Found 智能体不存在
500 1007 Internal Server Error 服务器内部错误

DELETE /agents/:id - 删除智能体

删除指定的自定义智能体。内置智能体不可删除。

路径参数:

参数 类型 说明
id string 智能体 ID

请求:

curl --location --request DELETE 'http://localhost:8080/api/v1/agents/550e8400-e29b-41d4-a716-446655440000' \
--header 'X-API-Key: sk-xxxxx'

响应:

{
    "success": true,
    "message": "Agent deleted successfully"
}

错误响应:

状态码 错误码 错误 说明
400 1000 Bad Request 智能体 ID 为空
403 1002 Forbidden 无法删除内置智能体
404 1003 Not Found 智能体不存在
500 1007 Internal Server Error 服务器内部错误

POST /agents/:id/copy - 复制智能体

复制指定的智能体,创建一个新的副本,副本始终为自定义智能体。支持复制内置智能体。成功返回 HTTP 201。

路径参数:

参数 类型 说明
id string 源智能体 ID

请求:

curl --location --request POST 'http://localhost:8080/api/v1/agents/builtin-smart-reasoning/copy' \
--header 'X-API-Key: sk-xxxxx'

响应:

{
    "success": true,
    "data": {
        "id": "660e8400-e29b-41d4-a716-446655440001",
        "name": "智能推理 (副本)",
        "description": "ReAct 推理框架,支持多步思考和工具调用",
        "is_builtin": false,
        "config": {
            "agent_mode": "smart-reasoning",
            "max_iterations": 50
        },
        "created_at": "2025-01-19T12:00:00Z",
        "updated_at": "2025-01-19T12:00:00Z"
    }
}

错误响应:

状态码 错误码 错误 说明
400 1000 Bad Request 智能体 ID 为空
404 1003 Not Found 智能体不存在
500 1007 Internal Server Error 服务器内部错误

GET /agents/placeholders - 获取占位符定义

获取所有可用的提示词占位符定义,按字段类型分组。这些占位符可用于系统提示词和上下文模板中。

请求:

curl --location 'http://localhost:8080/api/v1/agents/placeholders' \
--header 'X-API-Key: your_api_key'

响应:

{
    "success": true,
    "data": {
        "all": [...],
        "system_prompt": [...],
        "agent_system_prompt": [...],
        "context_template": [...],
        "rewrite_system_prompt": [...],
        "rewrite_prompt": [...],
        "fallback_prompt": [...]
    }
}

配置参数

智能体的 config 对象支持以下配置项:

基础设置

参数 类型 默认值 说明
agent_mode string - 智能体模式:quick-answerRAGsmart-reasoningReAct
system_prompt string - 系统提示词,支持使用占位符
system_prompt_id string - 系统提示词模板 ID引用 prompt_templates/ YAML 文件中的模板)
context_template string - 上下文模板(仅 quick-answer 模式使用)
context_template_id string - 上下文模板 ID引用 prompt_templates/ YAML 文件中的模板)

模型设置

参数 类型 默认值 说明
model_id string - 对话模型 ID
rerank_model_id string - 重排序模型 ID
temperature float 0.7 温度参数0-1
max_completion_tokens int 2048 最大生成 token 数
thinking *bool nil 是否启用思考模式(适用于支持扩展思考的模型)

Agent 模式设置

参数 类型 默认值 说明
max_iterations int 10 ReAct 最大迭代次数
allowed_tools []string - 允许使用的工具列表
mcp_selection_mode string - MCP 服务选择模式:all/selected/none
mcp_services []string - 选中的 MCP 服务 ID 列表
skills_selection_mode string - Skills 选择模式:all/selected/none
selected_skills []string - 选中的 Skill 名称列表mode 为 selected 时)

知识库设置

参数 类型 默认值 说明
kb_selection_mode string - 知识库选择模式:all/selected/none
knowledge_bases []string - 关联的知识库 ID 列表
retrieve_kb_only_when_mentioned bool false 仅在用户通过 @ 显式提及时才检索知识库
supported_file_types []string - 支持的文件类型(如 ["csv", "xlsx"]

图片上传 / 多模态设置

参数 类型 默认值 说明
image_upload_enabled bool false 是否允许上传图片
vlm_model_id string - 图片分析所用的 VLM 模型 ID
image_storage_provider string - 图片存储提供者:local/minio/cos/tos/oss,为空使用全局默认

FAQ 策略设置

参数 类型 默认值 说明
faq_priority_enabled bool true FAQ 优先策略开关
faq_direct_answer_threshold float 0.9 FAQ 直接回答阈值
faq_score_boost float 1.2 FAQ 分数加成系数

网络搜索设置

参数 类型 默认值 说明
web_search_enabled bool true 是否启用网络搜索
web_search_max_results int 5 网络搜索最大结果数
web_search_provider_id string - 网络搜索提供者 ID为空使用租户默认提供者
web_fetch_enabled bool false 是否自动获取重排后的搜索结果页面全文
web_fetch_top_n int 3 重排后获取全文的最大页面数

多轮对话设置

参数 类型 默认值 说明
multi_turn_enabled bool true 是否启用多轮对话
history_turns int 5 保留的历史轮次数

检索策略设置

参数 类型 默认值 说明
embedding_top_k int 10 向量检索 TopK
keyword_threshold float 0.3 关键词检索阈值
vector_threshold float 0.5 向量检索阈值
rerank_top_k int 5 重排序 TopK
rerank_threshold float 0.5 重排序阈值

推荐问题设置

参数 类型 默认值 说明
suggested_prompts []string - 推荐问题列表,用于在前端对话面板展示快捷提问

高级设置

参数 类型 默认值 说明
enable_query_expansion bool true 是否启用查询扩展
enable_rewrite bool true 是否启用多轮对话查询改写
rewrite_prompt_system string - 改写系统提示词
rewrite_prompt_user string - 改写用户提示词模板
fallback_strategy string model 回退策略:fixed(固定回复)或 model(模型生成);未设置时在服务端默认为 model
fallback_response string - 固定回退回复(fallback_strategyfixed 时使用)
fallback_prompt string - 回退提示词(fallback_strategymodel 时使用)

使用 Agent 进行问答

创建或获取智能体后,可以通过 /agent-chat/:session_id 接口使用智能体进行问答。详情请参考 聊天功能 API

在问答请求中使用 agent_id 参数指定要使用的智能体:

curl --location 'http://localhost:8080/api/v1/agent-chat/session-123' \
--header 'X-API-Key: sk-xxxxx' \
--header 'Content-Type: application/json' \
--data '{
    "query": "帮我分析一下这份数据",
    "agent_enabled": true,
    "agent_id": "builtin-data-analyst"
}'

相关文档

  • 智能体的组织共享、跨租户分发与禁用(/agents/:id/shares/shared-agents 等):见 组织管理 API
  • 智能体绑定 IM 渠道(/agents/:id/im-channels):见组织/IM 渠道相关文档
  • 网络搜索提供者配置(被 web_search_provider_id 引用):见 Web Search API