mirror of
https://github.com/Awuqing/BackupX.git
synced 2026-05-28 17:59:39 +08:00
Docusaurus 3.10 会把 locale id 'zh-Hans' 规范化为 BCP 47 的 'zh-CN' 来
读取 i18n/ 目录。之前手工创建的 i18n/zh-Hans/ 目录 Docusaurus 识别不到,
导致中文版 SSR 输出仍是英文字符串,只有 URL 路由 /zh-Hans/ 生效。
同时修复 index.tsx 中 <Translate id={labelId}> 动态 id 问题:
write-translations 工具要求静态字符串,已拆分为三个独立的 Translate 元素。
136 lines
4.6 KiB
Markdown
136 lines
4.6 KiB
Markdown
---
|
||
sidebar_position: 1
|
||
title: API 参考
|
||
description: REST API 端点 — 统一以 /api 为前缀,使用 JWT Bearer 认证。
|
||
---
|
||
|
||
# API 参考
|
||
|
||
所有端点都以 `/api` 为前缀,使用 JWT Bearer 令牌认证(通过 `POST /api/auth/login` 获取)。Agent 专用端点使用 `X-Agent-Token` 头认证。
|
||
|
||
## 认证
|
||
|
||
| 方法 | 端点 | 说明 |
|
||
|------|------|------|
|
||
| `GET` | `/api/auth/setup/status` | 查询是否需要初始化管理员 |
|
||
| `POST` | `/api/auth/setup` | 初始化首个管理员(仅当系统无任何用户时) |
|
||
| `POST` | `/api/auth/login` | 登录,返回 JWT |
|
||
| `POST` | `/api/auth/logout` | 登出(使当前 Token 失效) |
|
||
| `GET` | `/api/auth/profile` | 当前用户信息 |
|
||
| `PUT` | `/api/auth/password` | 修改密码 |
|
||
|
||
## 备份任务
|
||
|
||
| 方法 | 端点 | 说明 |
|
||
|------|------|------|
|
||
| `GET` | `/api/backup/tasks` | 列表 |
|
||
| `POST` | `/api/backup/tasks` | 创建 |
|
||
| `GET` | `/api/backup/tasks/:id` | 详情 |
|
||
| `PUT` | `/api/backup/tasks/:id` | 更新 |
|
||
| `DELETE` | `/api/backup/tasks/:id` | 删除 |
|
||
| `PUT` | `/api/backup/tasks/:id/toggle` | 启用 / 禁用 |
|
||
| `POST` | `/api/backup/tasks/:id/run` | 手动触发一次执行 |
|
||
|
||
## 备份记录
|
||
|
||
| 方法 | 端点 | 说明 |
|
||
|------|------|------|
|
||
| `GET` | `/api/backup/records` | 列表(支持筛选) |
|
||
| `GET` | `/api/backup/records/:id` | 记录详情 |
|
||
| `GET` | `/api/backup/records/:id/logs/stream` | 实时日志(SSE) |
|
||
| `GET` | `/api/backup/records/:id/download` | 下载备份产物 |
|
||
| `POST` | `/api/backup/records/:id/restore` | 恢复到原始源 |
|
||
| `DELETE` | `/api/backup/records/:id` | 删除记录 |
|
||
| `POST` | `/api/backup/records/batch-delete` | 批量删除 |
|
||
|
||
## 存储目标
|
||
|
||
| 方法 | 端点 | 说明 |
|
||
|------|------|------|
|
||
| `GET` | `/api/storage-targets` | 列表 |
|
||
| `POST` | `/api/storage-targets` | 创建 |
|
||
| `GET` | `/api/storage-targets/:id` | 详情 |
|
||
| `PUT` | `/api/storage-targets/:id` | 更新 |
|
||
| `DELETE` | `/api/storage-targets/:id` | 删除 |
|
||
| `POST` | `/api/storage-targets/test` | 用待审核配置测试连接 |
|
||
| `POST` | `/api/storage-targets/:id/test` | 重测已保存的目标 |
|
||
| `PUT` | `/api/storage-targets/:id/star` | 切换收藏状态 |
|
||
| `GET` | `/api/storage-targets/:id/usage` | 查询远端存储用量(支持此能力的后端) |
|
||
| `GET` | `/api/storage-targets/rclone/backends` | 列出可用的 rclone 后端 |
|
||
| `POST` | `/api/storage-targets/google-drive/auth-url` | 启动 Google Drive OAuth |
|
||
| `POST` | `/api/storage-targets/google-drive/complete` | 完成 OAuth 流程 |
|
||
|
||
## 节点(集群)
|
||
|
||
| 方法 | 端点 | 说明 |
|
||
|------|------|------|
|
||
| `GET` | `/api/nodes` | 节点列表 |
|
||
| `POST` | `/api/nodes` | 创建节点并返回 Token |
|
||
| `GET` | `/api/nodes/:id` | 节点详情 |
|
||
| `PUT` | `/api/nodes/:id` | 重命名 |
|
||
| `DELETE` | `/api/nodes/:id` | 删除(有关联任务时会被拒绝) |
|
||
| `GET` | `/api/nodes/:id/fs/list` | 浏览目录(远程节点走 Agent 异步 RPC) |
|
||
|
||
## Agent 协议(X-Agent-Token)
|
||
|
||
Agent CLI 专用端点,通过 `X-Agent-Token` 头认证而非 JWT。
|
||
|
||
| 方法 | 端点 | 说明 |
|
||
|------|------|------|
|
||
| `POST` | `/api/agent/heartbeat` | 上报心跳(返回节点 ID) |
|
||
| `POST` | `/api/agent/commands/poll` | 领取一条待执行命令 |
|
||
| `POST` | `/api/agent/commands/:id/result` | 上报命令结果 |
|
||
| `GET` | `/api/agent/tasks/:id` | 拉取任务规格(含解密后的存储配置) |
|
||
| `POST` | `/api/agent/records/:id` | 追加日志 / 更新记录状态 |
|
||
|
||
## 通知
|
||
|
||
| 方法 | 端点 | 说明 |
|
||
|------|------|------|
|
||
| `GET` | `/api/notifications` | 列表 |
|
||
| `POST` | `/api/notifications` | 创建 |
|
||
| `GET` | `/api/notifications/:id` | 详情 |
|
||
| `PUT` | `/api/notifications/:id` | 更新 |
|
||
| `DELETE` | `/api/notifications/:id` | 删除 |
|
||
| `POST` | `/api/notifications/test` | 用待审核配置测试 |
|
||
| `POST` | `/api/notifications/:id/test` | 重测已保存的通知器 |
|
||
|
||
## 仪表盘
|
||
|
||
| 方法 | 端点 | 说明 |
|
||
|------|------|------|
|
||
| `GET` | `/api/dashboard/stats` | 概览统计 |
|
||
| `GET` | `/api/dashboard/timeline` | 最近活动时间线 |
|
||
|
||
## 审计 / 系统 / 设置
|
||
|
||
| 方法 | 端点 | 说明 |
|
||
|------|------|------|
|
||
| `GET` | `/api/audit-logs` | 审计日志 |
|
||
| `GET` | `/api/system/info` | 系统信息 |
|
||
| `GET` | `/api/system/update-check` | 检查新版本 |
|
||
| `GET` | `/api/settings` | 系统级设置 |
|
||
| `PUT` | `/api/settings` | 更新系统设置 |
|
||
|
||
## 响应结构
|
||
|
||
成功响应统一为:
|
||
|
||
```json
|
||
{
|
||
"code": "OK",
|
||
"message": "",
|
||
"data": { /* 实际数据 */ }
|
||
}
|
||
```
|
||
|
||
错误返回 HTTP 4xx/5xx,并带:
|
||
|
||
```json
|
||
{
|
||
"code": "BACKUP_TASK_NOT_FOUND",
|
||
"message": "备份任务不存在",
|
||
"data": null
|
||
}
|
||
```
|