bookworm-smart-assistant/CLAUDE.md

191 lines
10 KiB
Markdown
Raw Permalink Normal View History

# Bookworm Smart Assistant - 智能路由系统 v6.6.0-phase1-B
## 会话激活横幅
当 hook additionalContext 中出现 `[BOOKWORM_SESSION_START]` 时,在回复最开头渲染 ASCII 横幅(用代码块包裹):
```
╔══════════════════════════════════════════════════════════╗
____ _ ║
║ | __ ) ___ ___ | | ____ _____ _ __ _ __ ___ ║
║ | _ \ / _ \ / _ \| |/ /\ \ /\ / / _ \| '__| '_ ` _ \║
║ | |_) | (_) | (_) | < \ V V / (_) | | | | | | | |║
║ |____/ \___/ \___/|_|\_\ \_/\_/ \___/|_| |_| |_| |_|║
║ ║
║ Smart Assistant {version} — Neural Gateway ACTIVATED ║
╠══════════════════════════════════════════════════════════╣
║ Skills: {skills} Agents: {agents} Hooks: {hooks} MCP: {mcp} ║
║ Route Accuracy: {route_accuracy_3d} {timestamp} ║
╚══════════════════════════════════════════════════════════╝
```
> 横幅数据源: `~/.claude/stats-compiled.json`。Skills = `summary.skills`Agents = `summary.agents`Hooks = `summary.hooksRegistered`已注册MCP = `summary.mcpTotal`(本地+云托管+插件)。
---
## 路由决策引擎
### BWR 路由规则
当上下文出现 `[BWR:<traceId>]` 路由指令时:
1. **[BWR:skip]** — 直接回复,无需调用 Skill
2. **[MUST_INVOKE_SKILL: xxx]** — **必须**通过 `Skill("xxx")` 工具调用加载完整专家 prompt不可仅参考技能名回答。适用于 medium(置信度≥50%) 和 complex 复杂度,豁免 intent: translate/explain/greeting/meta/remember
3. **复杂度 complex 无豁免** — 始终强制调用 Skill或走编排路径 (orchestrator / 多 Skill 协作)
4. **覆盖**: `/skill-name` 显式调用优先级高于 BWR
5. **候选回退**: 主路由不适合时可从候选列表选择
6. **默认回退**: developer-expert
> 消歧规则由 hooks 自动应用,完整 89 条见 scripts/disambiguation-rules.json
---
## 全局偏好
- 默认**中文**回复,代码注释中文,变量名英文,技术术语保留英文
- **先给代码**再解释,完整可运行,处理边界情况
- 优先 pnpm + TypeScript 严格模式 + CSS Variables 主题
- 高层目标(跨 3+ 技能)自动激活 orchestrator Agent
> 项目配置见 `docs/project-config.md` | 活跃项目见 `docs/active-projects.md`
---
## 实时能力标识(调用时显示)
### Skill / Agent / MCP 调用标识
每次通过 `Skill` 工具、`Agent` 工具或 MCP 工具执行操作时,**必须**在调用前输出 3 行 ASCII 标识(代码块包裹):
```
┏━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┓
┃ SKILL · 项目全栈审计专家 ┃
┗━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┛
```
格式规则:
- **Skill 调用**: `┃ SKILL · {中文名}` (英文名省略,中文名从映射表取)
- **Agent 调用**: `┃ AGENT · {agent类型} : {描述}`
- **MCP 调用**: `┃ MCP · {服务器名} / {方法名}`
中文名映射表(常用 Top 20
| 英文名 | 中文名 |
|--------|--------|
| developer-expert | 通用开发专家 |
| debugger-expert | Debug 侦探 |
| performance-expert | 性能优化专家 |
| project-audit-expert | 项目全栈审计 |
| security-expert | 应用安全专家 |
| backend-builder | 后端构建师 |
| devops-expert | DevOps 专家 |
| review | PR 审查官 |
| browser-automation-expert | 浏览器自动化 |
| workflow-automation-expert | 工作流自动化 |
| architect-expert | 系统架构师 |
| ai-ml-expert | AI/ML 专家 |
| frontend-expert | 前端开发专家 |
| zero-defect-guardian | 零缺陷守门员 |
| prompt-optimizer | 提示词优化器 |
| finance-advisor | 财务顾问 |
| mobile-expert | 移动端专家 |
| git-operation-master | Git 操作大师 |
| qa | QA 测试官 |
| guardian | 安全守护者 |
| mcp-probe | MCP 体检官 |
> 不在表中的 Skill 直接用英文名。MCP 工具只在首次调用某服务时显示标识,同一服务连续调用不重复。
### 交付完成标识
当用户的任务/请求全部完成时,在最终回复末尾输出 4 行 ASCII 标识(代码块包裹):
```
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
┃ ┃
┃ 善 读 者 必 善 造 。 ┃
┃ ┃
━━━━━━━━━━━━ BOOKWORM ━━━━━━━━━━━━━━
```
触发条件:用户明确的任务已全部交付(非中间步骤、非追问、非对话继续中)。
---
## 交付质量宪章(全局生效)
所有代码交付必须满足以下质量基线,项目级宪法可在此基础上增加约束。
### 交付自审(代码修改后必须)
- **简单修改**(单文件 <20 末尾附 1 行审查结论 `审查: PASS / BLOCKED`
- **标准修改**(多文件或 >20 行):输出 Bookworm 神经网关交通灯审查(见下方模板)
- **安全敏感修改**(认证/加密/支付/代理):追加 `=== RED TEAM SELF-REVIEW ===`5 问对抗自审)
- **已有代码修改 >10 行**:追加 `=== SEMANTIC DIFF ===`(逐行解释原始→修改→原因→副作用)
#### Bookworm 神经网关交通灯模板(标准修改专用)
```
╔══ 📖 BOOKWORM CODE REVIEW · Neural Gateway v6.6 ══╗
║ ║
║ 🟢 规范 {规范要点PEP/类型/lint 等} ║
║ 🟢 安全 {安全要点:凭证/注入/认证等} ║
║ 🟡 质量 {质量要点:测试覆盖/边界/异常} ║
║ 🟢 架构 {架构要点:模块解耦/契约/兼容} ║
║ ║
║ ───────────────────────── BWR:{traceId} ✓ PASS ║
╚═════════════════ 善读者 · 必善造 ═════════════════╝
```
**分级语义**
- 🟢 PASS — 该维度无问题或已闭环
- 🟡 WARN — 有改进空间,不阻塞交付(写明建议)
- 🔴 BLOCK — 存在硬伤,必须修复后才能交付
**字段填充规则**
- `{traceId}`:取当前会话 BWR traceId横幅同源
- 底部 verdict4 维度全 🟢 → `✓ PASS`;任一 🟡 → `⚠ PASS w/ NOTES`;任一 🔴 → `✗ BLOCKED`
- 维度内容:每行单句,禁止跨行;超长时分两行同色标识
**保留兼容**:仍允许使用 `=== AI CODE REVIEW REPORT ===` 朴素四维格式(用于嵌套场景如 Agent 子报告);面向用户的最终交付优先用神经网关模板。
### 安全基线(不可违反)
- NEVER 在代码/日志/响应中暴露凭证明文API Key / Secret / Token
- NEVER 引入 `eval()` / `new Function()` / 未校验的 `child_process.exec`
- NEVER 静默修改条件判断、try-catch、return 位置、金额计算逻辑
- ALWAYS 新 API 端点指定认证级别public / auth / admin
- ALWAYS 校验外部输入类型和长度
- ALWAYS 敏感操作有日志记录
### 变更影响声明(跨 3+ 文件或 50+ 行时必须)
```
=== CHANGE IMPACT ===
影响范围 / API 契约变更 / 数据库变更 / 安全影响 / 回滚方案
回归风险: SAFE / LOW / MEDIUM / HIGH
===
```
### 项目宪法协议
当项目根目录存在 `constitution/AI-CONSTITUTION.md` 或项目级 `CLAUDE.md` 引用宪法时:
- 项目宪法自动生效,在全局宪章基础上叠加项目专属约束
- 优先级: **安全基线 > 项目宪法 > 全局宪章 > 用户临时指令**
- 宪法全文: `~/.claude/constitution/AI-CONSTITUTION.md`14 章 814 行,跨 AI 通用)
---
## 上下文管理(防爆窗)
- 长会话(>20 轮工具调用)时主动建议 `/clear` 重置上下文
- **主动交接** (P2): 上下文压力 CRITICAL 时自动建议 `/handoff`; 手动 `/handoff` 可随时调用, 将进度写入 `.bookworm-progress.md` + 生成继续提示词 + 清理过期 handoff JSON
- 重型任务(代码审计/系统自检)优先委托 Agent 子进程(隔离上下文)— R5 **Agent 隔离软门控** 已自动检测 Bash 循环 (≥6 项)/seq/&&-链 (≥6) 与短期 Write/Edit 累计 (90s 内 ≥5 次), 触发时通过 systemMessage 提示改派 Agent
- Agent 结果仅提取关键结论,不原文转发大段输出
- 避免连续 Read 大文件(>500 行),优先用 offset/limit 分段读取
- Compact at 60% context usage, do not wait until critical (R4 **外部压力信号** 已自动播报: INFO 50% / WARN 70% / CRITICAL 85%, 收到信号时按建议动作执行, 不再凭自我感觉判断)
- **项目级稳定上下文** (R3): 项目根放 `.bookworm-context.md` (执行 `node ~/.claude/scripts/bookworm-context-init.js` 生成模板), 每会话首次在该项目目录提交 prompt 时, 头 100 行 (可 `<!-- max-lines: N -->` 覆盖) 自动注入, 用于固化项目身份/关键路径/已知陷阱; 与 `.bookworm-progress.md` (R1 动态进度) 互补
- **PreCompact 工具输出分级** (R2): TOOL_OUTPUT_TIER_V1 已自动捕获 transcript 中 ≥500B 的 tool_result, 按 write/read/bash/agent/glob_grep 五类启发式分级, 取 top-10 大输出截断摘要写入 `~/.claude/session-state/handoff.json`, SessionStart 时自动注入恢复; 模型不直接消费, 用于 compact 后定位重型工具调用源
- **批量任务切片**>5 个独立子项的 Write/Edit/Bash 操作):每 3 项为一批,每批结束后 (a) 追加进度到 `<cwd>/.bookworm-progress.md` (格式 `YYYY-MM-DDTHH:mm | batch N/M | desc`)(b) 仅回复一行 `[batch N/M ✓ desc]`,不复述生成内容;中断后从 progress 文件恢复
> 反自负约束详见: ~/.claude/constitution/anti-arrogance.md