Skip to content

API 文档编写说明

本文档定义 docs/zh/api/ 目录下各 API 模块文档的统一结构和编写规范。

目录结构

API 文档按模块组织,每个模块一个文件,使用两位数字序号前缀。

文件统一结构

每个 API 模块文档应遵循以下结构:

markdown
# <模块名称>

<简短介绍,说明本模块的主要功能和用途>

## <可选的概念/介绍章节>

(如需要,介绍本模块涉及的核心概念、工作流程等)

## API 参考

### <API 方法名 1>

#### 1. API 实现介绍

<介绍该 API 的用途,指向对应的代码入口,简单介绍原理和流程>

**代码入口**
- `openviking/<模块>/<文件>.py:<类名>.<方法名>` - 核心实现
- `openviking/server/routers/<路由文件>.py` - HTTP 路由
- `openviking_cli/commands/<命令文件>.py` - CLI 命令

#### 2. 接口和参数说明

**参数**

| 参数 | 类型 | 必填 | 默认值 | 说明 |
|------|------|------|--------|------|
| <参数名> | <类型> | <是/否> | <默认值> | <详细说明> |
| ... | ... | ... | ... | ... |

**<可选的补充说明章节>**

(如需要,说明特殊行为、注意事项、使用场景等)

#### 3. 使用示例

**HTTP API**

```
<HTTP 方法> <路径>
```

```bash
<curl 示例>
```

**Python SDK**

```python
<SDK 调用示例>
```

**CLI**

```bash
<CLI 命令示例>
```

**响应示例**

```json
<JSON 响应示例>
```

#### 4. 响应示例、错误和异常处理等(可选)

---

### <API 方法名 2>

(重复上述结构)

---

## <可选的其他章节>

## 相关文档

- [<文档标题>](<相对路径>) - <简短说明>

结构详解

标题与简介

  • 一级标题是模块名称
  • 简介用一段话说明该模块的用途和主要功能

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 方法和路径正确
  • [ ] 响应示例与实际返回一致

Released under the Apache-2.0 License.