# API 文档编写说明 本文档定义 `docs/zh/api/` 目录下各 API 模块文档的统一结构和编写规范。 ## 目录结构 API 文档按模块组织,每个模块一个文件,使用两位数字序号前缀。 ## 文件统一结构 每个 API 模块文档应遵循以下结构: ````markdown # <模块名称> <简短介绍,说明本模块的主要功能和用途> ## <可选的概念/介绍章节> (如需要,介绍本模块涉及的核心概念、工作流程等) ## API 参考 ### #### 1. API 实现介绍 <介绍该 API 的用途,指向对应的代码入口,简单介绍原理和流程> **代码入口**: - `openviking/<模块>/<文件>.py:<类名>.<方法名>` - 核心实现 - `openviking/server/routers/<路由文件>.py` - HTTP 路由 - `openviking_cli/commands/<命令文件>.py` - CLI 命令 #### 2. 接口和参数说明 **参数** | 参数 | 类型 | 必填 | 默认值 | 说明 | |------|------|------|--------|------| | <参数名> | <类型> | <是/否> | <默认值> | <详细说明> | | ... | ... | ... | ... | ... | **<可选的补充说明章节>** (如需要,说明特殊行为、注意事项、使用场景等) #### 3. 使用示例 **HTTP API** ``` <路径> ``` ```bash ``` **Python SDK** ```python ``` **CLI** ```bash ``` **响应示例** ```json ``` #### 4. 响应示例、错误和异常处理等(可选) --- ### (重复上述结构) --- ## <可选的其他章节> ## 相关文档 - [<文档标题>](<相对路径>) - <简短说明> ```` ## 结构详解 ### 标题与简介 - 一级标题是模块名称 - 简介用一段话说明该模块的用途和主要功能 ### API 参考章节 每个接口按以下三个部分组织: #### 1. API 实现介绍 - 说明该 API 的用途 - 提供代码入口路径,方便读者查阅源码 - 简单介绍实现原理和处理流程 **代码入口说明**: - 核心实现:指向主要业务逻辑代码 - HTTP 路由:指向 FastAPI 路由定义 - CLI 命令:指向 CLI 命令实现(如有) #### 2. 接口和参数说明 - 参数表:包含参数名、类型、是否必填、默认值、说明 - 补充说明(可选):特殊行为、注意事项、使用场景等 #### 3. 使用示例 按顺序提供: - HTTP API(方法 + 路径 + curl 示例) - Python SDK 示例 - CLI 示例 - 响应示例 ## 示例:完整接口文档 ````markdown ### add_resource() #### 1. API 实现介绍 向知识库添加资源,支持本地文件、目录、URL 等多种来源。 **处理流程**: 1. 识别资源类型(本地文件/目录/URL) 2. 调用对应 Parser 解析内容 3. 构建目录树并写入 AGFS 4. 异步生成 L0/L1 语义摘要 5. 建立向量索引 **代码入口**: - `openviking/core/client.py:OpenViking.add_resource()` - SDK 入口 - `openviking/resource/importer.py:ResourceImporter.import_resource()` - 核心实现 - `openviking/server/routers/resources.py` - HTTP 路由 - `openviking_cli/commands/resources.py` - CLI 命令 #### 2. 接口和参数说明 **参数** | 参数 | 类型 | 必填 | 默认值 | 说明 | |------|------|------|--------|------| | path | str | 是 | - | 本地路径、目录路径或 URL | | to | str | 否 | None | 目标 Viking URI(必须在 resources 作用域内) | | reason | str | 否 | "" | 添加该资源的原因 | | wait | bool | 否 | False | 是否等待语义处理完成 | **说明** - SDK/CLI 可直接传本地路径;裸 HTTP 需要先用 `temp_upload` 上传 - 当指定 `to` 且目标已存在时,走增量更新流程 #### 3. 使用示例 **HTTP API** ``` POST /api/v1/resources ``` ```bash curl -X POST http://localhost:1933/api/v1/resources \ -H "Content-Type: application/json" \ -H "X-API-Key: your-key" \ -d '{ "path": "https://example.com/guide.md", "reason": "User guide documentation", "wait": true }' ``` **Python SDK** ```python import openviking as ov client = ov.OpenViking(path="./data") client.initialize() result = client.add_resource( "./documents/guide.md", reason="User guide documentation" ) print(f"Added: {result['root_uri']}") client.wait_processed() ``` **CLI** ```bash openviking add-resource ./documents/guide.md --reason "User guide documentation" --wait ``` **响应示例** ```json { "status": "ok", "result": { "status": "success", "root_uri": "viking://resources/documents/guide.md", "source_path": "./documents/guide.md", "errors": [] }, "time": 0.123 } ``` --- ```` ## 文档维护清单 新增或修改 API 文档时,请检查: - [ ] 实现介绍清晰,代码入口路径正确 - [ ] 参数表完整且准确 - [ ] 示例代码简洁且可运行 - [ ] HTTP 方法和路径正确 - [ ] 响应示例与实际返回一致