Authorization gateway for AI agent side effects. CapFence lets agents propose tool calls, then enforces deterministic allow, deny, or approval decisions before shell, database, filesystem, payment, API, or MCP execution.
Project description
CapFence
CapFence is the authorization gateway between AI agents and real-world side effects.
Models may propose actions. CapFence decides whether those actions are allowed before execution.
Use CapFence when agents can touch shell commands, databases, filesystems, payment APIs, internal APIs, SaaS admin tools, or MCP servers.
Agent -> Proposed action -> CapFence -> Gated executor -> Tool
Denied actions do not reach the downstream tool.
Prompts are not security boundaries. CapFence removes the LLM from the authorization path.
First Blocked Action
An ops agent proposes:
rm -rf /var/lib/postgresql
CapFence returns:
Decision: DENY
Reason: destructive production filesystem operation
Tool invoked: false
Replay: capfence replay audit_sample.jsonl --policy policy.yaml
Install
pip install capfence
Try It Locally
Define a policy:
deny:
- capability: shell.exec.production
contains: "rm -rf"
allow:
- capability: shell.exec.readonly
Evaluate before execution:
from capfence import ActionEvent, ActionRuntime
runtime = ActionRuntime.from_policy("policies/shell.yaml")
event = ActionEvent.create(
actor="ops-agent",
resource="shell",
action="exec",
environment="production",
payload={"command": "rm -rf /var/lib/postgresql"},
)
verdict = runtime.execute(event)
if not verdict.authorized:
raise PermissionError(f"Blocked before execution: {verdict.reason}")
Expected result:
decision: DENY
reason: policy_deny
tool_invoked: false
Replay the decision:
capfence replay audit.jsonl --policy policies/shell.yaml
Replay output:
Recorded: shell.exec.production
Original: DENY
Replayed: DENY
Changed: false
Security Model
CapFence protects the gated tool path.
Recommended architecture:
Agent -> Proposed action -> CapFence -> Gated executor -> Tool
The agent should not hold raw downstream credentials. The executor owns credentials and invokes the tool only after CapFence returns allow.
CapFence is not effective if the agent can call downstream tools directly with raw credentials.
CapFence does not replace sandboxing, secrets management, network controls, IAM, or database-native permissions.
Why Authorization, Not Guardrails?
Prompt guardrails influence what the model says. CapFence controls what the agent is allowed to do.
The security question is not only:
Did the model intend something safe?
The operational question is:
Is this actor authorized to perform this side effect on this resource in this environment?
CapFence is built for that boundary.
How CapFence Is Different
| Category | What it controls | Weakness | CapFence difference |
|---|---|---|---|
| Prompt guardrails | Model text | Soft boundary | CapFence controls execution |
| LLM judges | Generated content | Probabilistic | CapFence uses deterministic policy |
| Observability | Past behavior | After the fact | CapFence blocks before execution |
| Sandboxes | Process/environment | Not business authorization | CapFence evaluates action semantics |
| IAM | Service identity | Too coarse for agent intent | CapFence authorizes each proposed action |
| Runtime contracts | Agent behavior patterns | Broad or abstract | CapFence focuses on concrete side effects |
Use CapFence For
shell.execboundaries before a process is spawned.- MCP tool authorization before the upstream server receives a request.
- Filesystem scope enforcement before secrets or repo-external paths are read.
- Database write and schema-change controls before queries execute.
- Payment or API action thresholds before external state changes.
CapFence Is Not
- An AI governance platform.
- An observability product.
- An orchestration framework.
- A prompt guardrail.
- An AI judge.
- A compliance dashboard.
Core Docs
- Agent authority model
- Action authorization
- Runtime authorization
- Policy model
- Decision receipts
- Credential placement
- Fail-closed enforcement
- Replayability
- Threat model
- MCP interception model
Status
CapFence is pre-1.0 public beta infrastructure. The core local YAML policy runtime is intended for production pilots, while framework adapters, policy packs, external policy backends, and release automation should be validated in your environment before high-risk use.
CapFence controls the gated tool path. It does not replace sandboxing, secrets management, network segmentation, downstream IAM, or database-native controls.
| Capability | Maturity |
|---|---|
| Local YAML policy evaluation | Beta |
| Audit hash chaining and replay | Beta |
| LangChain, LangGraph, CrewAI, OpenAI Agents SDK adapters | Beta |
| MCP, PydanticAI, LlamaIndex, AutoGen adapters | Experimental |
| Starter policy packs and OPA backend path | Experimental |
- Docs: https://capfence.dev/
- PyPI: https://pypi.org/project/capfence/
- Repository: https://github.com/capfencelabs/capfence
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file capfence-0.8.4.tar.gz.
File metadata
- Download URL: capfence-0.8.4.tar.gz
- Upload date:
- Size: 1.0 MB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
7b73ee278348bb82dd34db42181e96455390967368247e371f32c9a850e8d0ac
|
|
| MD5 |
595da38de0a53d61c46ef0099577d0b6
|
|
| BLAKE2b-256 |
bd9549de86980d4a9a98b8c6fbc16cae519e4e58a8f1d063cb041633d99567a2
|
Provenance
The following attestation bundles were made for capfence-0.8.4.tar.gz:
Publisher:
release.yml on capfencelabs/capfence
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
capfence-0.8.4.tar.gz -
Subject digest:
7b73ee278348bb82dd34db42181e96455390967368247e371f32c9a850e8d0ac - Sigstore transparency entry: 1637438426
- Sigstore integration time:
-
Permalink:
capfencelabs/capfence@0854136f0321df73c8e3543354758ecea5ae2386 -
Branch / Tag:
refs/tags/v0.8.4 - Owner: https://github.com/capfencelabs
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@0854136f0321df73c8e3543354758ecea5ae2386 -
Trigger Event:
release
-
Statement type:
File details
Details for the file capfence-0.8.4-py3-none-any.whl.
File metadata
- Download URL: capfence-0.8.4-py3-none-any.whl
- Upload date:
- Size: 98.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
128d69e8b9d361a2ef36c73ecbc2174d29c3aecb7220b55cfaf7cfd3ccb11e50
|
|
| MD5 |
ec03c80439aa1bc767f684e5b4aae428
|
|
| BLAKE2b-256 |
c30bb4963921efaa4334a74394efb06fcdc687fa9ba297a04ced23771346e3b0
|
Provenance
The following attestation bundles were made for capfence-0.8.4-py3-none-any.whl:
Publisher:
release.yml on capfencelabs/capfence
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
capfence-0.8.4-py3-none-any.whl -
Subject digest:
128d69e8b9d361a2ef36c73ecbc2174d29c3aecb7220b55cfaf7cfd3ccb11e50 - Sigstore transparency entry: 1637438592
- Sigstore integration time:
-
Permalink:
capfencelabs/capfence@0854136f0321df73c8e3543354758ecea5ae2386 -
Branch / Tag:
refs/tags/v0.8.4 - Owner: https://github.com/capfencelabs
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@0854136f0321df73c8e3543354758ecea5ae2386 -
Trigger Event:
release
-
Statement type: