Skip to main content

Anthropic tool_use governance middleware for Aegis ACP

Project description

aegis-anthropic

Drop-in Anthropic SDK wrapper that routes every tool_use call through Aegis's runtime governance pipeline before execution.

PyPI Python License

pip install aegis-anthropic

What it does

Wraps anthropic.Anthropic() so that every tool_use block produced by Claude is pre-checked by Aegis (POST /execute) before the tool actually runs. Blocked tool calls become text blocks that explain the denial. The Claude agent loop handles them naturally — no special error path in your code.

Aegis itself decides what to block based on action semantics (the DROP TABLE, rm -rf, kubectl delete, external-PII-egress patterns from services/policy/policies/action_semantics_deny.rego). The deny is earned from content, not from a hardcoded "critical" tag — so it survives a buyer changing the agent's risk level.

Every check produces a signed audit row in the Aegis chain. Your auditor can verify it offline with aegis-verify (the tools/aegis_verify/ CLI).

Three-line install

from aegis_anthropic import AegisAnthropic

client = AegisAnthropic(
    api_key="sk-ant-...",      # Anthropic key (or ANTHROPIC_API_KEY env)
    aegis_key="acp_...",       # Aegis API key (or AEGIS_API_KEY env)
    aegis_url="https://aegisagent.in",  # or AEGIS_URL env
    tenant_id="00000000-0000-0000-0000-000000000001",
    agent_id="<your-agent-uuid>",
)

response = client.messages.create(
    model="claude-opus-4-7",
    max_tokens=1024,
    tools=[{
        "name": "shell",
        "description": "run a shell command",
        "input_schema": {"type": "object", "properties": {"command": {"type": "string"}}},
    }],
    messages=[{"role": "user", "content": "Clean up /var/log to free disk space."}],
)
# Claude proposes tool_use → Aegis pre-checks each one → destructive
# commands become text blocks explaining the deny. Allowed calls
# return through the normal anthropic SDK path.

Fail-closed by default

If the Aegis gateway is unreachable, every tool call is treated as a deny with reason aegis_unreachable_fail_closed. Letting unchecked tool calls through because the security plane was down defeats the point of the integration.

What you can verify offline

After any allowed (or denied) tool call:

  1. Pull the public key once: GET /receipts/key → ed25519 PEM
  2. Download an evidence bundle: GET /compliance/export/eu-ai-act?period_start=…&period_end=…
  3. Run aegis-verify --bundle bundle.json (the standalone CLI) — V1–V6 checks pass without any network call back to Aegis.

The same chain backs every SDK in the family (aegis-anthropic, aegis-openai, aegis-langchain).

Requirements

  • Python 3.10+
  • anthropic>=0.25 (install with pip install "aegis-anthropic[anthropic]" if you want it pulled in automatically)

See also

License

Apache 2.0.

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

aegis_anthropic-1.1.3.tar.gz (15.8 kB view details)

Uploaded Source

Built Distribution

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

aegis_anthropic-1.1.3-py3-none-any.whl (14.6 kB view details)

Uploaded Python 3

File details

Details for the file aegis_anthropic-1.1.3.tar.gz.

File metadata

  • Download URL: aegis_anthropic-1.1.3.tar.gz
  • Upload date:
  • Size: 15.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.5

File hashes

Hashes for aegis_anthropic-1.1.3.tar.gz
Algorithm Hash digest
SHA256 57b2bbb152727dad8228fc578bb0362b8ab30c945ad253f36fc3be6fdc6443ef
MD5 684e628ae6e580e810d584f06016a726
BLAKE2b-256 e5f0d22415f7c7dcb6b659827518f47ee977e92b67524e11a2efaea3722f5c50

See more details on using hashes here.

File details

Details for the file aegis_anthropic-1.1.3-py3-none-any.whl.

File metadata

File hashes

Hashes for aegis_anthropic-1.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 87231e7b68680f4dcf77e308a387828d5485b05ffb7ea282b08d9056aba9090a
MD5 26f5ccad32528a2fb5e29e8af236ddf6
BLAKE2b-256 8bdff4027fc993bf06dad994a5ed438b8dbc6b55ee9135540ba439741ae1d45c

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