<< All versions
Skill v1.0.0
currentAutomated scan100/100vibeeval/vibecosystem/hooks
──Details
PublishedApril 29, 2026 at 10:21 PM
Content Hashsha256:80d3a601561c9821...
Git SHA6172d4ac24fc
──Files
Files (1 file, 1.4 KB)
SKILL.md1.4 KBactive
SKILL.md · 74 lines · 1.4 KB
version: "1.0.0"
name: hooks description: Hook Development Rules user-invocable: false
Hook Development Rules
When working with files in .claude/hooks/:
Pattern
Shell wrapper (.sh) → TypeScript (.ts) via npx tsx
Shell Wrapper Template
bash
#!/bin/bashset -ecd "$CLAUDE_PROJECT_DIR/.claude/hooks"cat | npx tsx <handler>.ts
TypeScript Handler Pattern
typescript
interface HookInput {// Event-specific fields}async function main() {const input: HookInput = JSON.parse(await readStdin());// Process inputconst output = {result: 'continue', // or 'block'message: 'Optional system reminder'};console.log(JSON.stringify(output));}
Hook Events
- PreToolUse - Before tool execution (can block)
- PostToolUse - After tool execution
- UserPromptSubmit - Before processing user prompt
- PreCompact - Before context compaction
- SessionStart - On session start/resume/compact
- Stop - When agent finishes
Testing
Test hooks manually:
bash
echo '{"type": "resume"}' | .claude/hooks/session-start-continuity.sh
Registration
Add hooks to .claude/settings.json:
json
{"hooks": {"EventName": [{"matcher": ["pattern"], // Optional"hooks": [{"type": "command","command": "$CLAUDE_PROJECT_DIR/.claude/hooks/hook.sh"}]}]}}