Files
ai-proj-helper/hooks/README.md
John Qiu 23ea8fdca5 feat: 融合 devflow-claude P0 批机制 (REQ-20260416-0017)
P0-1: SessionStart Hook — hooks/session-context.sh
  从分支名解析 REQ-ID,调 MCP API 查询需求详情注入 system-reminder

P0-2: PreToolUse Hook — hooks/pre-tool-confirm.sh
  拦截生产推送、force push、docker prod 容器操作、git reset --hard 等

P0-3: Release Draft 闸门设计文档 — docs/design/release-draft-gate.md
  完整架构 + 渐进式落地路径(拆 7 个子任务延后)
  附最小可用脚本 hooks/release-draft.sh 创建 Gitea draft release

P0-4: Memory 隔离规则 — 写入 req-prd / req-design / req-workflow
  禁止 auto-memory 污染模板产出物(章节结构、字段定义、文档结构)

P0-5: CLAUDE.md 架构检查 + 架构片段库
  dev-coding skill 执行前检查架构关键词
  新增 templates/claude-md-snippets/ 含 Go+Gin / React+AntD / Vue+Element /
  MCP+TS / generic 五套骨架

P0-6: /commit 分支保护自动化 — 新 skill dev-commit-plugin
  保护分支自动建功能分支 + Conventional Commits + REQ-XXX 自动关联

安装:
  bash hooks/install.sh

后续:
  P0-3 完整实现拆 7 个子任务(P0-3.1 ~ P0-3.7)
  建议先部署 hooks 跑 1-2 周观察,再推进 Release 机制落地
2026-04-16 21:02:29 +09:30

2.4 KiB
Raw Blame History

Claude Code Hooks

本目录包含 ai-proj-helper 体系的 Claude Code 钩子脚本。

REQ-20260416-0017 P0 批 — 源自 devflow-claude 借鉴

脚本清单

脚本 事件 作用
session-context.sh SessionStart 从分支名解析 REQ-ID注入需求上下文到会话
pre-tool-confirm.sh PreToolUse (Bash) 拦截生产发布、force push、docker 生产容器、reset --hard 等危险操作

安装(用户级,一次即可)

方式 1编辑 ~/.claude/settings.json

{
  "hooks": {
    "SessionStart": [
      {
        "hooks": [
          {
            "type": "command",
            "command": "/Users/donglinlai/coding/qiudl/ai-proj-helper/hooks/session-context.sh",
            "timeout": 10
          }
        ]
      }
    ],
    "PreToolUse": [
      {
        "matcher": "Bash",
        "hooks": [
          {
            "type": "command",
            "command": "/Users/donglinlai/coding/qiudl/ai-proj-helper/hooks/pre-tool-confirm.sh",
            "timeout": 30
          }
        ]
      }
    ]
  }
}

方式 2一键安装脚本

bash /Users/donglinlai/coding/qiudl/ai-proj-helper/hooks/install.sh

验证

SessionStart hook

  1. 切到一个带 REQ-ID 的分支:git checkout feat/REQ-20260416-0017-xxx
  2. 打开新的 Claude Code 会话
  3. 会话开头应看到 # 需求上下文SessionStart Hook

PreToolUse hook

让 AI 尝试执行这些命令中的任一条,应弹出原生确认对话框:

  • git push origin main
  • git push --force
  • tea pr merge --base main
  • docker rm ai_postgres_prod
  • git reset --hard

依赖

  • bash (macOS / Linux 默认)
  • jq (PreToolUse hook 需要,brew install jq)
  • python3 (SessionStart hook 解析 JSON)
  • curl (SessionStart hook 调 MCP API)

自定义

修改 MCP API 地址

在项目根目录创建 .ai-proj-env

export AI_PROJ_API_BASE="https://api.ai-proj.example.com"
export AI_PROJ_MCP_KEY="your-mcp-api-key"

或设置全局环境变量。

拦截更多命令

编辑 pre-tool-confirm.sh,在 REASON 赋值的 elif 链中增加规则。

设计原则

  1. 快速失败退出:不处理的命令立即 exit 0,不影响性能
  2. 非侵入性:网络/依赖缺失时静默退出,不阻塞正常工作流
  3. 可复现hook 脚本跟随仓库分发,方便团队一致部署