Back to Skills

Hook Register

epieczko
Updated 2 days ago
38 views
0
View on GitHub
Othergeneral

About

The Hook Register skill validates and registers YAML hook manifest files into a versioned Hook Registry for centralized management. It enables formal hook governance with version control, code review processes, and schema validation, unlike dynamic hook creation. Use this when you need structured, version-controlled hooks that undergo review before activation.

Documentation

hook.register Skill

Validates and registers hook manifest files, adding them to the Hook Registry for automatic enforcement.

Purpose

While hook.define creates hooks on-the-fly and updates the live configuration (.claude/hooks.yaml), the hook.register skill formalizes this by validating a hook manifest and adding it to a versioned registry (/registry/hooks.json). This enables:

  • Version Control: Track hooks as code with full history
  • Review Process: Hook manifests can go through code review before activation
  • Centralized Management: Single source of truth for all hooks in the organization
  • Formal Schema: Ensures hooks conform to required structure

This skill is part of Betty's Layer 5 (Hooks/Policy) infrastructure, enabling automated governance and validation.

Difference from hook.define

Featurehook.definehook.register
PurposeCreate hooks immediatelyRegister hook manifests for version control
Output File.claude/hooks.yaml (live config)/registry/hooks.json (registry)
Use CaseQuick development, testingProduction deployment, formal tracking
VersioningNot trackedFull version history
Schema ValidationBasicComprehensive

Usage

python skills/hook.register/hook_register.py <path_to_hook_manifest.yaml>

Arguments

ArgumentTypeRequiredDescription
manifest_pathstringYesPath to the hook manifest YAML file to validate

Hook Manifest Schema

Required Fields

  • name: Unique hook identifier (kebab-case recommended, e.g., validate-openapi-specs)
  • version: Semantic version (e.g., 0.1.0)
  • description: Human-readable description of what the hook does
  • event: Hook trigger event (see Valid Events table below)
  • command: Command to execute when hook triggers

Optional Fields

  • when: Conditional execution
    • pattern: File pattern to match (e.g., "*.openapi.yaml", "specs/**/*.yaml")
  • blocking: Whether hook should block operation if it fails (default: false)
  • timeout: Timeout in milliseconds (default: 30000)
  • on_failure: What to do on failure: show_errors, silent, log_only (default: show_errors)
  • status: Hook status (draft or active, defaults to draft)
  • tags: Array of tags for categorization (e.g., ["api", "validation", "compliance"])

Valid Events

EventTriggers WhenCommon Use Cases
on_file_editFile is edited in editorReal-time syntax validation
on_file_saveFile is saved to diskCode generation, formatting
on_commitGit commit attemptedBreaking change detection, linting
on_pushGit push attemptedFull validation suite, security scans
on_tool_useAny tool is usedAudit logging, usage tracking
on_agent_startAgent begins executionContext injection, authorization
on_workflow_endWorkflow completesCleanup, notifications, reporting

Validation Rules

The skill performs comprehensive validation:

  1. Required Fields – Ensures name, version, description, event, and command are present
  2. Name Format – Validates hook name is non-empty and follows naming conventions
  3. Version Format – Ensures version follows semantic versioning (e.g., 0.1.0)
  4. Event Type – Verifies event is one of the supported triggers
  5. Command Validation – Ensures command is non-empty
  6. Type Checking – Validates blocking is boolean, timeout is positive number
  7. Pattern Validation – If when.pattern is provided, ensures it's a valid string
  8. Name Uniqueness – Checks that hook name doesn't conflict with existing hooks in registry

Outputs

Success Response

{
  "ok": true,
  "status": "registered",
  "errors": [],
  "path": "hooks/validate-openapi.yaml",
  "details": {
    "valid": true,
    "status": "registered",
    "registry_updated": true,
    "manifest": {
      "name": "validate-openapi-specs",
      "version": "0.1.0",
      "description": "Validate OpenAPI specs against Zalando guidelines",
      "event": "on_file_edit",
      "command": "python skills/api.validate/api_validate.py {file_path} zalando",
      "when": {
        "pattern": "*.openapi.yaml"
      },
      "blocking": true,
      "timeout": 10000,
      "status": "active",
      "tags": ["api", "validation", "openapi"]
    }
  }
}

Failure Response

{
  "ok": false,
  "status": "failed",
  "errors": [
    "Invalid event: 'on_file_change'. Must be one of: on_file_edit, on_file_save, on_commit, on_push, on_tool_use, on_agent_start, on_workflow_end"
  ],
  "path": "hooks/invalid-hook.yaml",
  "details": {
    "valid": false,
    "errors": [
      "Invalid event: 'on_file_change'. Must be one of: on_file_edit, on_file_save, on_commit, on_push, on_tool_use, on_agent_start, on_workflow_end"
    ],
    "path": "hooks/invalid-hook.yaml"
  }
}

Examples

Example 1: Register OpenAPI Validation Hook

Hook Manifest (hooks/validate-openapi.yaml):

name: validate-openapi-specs
version: 0.1.0
description: "Validate OpenAPI specs against Zalando guidelines on every edit"

event: on_file_edit
command: "python skills/api.validate/api_validate.py {file_path} zalando"

when:
  pattern: "*.openapi.yaml"

blocking: true
timeout: 10000

status: active
tags: [api, validation, openapi, zalando]

Registration Command:

$ python skills/hook.register/hook_register.py hooks/validate-openapi.yaml
{
  "ok": true,
  "status": "registered",
  "errors": [],
  "path": "hooks/validate-openapi.yaml",
  "details": {
    "valid": true,
    "status": "registered",
    "registry_updated": true
  }
}

Example 2: Register Breaking Change Detection Hook

Hook Manifest (hooks/prevent-breaking-changes.yaml):

name: prevent-breaking-changes
version: 0.1.0
description: "Block commits that introduce breaking API changes"

event: on_commit
command: "python skills/api.compatibility/check_compatibility.py {file_path} --fail_on_breaking"

when:
  pattern: "specs/**/*.yaml"

blocking: true
timeout: 30000

on_failure: show_errors

status: active
tags: [api, compatibility, breaking-changes, commit-hook]

Example 3: Register Audit Log Hook

Hook Manifest (hooks/audit-tool-usage.yaml):

name: audit-tool-usage
version: 0.1.0
description: "Log all tool usage for compliance audit trail"

event: on_tool_use
command: "python skills/audit.log/log_tool_usage.py {tool_name} {timestamp}"

blocking: false
timeout: 5000

on_failure: log_only

status: active
tags: [audit, compliance, logging]

Integration

With Workflows

Hooks can be registered as part of a workflow:

# workflows/setup_governance.yaml
steps:
  - skill: hook.register
    args:
      - "hooks/validate-openapi.yaml"
    required: true

  - skill: hook.register
    args:
      - "hooks/prevent-breaking-changes.yaml"
    required: true

With CI/CD

Validate hooks in continuous integration:

# .github/workflows/validate-hooks.yml
name: Validate Hooks
on: [push, pull_request]
jobs:
  validate:
    runs-on: ubuntu-latest
    steps:
      - uses: actions/checkout@v3
      - name: Validate all hooks
        run: |
          for hook in hooks/*.yaml; do
            python skills/hook.register/hook_register.py "$hook" || exit 1
          done

Loading Hooks at Runtime

Once registered, hooks can be loaded from the registry:

import json

with open('/registry/hooks.json') as f:
    registry = json.load(f)

active_hooks = [h for h in registry['hooks'] if h['status'] == 'active']

Common Errors

ErrorCauseSolution
"Missing required fields: name"Hook manifest missing required fieldAdd all required fields: name, version, description, event, command
"Invalid event: 'X'"Event type not recognizedUse one of the valid events: on_file_edit, on_file_save, on_commit, on_push, on_tool_use, on_agent_start, on_workflow_end
"command cannot be empty"Command field is empty or whitespaceProvide a valid command string
"blocking must be a boolean"blocking field is not true/falseUse boolean value: true or false (not string)
"timeout must be a positive number"timeout is zero or negativeProvide positive number in milliseconds (e.g., 30000)
"when.pattern must be a non-empty string"Pattern is empty or wrong typeProvide valid glob pattern (e.g., "*.yaml")

Files Modified

  • Registry: /registry/hooks.json – Updated with new or modified hook entry
  • Logs: Hook validation and registration logged to Betty's logging system

Hook Registry Structure

The /registry/hooks.json file has this structure:

{
  "registry_version": "1.0.0",
  "generated_at": "2025-10-23T12:00:00Z",
  "hooks": [
    {
      "name": "validate-openapi-specs",
      "version": "0.1.0",
      "description": "Validate OpenAPI specs against Zalando guidelines",
      "event": "on_file_edit",
      "command": "python skills/api.validate/api_validate.py {file_path} zalando",
      "when": {
        "pattern": "*.openapi.yaml"
      },
      "blocking": true,
      "timeout": 10000,
      "on_failure": "show_errors",
      "status": "active",
      "tags": ["api", "validation", "openapi"]
    }
  ]
}

See Also

Exit Codes

  • 0: Success (manifest valid and registered)
  • 1: Failure (validation errors or registry update failed)

Best Practices

  1. Version Control: Keep hook manifests in your repository (hooks/ directory)
  2. Review Process: Require code review for hook changes (they can block operations)
  3. Start with Draft: Register new hooks with status: draft, test them, then promote to active
  4. Descriptive Names: Use clear, kebab-case names that describe the hook's purpose
  5. Appropriate Blocking: Only set blocking: true for critical validations (it will stop operations)
  6. Reasonable Timeouts: Set realistic timeouts based on hook complexity (avoid too short or too long)
  7. Tag Appropriately: Use tags for easy filtering and organization
  8. Test Patterns: Test file patterns thoroughly to avoid unintended matches

Status

Active – This skill is production-ready and actively used in Betty's hook infrastructure.

Version History

  • 0.1.0 (Oct 2025) – Initial implementation with full validation and registry management

Quick Install

/plugin add https://github.com/epieczko/betty/tree/main/hook.register

Copy and paste this command in Claude Code to install this skill

GitHub 仓库

epieczko/betty
Path: skills/hook.register

Related Skills

subagent-driven-development

Development

This skill executes implementation plans by dispatching a fresh subagent for each independent task, with code review between tasks. It enables fast iteration while maintaining quality gates through this review process. Use it when working on mostly independent tasks within the same session to ensure continuous progress with built-in quality checks.

View skill

algorithmic-art

Meta

This Claude Skill creates original algorithmic art using p5.js with seeded randomness and interactive parameters. It generates .md files for algorithmic philosophies, plus .html and .js files for interactive generative art implementations. Use it when developers need to create flow fields, particle systems, or other computational art while avoiding copyright issues.

View skill

executing-plans

Design

Use the executing-plans skill when you have a complete implementation plan to execute in controlled batches with review checkpoints. It loads and critically reviews the plan, then executes tasks in small batches (default 3 tasks) while reporting progress between each batch for architect review. This ensures systematic implementation with built-in quality control checkpoints.

View skill

cost-optimization

Other

This Claude Skill helps developers optimize cloud costs through resource rightsizing, tagging strategies, and spending analysis. It provides a framework for reducing cloud expenses and implementing cost governance across AWS, Azure, and GCP. Use it when you need to analyze infrastructure costs, right-size resources, or meet budget constraints.

View skill