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.2.tar.gz (13.4 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.2-py3-none-any.whl (13.4 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: aegis_anthropic-1.1.2.tar.gz
  • Upload date:
  • Size: 13.4 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.2.tar.gz
Algorithm Hash digest
SHA256 39fa5f6bc3165c3aeeef877106ccd3a8c208661dddcd719191509b599ecafd38
MD5 8917c643bc93e2bcaf86de695853291c
BLAKE2b-256 4c363a00692e312941ef855893e27c8cf2353b17cf3c92cfb186c927d36f4f01

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for aegis_anthropic-1.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 e5766e58ede7ce01119ce126c7bc7112b300d774e8af00e45a3a5e3843b25eca
MD5 1c9c8e771eb8ab1dcc3b2e55809ae261
BLAKE2b-256 ae49ed821b0614de69228e69efc9af84d9d21e096fa7ba1859daf200dde4b5f9

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