Skip to main content

Hook system and MCP tool server for Claude Code agents

Project description

agentihooks

Standalone License: MIT CI Python 3.11+ Docs

The production harness for Claude Code. Turn Claude Code into a managed fleet — with profile chaining, guardrails, context intelligence, and real-time broadcast messaging across every active session.

Full documentation: the-cloud-clockwork.github.io/agentihooks


The Four Pillars

graph LR
    A["Identity<br/>Who your agents are"] --> E["AgentiHooks"]
    B["Guardrails<br/>What keeps them safe"] --> E
    C["Context Intelligence<br/>What keeps them sharp"] --> E
    D["Fleet Command<br/>Talk to your entire fleet"] --> E

Pillar 1: Identity — Who your agents are

One command transforms your agent's entire personality, permissions, and toolset.

agentihooks init --profile coding,anton     # chain profiles
agentihooks settings-profile admin          # swap permissions without touching persona
  • Profile chaining — comma-separated profiles merge left-to-right (rules accumulate, settings deep-merge, CLAUDE.md concatenates)
  • Two-axis model — persona (rules/CLAUDE.md) and settings (permissions/MCP) are independent layers
  • Bundle system — external repos of profiles, auto-discovered via agentihooks bundle link
  • Built-in profiles: default (auto mode), coding (acceptEdits), admin (bypassPermissions)
  • Live rule refreshagentihooks refresh-rules pushes rule updates into every running Claude session without restart. One-shot per session, session-snapshotted so new sessions don't re-consume.

Full docs: Identity

Pillar 2: Guardrails — What keeps them safe

9+ guardrails active by default. Your fleet operates within boundaries you set.

Guardrail What it does
Secrets — two-tier Hard-block on Write/Edit/Bash-to-file containing secrets; inline Bash args scan + log + note only (operator-managed transcript)
Branch + PR guard Default-deny branch creation and gh pr create; unlocked per-turn (branch) or per-session (PR) by operator signal phrases
Prod lockdown Default-deny gh pr merge main, release.yml, :latest/:prod/:stable image tags; session-scoped unlock via release/hotfix signals
Controls toggle (bypass mode) Operator phrase disable controls flips a session-wide bypass that lifts branch/PR/release-merge/hotfix/non-main-force-push gates at once; subagents inherit; HARD FLOOR (push-to-main, commit-on-main, secrets-in-files) stays enforced; restored by enable controls or SessionEnd
Retry breaker Soft directive at N=5 (launch error-researcher agents) → hard block at N=10 on repeated identical failures
Dependency banner Visible banner on every pip/npm/cargo/uv/poetry/apt/brew install — supply chain audit surface
Version guard Blocks AI from editing version fields in manifests
CLAUDE.md sanity Prevents bloat past configurable line limit
MCP surface area Warns when too many tools are loaded
Bash output filter Truncates verbose output to save tokens
File read dedup Blocks redundant re-reads of unchanged files

Full docs: Guardrails

Pillar 3: Context Intelligence — What keeps them sharp

LLMs lose focus on early instructions as conversations grow. AgentiHooks defeats attention decay.

  • Context refresh — re-injects rules every 20 turns and CLAUDE.md every 40 turns
  • Priority frontmatter — critical rules load first within the 8000-char budget
  • Token compression — 4 levels (off/light/standard/aggressive) with safety-preserving protection mask
  • Tool memory — past errors injected so agents don't repeat mistakes
  • Brain adapter — pluggable source that pumps knowledge (hot arcs, operational memory) into agents via broadcast channels
  • Context audit — tracks what's being injected and how much budget is used
# In ~/.agentihooks/.env
CONTEXT_REFRESH_COMPRESSION=standard    # default
CONTEXT_COMPRESSION_SCOPE=all           # compress all injections

Full docs: Context Intelligence

Pillar 4: Fleet Command — Talk to your entire fleet

No other tool does this. Send messages to every active Claude Code session simultaneously — like a PA system for your AI workforce. Now with channels for targeted delivery — subscribe agents to topics, and only the right sessions hear the right messages.

# Manual — full control
agentihooks broadcast "Deploy freeze until 3am" -s alert -t 8h
agentihooks broadcast "STOP ALL WRITES" -s critical -t 15m

# AI-assisted — describe intent in plain English
agentihooks broadcast emit "production incident, all agents stop deploying"
agentihooks broadcast emit "clear all broadcasts"
Severity Delivery Default TTL Use case
info Once per session 4 hours Reminders, FYI notices
alert Every user turn 1 hour Deploy freezes, degraded services
critical Every turn + every tool call 30 min Incidents, immediate stops

emit is sandboxed: Claude Haiku can only run agentihooks broadcast commands — all other tools are disallowed.

Full docs: Fleet Command


Quick Start

Requirement: uv must be installed.

git clone https://github.com/The-Cloud-Clockwork/agentihooks
cd agentihooks

# 1. Create the dedicated venv and install everything
uv venv ~/.agentihooks/.venv
uv pip install --python ~/.agentihooks/.venv/bin/python -e ".[all]"

# 2. Install hooks + settings + MCP into ~/.claude
agentihooks init

agentihooks init wires hooks into ~/.claude/settings.json, symlinks skills/agents/commands/rules, merges MCP servers into ~/.claude.json, and installs the CLI globally. Re-run any time — it is idempotent.

A CLI that keeps up with your fleet

agentihooks sessions shows every running Claude Code session at a glance — session names from /rename, accurate lifetimes, and reopen by index for crash recovery.

agentihooks sessions listing 5 alive Claude Code sessions with NAME, AGE, CWD, and ID columns

Architecture

Claude Code
  |
  |-- Hook Events (stdin JSON) --> python -m hooks --> hook_manager.py
  |     SessionStart, PreToolUse,       |
  |     PostToolUse, Stop, ...         |-- context refresh + compression
  |     (10 events total)              |-- guardrails pipeline
  |                                    |-- broadcast delivery
  |                                    |-- transcript logging
  |
  |-- statusLine (native setting) --> python -m hooks.statusline
  |     pipes JSON on every turn       --> 2-3 line status bar
  |
  +-- MCP Tools --> python -m hooks.mcp --> category modules
        aws, email, storage,                  --> hooks/mcp/*
        database, compute, ...

CLI Reference

# Install / configure
agentihooks init                             # global install with default profile
agentihooks init --profile coding,anton       # chain profiles
agentihooks settings-profile admin           # quick-switch settings layer

# Fleet messaging
agentihooks broadcast "msg"                  # send info broadcast
agentihooks broadcast "msg" -s critical      # critical severity
agentihooks broadcast emit "natural lang"    # AI-assisted
agentihooks broadcast --list                 # active broadcasts
agentihooks broadcast --clear                # clear all

# Launch claude with --dangerously-skip-permissions
agentihooks claude                           # bypassPermissions + your extra args
agenti                                       # alias (after source ~/.bashrc)

# Bundle management
agentihooks bundle link ~/dev/my-tools       # link a bundle
agentihooks bundle pull                      # update linked bundle

# Link an external profile dir into the chain
agentihooks link-profile link ~/dev/brain-profile     # auto-appends to chain + re-installs
agentihooks link-profile link ~/dev/brain --name br   # disambiguate name on collision
agentihooks link-profile list                         # show all linked external profiles
agentihooks link-profile unlink brain-profile         # remove from chain + sweep symlinks

# Broadcast channels — subscriptions are env-driven via AGENTIHOOKS_BASE_CHANNELS
# (set in profile's settings.overrides.json env block; override per-repo via
# .claude/settings.local.json env, or per-container via launch ENV)
agentihooks channel publish brain "msg"      # publish to a channel
agentihooks channel list                     # active channels + message counts

# Brain adapter (knowledge injection)
agentihooks brain status                     # source type, entries, refresh state
agentihooks brain refresh                    # force re-read + republish

# Live rule refresh (push rule updates into running sessions)
agentihooks refresh-rules --dry-run          # preview payload + target session IDs
agentihooks refresh-rules                    # one-shot push to all alive sessions
agentihooks refresh-rules --clear            # cancel a pending marker

# Session registry (crash recovery + session picker)
agentihooks sessions                         # list recent sessions with NAME + AGE columns
agentihooks sessions reopen <IDX>            # reopen by index from the list
agentihooks sessions backfill                # seed registry from JSONL transcripts

# Diagnostics
agentihooks status                           # full system health
agentihooks lint-claude [path]               # CLAUDE.md token cost analysis
agentihooks mcp report                       # MCP surface area

# Utilities
agentihooks ignore [path]                    # create .claudeignore
agentihooks --list-profiles                  # available profiles
agentihooks --query                          # active profile name
agentihooks uninstall [--yes]                # remove everything

What init Does

  1. Links bundle (if --bundle provided)
  2. Merges settings: settings.base.json -> profile overrides -> settings-profile overlay -> OTEL config
  3. Symlinks skills, agents, commands, and rules (3-layer merge, additive across chain)
  4. Writes CLAUDE.md to ~/.claude/CLAUDE.md
  5. Installs MCP servers (hooks-utils + bundle + profile)
  6. Prunes orphaned MCP servers
  7. Installs CLI globally via uv tool
  8. Writes bashrc block (agentienv shell function + agenti alias)

Per-repo init (--repo / --local) and .agentihooks.json were removed 2026-05-07. agentihooks init is global-only.

Profiles

Profiles mirror the Claude Code project structure:

profiles/<name>/
|-- CLAUDE.md                    # system prompt (-> ~/.claude/CLAUDE.md)
+-- .claude/
    |-- settings.overrides.json  # merged into ~/.claude/settings.json
    |-- .mcp.json                # profile MCP servers
    |-- skills/                  # -> ~/.claude/skills/
    |-- agents/                  # -> ~/.claude/agents/
    |-- commands/                # -> ~/.claude/commands/
    +-- rules/                   # -> ~/.claude/rules/

Built-in profiles: default (auto), coding (acceptEdits), admin (bypassPermissions). Bundle profiles are discovered automatically.

3-layer merge: agentihooks built-in -> bundle global .claude/ -> profile-specific .claude/. Applies to skills, agents, commands, rules, and MCP servers.

Profile chaining: agentihooks init --profile coding,anton applies each profile sequentially — hooks append, CLAUDE.md concatenates, rules/skills accumulate additively.

Settings profiles (two-axis model): Control settings independently from persona:

agentihooks init --profile anton --settings-profile admin
agentihooks settings-profile admin           # quick-switch
agentihooks settings-profile --clear         # revert

Hook Events

10 lifecycle events, all handled by python -m hooks:

Event Key behavior
SessionStart Register session, inject context, brain injection, deliver broadcasts, MCP warnings
PreToolUse Secrets scan, branch/version guard, retry breaker, critical broadcasts
PostToolUse Bash output filtering, file dedup, tool error recording
UserPromptSubmit Secrets scan, brain refresh, context refresh, channel-filtered broadcast delivery
Stop Transcript scan, auto-memory, cost metrics
SessionEnd Deregister session, clear caches, log summary
SubagentStop Subagent transcript logging
Notification Log notifications
PreCompact Log before compaction
PermissionRequest Log permission requests

Configuration

All configuration in .env files in ~/.agentihooks/. Key variables:

Variable Default Description
CONTEXT_REFRESH_COMPRESSION standard Token compression level
CONTEXT_COMPRESSION_SCOPE refresh Scope: refresh or all
CONTEXT_REFRESH_INTERVAL 20 Re-inject rules every N turns
BROADCAST_ENABLED true Fleet messaging master switch
BROADCAST_CRITICAL_ON_PRETOOL false Re-inject critical broadcasts on every PreToolUse (default off — alerts still land on UserPromptSubmit)
BROADCAST_PRETOOL_MIN_SEVERITY critical Minimum severity for PreToolUse re-injection. alert widens it.
BROADCAST_MAX_BYTES_PRETOOL 0 PreToolUse banner byte cap. 0 = no cap. Set >0 to opt in to truncation under Claude Code's 10K hook output limit.
BROADCAST_MAX_BYTES_PROMPT 0 UserPromptSubmit banner byte cap. Same semantics.
AGENTIHOOKS_BASE_CHANNELS "" (empty) Comma-separated channel subscription floor for the session. Default ships in profiles/default/.claude/settings.overrides.json env block as "brain,amygdala". Layered: profile env → repo .claude/settings.json → repo .claude/settings.local.json → container ENV (highest). Wildcard * subscribes to everything.
CI_MANIFESTO_MAX_BYTES 0 CI manifesto inject byte cap. 0 = full doctrine ships through. Set >0 (e.g. 7500) to truncate with a "Read full file at <path>" footer.
TOKEN_CONTROL_ENABLED true Token control layer master switch
BASH_FILTER_ENABLED true Truncate verbose bash output
FILE_READ_CACHE_ENABLED true Block redundant file re-reads
BRAIN_ENABLED false Brain adapter master switch
BRAIN_URL "" Remote brain HTTP endpoint (kb-router). When set, hooks fetch /feed, /signal, post /marker instead of reading the filesystem.
BRAIN_HTTP_TOKEN "" Bearer token for BRAIN_URL. Falls back to KB_ROUTER_TOKEN.
BRAIN_SOURCE_PATH ~/.agentihooks/brain Filesystem fallback when BRAIN_URL unset.
BRAIN_CHANNEL brain Broadcast channel the brain adapter publishes to. Receivers must include this name in AGENTIHOOKS_BASE_CHANNELS.
BRAIN_REFRESH_INTERVAL 30 Re-read brain source every N turns
AMYGDALA_ENABLED false Active-signal injection (uses BRAIN_URL /signal).
BRAIN_WRITER_ENABLED false POST /marker on Stop / SubagentStop.

Complete table: Configuration Reference

Hook output and the 10K cap

Claude Code injects hook stdout (and any hookSpecificOutput.additionalContext) into the model's context up to a documented 10,000-character hard cap. Beyond the cap, the harness silently writes the body to a temp file and the model receives a filepath instead of the content. If your SessionStart or UserPromptSubmit injection accumulates above 10K, it is silently lost.

AgentiHooks does not enforce a default cap — full content ships through so agents have the most context possible. To audit what each event actually emits and whether anything is over the limit, run:

agentihooks doctor --debug-hook

If you stack many injections (CI manifesto + brain feed + amygdala + custom overlays + tool memory), use the *_MAX_BYTES knobs above to cap the biggest contributors and leave headroom for the rest.

Remote brain quickstart

To wire a Claude Code session into a brain stack you already deployed (e.g. via agentibrain-kernel's docker compose or helm charts), drop the following four lines into ~/.agentihooks/.env:

BRAIN_URL=http://<your-kb-router-host>:<port>
BRAIN_HTTP_TOKEN=<KB_ROUTER_TOKEN from your bootstrap>
BRAIN_ENABLED=true
AMYGDALA_ENABLED=true
# optional — write back markers from this session
BRAIN_WRITER_ENABLED=true

Restart your Claude Code session. The hook stack will fetch hot arcs + active signals on every prompt and inject them as broadcast banners. No profile install required — works alongside any profile (or none).

Portability

Everything user-specific lives in ~/.agentihooks/. To move to a new machine:

uv venv ~/.agentihooks/.venv
uv pip install --python ~/.agentihooks/.venv/bin/python -e ".[all]"
agentihooks init

Related Projects

Project Description
agenticore Claude Code runner and orchestrator
agentibridge MCP server for session persistence and remote control

License

See LICENSE for details.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

agentihooks-1.13.0.tar.gz (293.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

agentihooks-1.13.0-py3-none-any.whl (288.2 kB view details)

Uploaded Python 3

File details

Details for the file agentihooks-1.13.0.tar.gz.

File metadata

  • Download URL: agentihooks-1.13.0.tar.gz
  • Upload date:
  • Size: 293.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for agentihooks-1.13.0.tar.gz
Algorithm Hash digest
SHA256 ac47b07cd5a2bd3c94afb8d802e736d7eb2d832fb1260bd9bf5f38b334f46f4d
MD5 b25dd8da7a2b730325d420d5ec4f0ed9
BLAKE2b-256 2190356cd0df8403d4237faef3306fbce8fd7ceccc7b90d9e3bba36351096d19

See more details on using hashes here.

Provenance

The following attestation bundles were made for agentihooks-1.13.0.tar.gz:

Publisher: publish-pypi.yml on the-cloud-clockwork/agentihooks

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file agentihooks-1.13.0-py3-none-any.whl.

File metadata

  • Download URL: agentihooks-1.13.0-py3-none-any.whl
  • Upload date:
  • Size: 288.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for agentihooks-1.13.0-py3-none-any.whl
Algorithm Hash digest
SHA256 e0e813f375e47e36de8775db63991a8982de094cf8cfad22dd60ba0bd2bbe930
MD5 d579743f0cb50692009391b72ac7d4f9
BLAKE2b-256 0b3a831e1e644141715ef211d3ae84b16dc55d9e738d35ccd2588778a60f0053

See more details on using hashes here.

Provenance

The following attestation bundles were made for agentihooks-1.13.0-py3-none-any.whl:

Publisher: publish-pypi.yml on the-cloud-clockwork/agentihooks

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page