Skip to main content

Approve or deny your AI coding agent's risky commands from your phone, with an audit trail. Works with Claude Code and OpenAI Codex.

Project description

AgentGuard

A guardrail layer for autonomous coding agents. AgentGuard classifies the risk of every shell command and file edit your AI coding agent attempts, routes the risky ones to your phone for approval, and — critically — denies by default when no one responds. Every decision is logged.

Not a remote-control app. Anthropic's Remote Control already lets you drive a Claude session from your phone. AgentGuard is the policy layer underneath: it decides what an agent is allowed to do, enforces protected files unconditionally, fails safe, and is built to gate any agent — not just one vendor's.

Why it exists

Native permission prompts (and Remote Control's mirrored version of them) ask "allow this?" with no risk model, no protected-file enforcement, and no fail-safe: ignore the prompt and nothing is denied. AgentGuard adds the missing governance layer:

Native prompt / Remote Control AgentGuard
Risk classification CRITICAL → LOW, defaults to "ask"
Protected files (.env, CI, lockfiles, .claude/) Always re-affirm, bypass auto-allow
No-response behavior nothing denied default-deny (fail-safe timeout)
Phone-set guards / auto-rules yes
Audit trail every classify/approve/deny logged

How it works

A PreToolUse hook intercepts the agent's tool call, a classifier scores it, and:

  • LOW → auto-approve.
  • CRITICAL → auto-deny.
  • MEDIUM / HIGH → sent to your phone with a diff/snippet; blocks until you decide.
  • Protected file (gate config, secrets, supply-chain/CI) → always reaches you, regardless of score.
  • No decision within the timeoutdeny (fail-safe).

Install

pip install agentsguard            # the CLI command is `agentguard`
agentguard install-hooks          # wire hooks into this project (.claude/settings.local.json)
agentguard install-hooks --global # …or all projects (~/.claude/settings.json)

Then restart Claude Code (or run /hooks). It's idempotent and leaves any other hooks in place.

Approval channels

AgentGuard is transport-agnostic — the gate is the product, the channel is a detail:

  • Telegram (default, zero infra):
    agentguard init                 # bot token + chat id
    
  • Cloud relay + mobile app (approvals from anywhere):
    agentguard pair                 # link this machine to the phone app
    

Quick manual test (no agent needed):

agentguard approve-command "git push origin main"   # exits 0 (allow) / 1 (deny)

Approval modes (agentguard mode)

Mode Who approves Use when
phone (default) Only your phone. The local popup is suppressed — the hook tells Claude Code allow/deny directly, so work continues the instant you tap. You're away, or don't want anyone at the keyboard approving for you.
laptop Only the local prompt. No phone notifications; the hook steps aside. You're at the desk and don't want phone pings.

agentguard mode laptop takes effect immediately (read at runtime).

Claude Code hook

install-hooks wires the gating + notification hooks with the correct local path filled in. The gating hook looks like:

{
  "hooks": {
    "PreToolUse": [
      {
        "matcher": "Bash",
        "hooks": [
          { "type": "command", "command": "agentguard hook --timeout 1800", "timeout": 1800 }
        ]
      }
    ]
  }
}
  • Critical invariant: the inner --timeout must be the outer "timeout", or Claude Code kills the hook before your phone can respond. install-hooks keeps them matched.
  • Hook config changes take effect only after restarting Claude Code (snapshotted at session start). Hook code is live with an editable install.

Other commands

agentguard logs -n 20      # activity timeline
agentguard pending         # is a command awaiting me, or did it stop?
agentguard resume          # lift a Stop kill-switch
agentguard instructions    # show instructions sent from the phone

Storage

All state lives in ~/.agentguard/: config.json, approvals.json, instructions.json, audit_log.json.

License

Proprietary. See LICENSE.

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

agentsguard-0.3.1.tar.gz (59.3 kB view details)

Uploaded Source

Built Distribution

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

agentsguard-0.3.1-py3-none-any.whl (64.6 kB view details)

Uploaded Python 3

File details

Details for the file agentsguard-0.3.1.tar.gz.

File metadata

  • Download URL: agentsguard-0.3.1.tar.gz
  • Upload date:
  • Size: 59.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.12

File hashes

Hashes for agentsguard-0.3.1.tar.gz
Algorithm Hash digest
SHA256 cbc38d13a713e3e4360382c7f9d3bb3cde9ea7198dfc6da555f7fa43118c1f43
MD5 f11782f5a610b0956131691f3423c829
BLAKE2b-256 01e8d8cc02a396fd049be297d5eec7517feb355a582e7877425ba31a254c86db

See more details on using hashes here.

File details

Details for the file agentsguard-0.3.1-py3-none-any.whl.

File metadata

  • Download URL: agentsguard-0.3.1-py3-none-any.whl
  • Upload date:
  • Size: 64.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.12

File hashes

Hashes for agentsguard-0.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 1e48f15b63ee0f23577101a054a1c949d65160b8567aae97877703fdc59f5399
MD5 6209b75dc8d0650e1ebbc365b23517b8
BLAKE2b-256 bb1c9cf655cae1d19351afc27c2a6e192711a4aac718c378ed4aff2ddf395dcf

See more details on using hashes here.

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