3.1 KiB
3.1 KiB
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 1:API 基础收口
- ✅ 新增/改造接口统一
{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 3:Dashboard 聚合后端
- ✅
GET /api/v1/dashboard/overview - ✅
GET /api/v1/dashboard/summary - ✅ jobs 列表多维筛选(见 Phase 4)
Phase 4:Ops 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: trueX-API-ReplacementWarning: 299 ...
- ✅ 迁移观测接口:
GET /api/v1/admin/legacy/usageGET /api/v1/admin/legacy/trend?days=...GET /api/v1/admin/legacy/readiness?days=...&zero_days=...
仍在进行 / 建议下一步
- Policy 进一步模板化
- 将
NeedFlag/RequireConfirm/AllowDryRun配置抽成模块命令描述,减少模块内手写。
- Channel Adapter 统一化
- TG/QQ/Feishu 进一步收敛到
core/ports/channel.go统一适配层。
- Legacy 软下线流程
- 当
readiness.ready=true连续多日后,先灰度关闭 legacy,再完全移除路由映射。
- 发布前整理
- 清理工作区改动并提交;执行
make release-check。
关键验证
- 最近多轮
go build ./cmd/main.go均通过(仅 gojieba C++ deprecation warning,非阻塞)。 - 双服务并存策略维持不变:
xiaji-go与ops-assistant并行。