P0-1 (limits.go): Allow()方法改为全程使用写锁保护counters map读写,避免RLock写入时的data race P0-2 (ticket_workflow.go+ticket_handler.go): Assign/Resolve/Close操作先查询ticket存在性和状态,返回明确的CS_TICKET_4001/CS_TKT_4002/CS_TICKET_4092/CS_TICKET_4093错误码,handler根据错误前缀路由HTTP状态码 P1-1 (ticket_store.go): 移除GetStats中3处手动rows.Close(),只保留defer Close()
135 lines
4.9 KiB
Markdown
135 lines
4.9 KiB
Markdown
# 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 store(memory)。
|
||
4. 实现 intent service(规则匹配:quota/token/error/handoff/general)。
|
||
5. 实现 reply service(规则回复/fallback)。
|
||
6. 实现 handoff service(敏感词或低置信度转人工)。
|
||
7. 实现 audit store(memory)。
|
||
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 规则实现误标为生产完成;本计划交付的是“最小生产可运行原型”,不是最终版。
|