init: ops-assistant codebase

This commit is contained in:
OpenClaw Agent
2026-03-19 21:23:28 +08:00
commit 81deba4766
94 changed files with 10767 additions and 0 deletions

View File

@@ -0,0 +1,89 @@
# Ops-Assistant 后端独立化完成清单Phase 1~6
更新日期2026-03-10
---
## 总览
目标:`ops-assistant` 后端从旧 `xiaji-go` 记账心智中独立,形成 Ops 场景可扩展架构。
当前结论:
- ✅ 核心链路已成型:`Command -> Module -> Policy -> Runbook -> Audit -> Reply`
- ✅ 三模块CPA/CF/Mail已纳入统一执行骨架CF/Mail 为安全占位 runbook
- ✅ Ops Web 数据面已具备dashboard/modules/jobs/channels/audit/flags
- ✅ Legacy 兼容层已进入可观测可下线阶段usage/trend/readiness
---
## Phase 状态
## Phase 1API 基础收口
- ✅ 新增/改造接口统一 `{code,message,data}`
- ✅ 导出类接口保留文件流(`/api/v1/export`
- ✅ 失败路径统一 JSON 错误
## Phase 2模块管理后端
-`GET /api/v1/modules`
-`POST /api/v1/modules/:module/toggle`
- ✅ toggle reason 必填
- ✅ toggle 幂等 noop 返回
- ✅ 关键模块保护:禁止禁用 `cpa`
## Phase 3Dashboard 聚合后端
-`GET /api/v1/dashboard/overview`
-`GET /api/v1/dashboard/summary`
- ✅ jobs 列表多维筛选(见 Phase 4
## Phase 4Ops Jobs 能力增强
-`GET /api/v1/ops/jobs` 支持筛选:
- `limit/status/target/runbook/request_id/operator/risk_level/q/from/to`
-`GET /api/v1/ops/jobs/request/:requestID`(含 `total`
-`GET /api/v1/ops/jobs/:id``step_stats/step_total/duration`
-`POST /api/v1/ops/jobs/:id/cancel`reason 必填,状态校验)
-`POST /api/v1/ops/jobs/:id/retry`reason 必填,仅 failed
## Phase 5策略与风控中心化阶段性
-`policy.CheckGate` 作为 gate 核心校验
- ✅ 新增 `policy.ParseCommonFlags`,统一 `--dry-run/--confirm`
- ✅ CPA 移除重复 guard不再分散解析
- ✅ CF/Mail 切到 Runner + Gate + Runbook 模式
- ⏳ 待补:更细粒度 permission/gate 模板化(跨模块统一声明)
## Phase 6兼容层收缩与下线准备
- ✅ legacy 路由包装审计:
- `/api/records`
- `/delete/:id`
- `/export`
- ✅ 访问 legacy 自动写审计:`legacy.route.access`
- ✅ legacy deprecated 响应头:
- `X-API-Deprecated: true`
- `X-API-Replacement`
- `Warning: 299 ...`
- ✅ 迁移观测接口:
- `GET /api/v1/admin/legacy/usage`
- `GET /api/v1/admin/legacy/trend?days=...`
- `GET /api/v1/admin/legacy/readiness?days=...&zero_days=...`
---
## 仍在进行 / 建议下一步
1) Policy 进一步模板化
-`NeedFlag/RequireConfirm/AllowDryRun` 配置抽成模块命令描述,减少模块内手写。
2) Channel Adapter 统一化
- TG/QQ/Feishu 进一步收敛到 `core/ports/channel.go` 统一适配层。
3) Legacy 软下线流程
-`readiness.ready=true` 连续多日后,先灰度关闭 legacy再完全移除路由映射。
4) 发布前整理
- 清理工作区改动并提交;执行 `make release-check`
---
## 关键验证
- 最近多轮 `go build ./cmd/main.go` 均通过(仅 gojieba C++ deprecation warning非阻塞
- 双服务并存策略维持不变:`xiaji-go``ops-assistant` 并行。