Configuration¶
Agent Hooks is configured primarily through CLI flags and environment variables.
Recommended config split
Use CLI flags for per-caller choices like --provider, and use environment variables for local defaults like log paths, project root, AppleScript behavior, and Codex policy settings.
Provider Selection¶
--provider claude-code|codexAGENT_HOOK_PROVIDER
Use the explicit CLI flag when you want the most predictable behavior. If you do not set one, Agent Hooks will try to infer the provider from the incoming payload.
AppleScript Control¶
AGENT_HOOK_DISABLE_OSASCRIPTCLAUDE_HOOK_DISABLE_OSASCRIPT
Accepted true values:
1trueyeson
Accepted false values:
0falsenooff
Testing mode
Set AGENT_HOOK_DISABLE_OSASCRIPT=1 when you want to validate callback behavior without opening macOS dialogs or notifications.
Project Root And Paths¶
AGENT_HOOK_PROJECT_ROOTAGENT_HOOK_LOG_DIRAGENT_HOOK_APP_LOG_PATHAGENT_HOOK_INPUT_AUDIT_LOG_PATHAGENT_HOOK_RESPONSE_AUDIT_LOG_PATH
Relative paths are resolved from AGENT_HOOK_PROJECT_ROOT. If you do not set it, the package default project root is used.
Path resolution
Relative log paths are anchored to AGENT_HOOK_PROJECT_ROOT. If your logs end up somewhere unexpected, this is usually the first setting to check.
App Log Controls¶
AGENT_HOOK_APP_LOG_LEVELAGENT_HOOK_APP_LOG_FORMATAGENT_HOOK_APP_LOG_MAX_BYTESAGENT_HOOK_APP_LOG_BACKUP_COUNT
Shared Log Rotation Controls¶
AGENT_HOOK_LOG_MAX_BYTESAGENT_HOOK_LOG_BACKUP_COUNT
These act as fallbacks when a log-specific max-bytes or backup-count env var is not set.
Input Audit Log Controls¶
AGENT_HOOK_INPUT_AUDIT_LOG_MAX_BYTESAGENT_HOOK_INPUT_AUDIT_LOG_BACKUP_COUNT
Response Audit Log Controls¶
AGENT_HOOK_RESPONSE_AUDIT_LOG_MAX_BYTESAGENT_HOOK_RESPONSE_AUDIT_LOG_BACKUP_COUNT
Codex execpolicy¶
AGENT_HOOK_CODEX_EXECPOLICY_MODELAGENT_HOOK_CODEX_EXECPOLICY_RULES
The current default model is 5.4-mini and the default rules path is ~/.codex/rules/default.rules.
Important for Codex users
These settings control the pre-check that can suppress repeated permission dialogs for already-allowed Bash commands. If the behavior seems off, verify both the model and the rules path.
Recommended Pattern¶
Use CLI flags for provider choice and environment variables for persistent local defaults, especially:
- project root
- log paths
- AppleScript enable or disable
- Codex rules path