Files
WeKnora/docs/api/web-search.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

7.3 KiB
Raw Blame History

Web Search API

返回目录

包含两组接口:

  • /web-search/providers:返回可用的 provider 类型(只读元数据)
  • /web-search-providers/*:当前租户自定义保存的 provider CRUD 与连通性测试
方法 路径 描述
GET /web-search/providers 获取网络搜索服务商类型列表
GET /web-search-providers/types 获取 Provider 类型元数据(含参数定义)
POST /web-search-providers/test 使用原始凭证测试连通性(不落库)
POST /web-search-providers 创建租户级 Provider 配置
GET /web-search-providers 获取当前租户已保存的 Provider 列表
GET /web-search-providers/:id 获取指定 Provider 详情
PUT /web-search-providers/:id 更新 Provider
DELETE /web-search-providers/:id 删除 Provider
POST /web-search-providers/:id/test 使用已保存凭证测试连通性

GET /web-search/providers - 获取网络搜索服务商类型列表

获取系统中可用的网络搜索服务商列表(系统级元数据,与租户无关)。

请求:

curl --location 'http://localhost:8080/api/v1/web-search/providers' \
--header 'X-API-Key: sk-xxxxx' \
--header 'Content-Type: application/json'

响应:

{
    "data": [
        {
            "name": "google",
            "label": "Google Search",
            "description": "通过 Google 自定义搜索 API 进行网络搜索",
            "enabled": true
        },
        {
            "name": "bing",
            "label": "Bing Search",
            "description": "通过 Bing Search API 进行网络搜索",
            "enabled": true
        },
        {
            "name": "serpapi",
            "label": "SerpAPI",
            "description": "通过 SerpAPI 进行搜索引擎结果抓取",
            "enabled": false
        }
    ],
    "success": true
}

GET /web-search-providers/types - 获取 Provider 类型元数据

返回 UI 表单需要的所有 provider 类型及参数定义(每种 provider 需要哪些字段、类型、是否必填)。

请求:

curl --location 'http://localhost:8080/api/v1/web-search-providers/types' \
--header 'X-API-Key: sk-xxxxx'

响应:

{
    "data": [
        {
            "provider": "google",
            "label": "Google Search",
            "description": "...",
            "parameter_schema": [
                { "name": "api_key", "label": "API Key", "type": "string", "required": true },
                { "name": "cx", "label": "Search Engine ID", "type": "string", "required": true }
            ]
        }
    ],
    "success": true
}

POST /web-search-providers/test - 使用原始凭证测试连通性

前端表单"测试连接"按钮使用:用尚未保存的凭证发起一次样本搜索。

参数说明(请求体):

字段 类型 必填 说明
provider string provider 类型(如 googlebing
parameters object 该 provider 所需凭证与参数(与 /typesparameter_schema 对应)

请求:

curl --location --request POST 'http://localhost:8080/api/v1/web-search-providers/test' \
--header 'X-API-Key: sk-xxxxx' \
--header 'Content-Type: application/json' \
--data '{
    "provider": "google",
    "parameters": {
        "api_key": "AIza...",
        "cx": "0123456789:abcdefg"
    }
}'

响应:

{ "success": true }

失败时:

{ "success": false, "error": "google api: 403 forbidden" }

POST /web-search-providers - 创建 Provider

参数说明(请求体):

字段 类型 必填 说明
name string Provider 显示名(在租户内唯一友好名)
provider string Provider 类型(来自 /web-search-providers/types
description string 备注
parameters object 凭证与参数
is_default boolean 是否设为当前租户默认 Provider

请求:

curl --location 'http://localhost:8080/api/v1/web-search-providers' \
--header 'X-API-Key: sk-xxxxx' \
--header 'Content-Type: application/json' \
--data '{
    "name": "公司 Google CSE",
    "provider": "google",
    "description": "用于内网搜索",
    "parameters": {
        "api_key": "AIza...",
        "cx": "0123456789:abcdefg"
    },
    "is_default": true
}'

响应:

{
    "data": {
        "id": "wsp-...",
        "tenant_id": 1,
        "name": "公司 Google CSE",
        "provider": "google",
        "is_default": true,
        "parameters": { "api_key": "***", "cx": "0123456789:abcdefg" }
    },
    "success": true
}

GET /web-search-providers - 获取 Provider 列表

返回当前租户已保存的所有 Provider。

请求:

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

响应:

{
    "data": [
        { "id": "wsp-001", "name": "公司 Google CSE", "provider": "google", "is_default": true }
    ],
    "success": true
}

GET /web-search-providers/:id - 获取 Provider 详情

路径参数:

字段 类型 说明
id string Provider ID

请求:

curl --location 'http://localhost:8080/api/v1/web-search-providers/wsp-001' \
--header 'X-API-Key: sk-xxxxx'

响应: 同创建接口。404 表示不存在。

PUT /web-search-providers/:id - 更新 Provider

说明provider 字段(类型)创建后不可修改,仅支持更新 name / description / parameters / is_default

参数说明(请求体): 同创建接口,但不包含 provider

请求:

curl --location --request PUT 'http://localhost:8080/api/v1/web-search-providers/wsp-001' \
--header 'X-API-Key: sk-xxxxx' \
--header 'Content-Type: application/json' \
--data '{
    "name": "公司 Google CSE (v2)",
    "parameters": { "api_key": "NEW...", "cx": "0123456789:abcdefg" },
    "is_default": false
}'

响应: { "data": {...更新后实体...}, "success": true }

DELETE /web-search-providers/:id - 删除 Provider

请求:

curl --location --request DELETE 'http://localhost:8080/api/v1/web-search-providers/wsp-001' \
--header 'X-API-Key: sk-xxxxx'

响应: { "success": true }

POST /web-search-providers/:id/test - 测试已保存的 Provider

使用数据库中已保存的凭证发起一次样本搜索。

请求:

curl --location --request POST 'http://localhost:8080/api/v1/web-search-providers/wsp-001/test' \
--header 'X-API-Key: sk-xxxxx'

响应: 同 POST /web-search-providers/test