Files
ai-customer-service/IMPLEMENTATION_PLAN.md

135 lines
4.9 KiB
Markdown
Raw Normal View History

# AI-Customer-Service 实施计划
> 状态说明:本文件原先采用 `MVP-proto` 口径,已不再作为生产上线判断依据。生产执行以 `PRODUCTION_EXECUTION_PLAN.md` 为准。
> 历史说明:以下内容保留为原型阶段记录,不代表当前生产目标已达成。
## 1. 选择该项目的理由
AI-Customer-Service 是当前三个项目里最适合优先实施的对象:
- 文档结构最完整,且章节一致性最好。
- 业务主链路最短Webhook 接入 → Session → Intent → Reply/Handoff → Audit。
- 风险可控,适合作为从文档到实现的第一条样板链路。
- 相比 AI-Ops 和 Supply-Intelligence外部依赖与状态机复杂度更低更容易做最小闭环验证。
## 2. 实施目标
第一阶段只交付“最小生产可运行版本”,包含:
1. 独立运行模式 HTTP 服务。
2. 健康检查端点:`/actuator/health``/actuator/health/live``/actuator/health/ready`
3. Webhook 接口:最小文本消息接入。
4. Session 管理:内存版会话存储。
5. Intent 识别:规则版最小实现(不用真实 LLM
6. Reply 生成:规则版 FAQ / fallback 回复。
7. Handoff敏感意图或低置信度转人工。
8. Audit内存版审计日志记录。
9. OpenAPI 占位文档。
10. 最小测试:主路径 + 失败路径。
非目标:
- 不在第一阶段实现 PostgreSQL / Redis / 向量数据库。
- 不在第一阶段实现真正 RAG 检索。
- 不在第一阶段实现多渠道适配,只做单 webhook 文本入口。
- 不在第一阶段实现完整 RBAC 后台。
## 3. 推荐工程结构
```text
ai-customer-service/
go.mod
cmd/ai-customer-service/main.go
internal/app/app.go
internal/http/router.go
internal/http/handlers/health_handler.go
internal/http/handlers/webhook_handler.go
internal/domain/message/message.go
internal/domain/session/session.go
internal/domain/intent/intent.go
internal/domain/audit/audit.go
internal/service/dialog/service.go
internal/service/intent/service.go
internal/service/reply/service.go
internal/service/handoff/service.go
internal/store/memory/session_store.go
internal/store/memory/audit_store.go
internal/store/memory/knowledge_store.go
internal/openapi/openapi.json
test/e2e/webhook_e2e_test.go
test/integration/dialog_service_test.go
Makefile
Dockerfile
```
## 4. 分阶段任务清单
### Phase 1工程初始化
1. 创建 Go module。
2. 建立 `cmd/` + `internal/` 目录结构。
3. 创建最小 `main.go`,支持 HTTP 启动。
4. 增加 health handler。
5. 增加基础 router。
6. 写启动 smoke test。
### Phase 2主链路实现
1. 定义 `UnifiedMessage``Session``IntentResult``AuditEvent`
2. 实现 webhook handler接收最小 JSON 文本消息。
3. 实现 session storememory
4. 实现 intent service规则匹配quota/token/error/handoff/general
5. 实现 reply service规则回复/fallback
6. 实现 handoff service敏感词或低置信度转人工
7. 实现 audit storememory
8. 打通主链路receive → parse → intent → reply/handoff → audit。
### Phase 3测试与门禁
1. 单元测试intent service。
2. 单元测试handoff service。
3. 集成测试dialog service。
4. E2E 测试webhook 主路径。
5. E2E 测试:敏感词转人工失败路径。
6. 验证 health/readiness 端点。
7. 生成最小 OpenAPI 占位文档。
### Phase 4运行工件
1. 编写 Dockerfile。
2. 编写最小 Makefile。
3. 本地运行验证:`go test ./...`
4. 本地运行验证:启动服务并 curl health/webhook。
## 5. 阶段门禁
### Gate A进入实现前
- [x] PRD / HLD / TEST_DESIGN / INTERFACE 已存在。
- [x] 文档中门禁、威胁建模、阻断条件已补齐。
- [x] 工程目录已创建。
### Gate B主链路完成
- [x] 独立运行服务可启动。
- [x] Webhook 能接收消息并返回应答。
- [x] 敏感意图能够转人工。
- [x] 审计事件会记录。
### Gate C可交付最小版本
- [x] `go test ./...` 全通过。
- [x] health/live/ready 通过。
- [x] 至少 1 条主路径 + 1 条失败路径 + 1 条转人工路径验证通过。
- [x] Dockerfile 可构建。
## 6. 验证命令
```bash
go test ./...
go test ./test/e2e -v
curl -i http://127.0.0.1:8080/actuator/health/live
curl -i http://127.0.0.1:8080/actuator/health/ready
curl -i -X POST http://127.0.0.1:8080/api/v1/customer-service/webhook \
-H 'Content-Type: application/json' \
-d '{"message_id":"m1","channel":"widget","open_id":"u1","content":"查询额度"}'
```
## 7. 风险与控制
1. 当前没有真实 LLM/RAG先用规则实现防止卡死在外部依赖。
2. 先做内存存储,防止过早引入数据库和 Redis 增加噪声。
3. 先独立运行,不先做集成模式,等主链路稳定后再补 IntegrationPlugin。
4. 严禁把 demo 规则实现误标为生产完成;本计划交付的是“最小生产可运行原型”,不是最终版。