Agent skill
hook-templates
Comprehensive Claude Code hook patterns for automation, state management, and external integration. Use when implementing hooks for validation, workflow gates, MCP integration, or state machines.
Install this agent skill to your Project
npx add-skill https://github.com/chkim-su/forge-editor/tree/main/skills/hook-templates
SKILL.md
Hook Patterns
Production-tested patterns for Claude Code hooks (1.0.40+).
Hook Roles (Beyond Just Validation)
| Role | Hook Event | Example |
|---|---|---|
| Gate | PreToolUse | Block dangerous commands, require prerequisites |
| Side Effect | PostToolUse | Auto-format, auto-commit, lint |
| State Manager | PostToolUse | Create/delete state files, track workflow phase |
| External Integrator | Any | MCP calls, HTTP APIs, WebSocket |
| Context Injector | SessionStart | Load project context, activate services |
Event Reference
| Event | Trigger | Can Block | Use For |
|---|---|---|---|
| SessionStart | Session begins | No | Context loading, service activation |
| UserPromptSubmit | User sends message | Yes | Prompt validation, skill suggestion |
| PreToolUse | Before tool | Yes | Validation, workflow gates |
| PostToolUse | After tool | No | State updates, side effects |
| Stop | Claude stops | Yes | Quality gates, cleanup |
| SubagentStop | Subagent stops | Yes | Subagent quality gates |
Exit Codes
| Code | PreToolUse/Stop | Others |
|---|---|---|
| 0 | Allow | Continue |
| 2 | Block (stderr→Claude) | Logged |
| 1, 3+ | Block | Logged |
JSON Response (Advanced)
{
"decision": "approve|block",
"reason": "Shown to user/Claude",
"continue": true,
"suppressOutput": false
}
Quick Registration
{
"hooks": {
"PreToolUse": [{
"matcher": "Edit|Write",
"hooks": [{ "type": "command", "command": "script.sh", "timeout": 5 }]
}]
}
}
Pattern Selection
| Need | Pattern | Reference |
|---|---|---|
| Force skill/agent activation | Orchestration | orchestration-templates.md |
| Block dangerous actions | Gate Pattern | gate-patterns.md |
| Auto-format/lint/commit | Side Effect Pattern | side-effect-patterns.md |
| Full working examples | Examples | full-examples.md |
Orchestration Patterns (NEW)
Hook-based skill/agent activation with reliability stats:
| Pattern | Success | Use Case |
|---|---|---|
| Forced Evaluation | 84% | Force Claude to evaluate and use skills |
| Agent Router | 100% | Route to plugin agents via Task tool |
| Context Injection | 100% | Load project context at session start |
See orchestration-templates.md for templates.
Debugging
Common issues and solutions in debugging-guide.md.
Quick checklist:
- Hook executable? (
chmod +x) - Using
INPUT=$(cat)to read stdin? - Using
exit 2for blocking (not exit 1)? - Debug to stderr (
>&2), output to stdout? - New session after settings.json change?
Common Mistakes
- Missing nested
hooksarray - Missing
"type": "command" - Using exit 1 instead of exit 2 for blocking
- Object matcher (not supported) - use script parsing instead
Recommended Agent Skills
Expand your agent's capabilities with these related and highly-rated skills.
forge-analyzer
Analyze vague user ideas and recommend architecture based on actual needs, not predefined categories. Front-end for clarifying ambiguous requests before routing to appropriate skillmaker tools.
hook-system
Claude Code Hook system entry point. Guides you to the right skill based on your needs.
mcp-gateway-patterns
MCP Gateway design patterns for Agent Gateway, Subprocess, and Daemon isolation. Use when designing MCP integrations.
workflow-state-patterns
Hook-based state machine patterns for multi-phase workflows. Use when designing sequential workflows with quality gates.
mcp-daemon-isolation
Context isolation for query-type MCP tools (LSP, search, database) via external CLI. Use when MCP query results consume too many context tokens.
critical-analysis-patterns
Philosophical/meta project analysis - critical analysis framework that asks "why?"
Didn't find tool you were looking for?