create-hook
// Create a hook (.json) to enforce policy or automate agent lifecycle events.
$ git log --oneline --stat
stars:186 154
forks:35k
updated:June 11, 2026
SKILL.mdreadonly
SKILL.md Frontmatter
namecreate-hook
descriptionCreate a hook (.json) to enforce policy or automate agent lifecycle events.
argument-hintWhat should be enforced or automated?
disable-model-invocationtrue
Related skill: agent-customization. Load and follow hooks.md for template and principles.
Guide the user to create a hook in .github/hooks/.
Extract from Conversation
First, review the conversation history. If the user has been expressing concerns about agent behavior (e.g., "don't run this command", "always check before doing X", "inject this context"), generalize that into a hook. Extract:
- Actions that should be blocked or gated
- Context that should be injected at certain points
- Automation needs at session start/end or tool use
Clarify if Needed
If no clear policy need emerges from the conversation, clarify:
- What event should trigger this hook? (e.g. PreToolUse, SessionStart, Stop)
- Should it block, warn, or inject context?
- Does it need a companion script?
Path Conventions
- Hook commands and companion scripts run with
cwddefaulting to the workspace root (when a workspace folder is available); otherwisecwdfalls back to the user home directory. Relative paths resolve fromcwd. Absolute paths are fine when intentional — just be deliberate about which you use. - Do not use environment variables for pathing. The only exception is plugin-provided environment variables in hooks shipped as part of an agent plugin; never use environment variables for pathing outside of a plugin context.
Iterate
- Draft the hook JSON (and any scripts) and save them.
- Identify the most ambiguous or weak parts and ask about those.
- Once finalized, summarize what the hook enforces, suggest ways to test it, and propose related customizations to create next.
Remember to follow the agent-customization guidelines to create highly effective hooks.