Skip to main content

Deny-first tool authorization for pydantic-ai agents — by AgentsID

Project description

pydantic-ai-toolguard

Deny-first tool authorization for pydantic-ai agents — by AgentsID.

Implements the AgentsID Permission Specification: glob-based tool patterns, parameter conditions, schedule windows, rate limiting, approval workflows, and an append-only audit log.

Install

pip install pydantic-ai-toolguard

Quick Start

from pydantic_ai import Agent
from pydantic_ai_toolguard import ToolGuard, PermissionRule

guard = ToolGuard(rules=[
    PermissionRule(tool_pattern="delete_*", action="deny"),
    PermissionRule(tool_pattern="*", action="allow"),
])

agent = Agent("openai:gpt-5.2", capabilities=[guard])

The guard hides denied tools from the model and blocks execution if a denied tool is somehow called. Every decision is recorded in the audit log.

How It Works

Rules are evaluated deny-first:

  1. DENY rules checked first — first matching deny = blocked
  2. ALLOW rules checked second — first matching allow = permitted (subject to rate limits, schedule, approval)
  3. Default DENY — no matching rule = blocked

This integrates via three pydantic-ai capability hooks:

  • prepare_tools — filters denied tools out of the model's view
  • before_tool_execute — evaluates permissions before execution
  • after_tool_execute — records the result

Features

Glob Pattern Matching

PermissionRule(tool_pattern="*", action="allow")         # all tools
PermissionRule(tool_pattern="db_*", action="deny")        # prefix match
PermissionRule(tool_pattern="*_readonly", action="allow")  # suffix match

Parameter Conditions

PermissionRule(
    tool_pattern="query_db",
    action="deny",
    conditions={"env": "production"},  # only deny production queries
)

Schedule Windows

from pydantic_ai_toolguard import ScheduleConfig

PermissionRule(
    tool_pattern="deploy_*",
    action="allow",
    schedule=ScheduleConfig(
        hours_start=9, hours_end=17,
        timezone="US/Pacific",
        days=("mon", "tue", "wed", "thu", "fri"),
    ),
)

Rate Limiting

from pydantic_ai_toolguard import RateLimitConfig

PermissionRule(
    tool_pattern="search_*",
    action="allow",
    rate_limit=RateLimitConfig(max=10, per="minute"),
)

Approval Workflows

async def ask_user(tool: str, rule: PermissionRule) -> bool:
    return input(f"Allow {tool}? (y/n) ") == "y"

guard = ToolGuard(
    rules=[PermissionRule(tool_pattern="transfer_*", action="allow", requires_approval=True)],
    on_approval=ask_user,
)

Audit Log

guard = ToolGuard(rules=[...])

# After agent runs...
for entry in guard.audit_log.query(decision="denied"):
    print(f"{entry.timestamp}{entry.tool}: {entry.reason}")

# Export as JSON
print(guard.audit_log.export_json())

Configuration

Parameter Type Default Description
rules Sequence[PermissionRule] required Permission rules
on_approval async (str, PermissionRule) -> bool None Approval callback
hide_denied bool True Remove denied tools from model view
log_decisions bool True Record to audit log
deny_message str "Permission denied: {reason}" Message returned to model on deny

Links

License

MIT

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

pydantic_ai_toolguard-0.1.0.tar.gz (12.4 kB view details)

Uploaded Source

Built Distribution

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

pydantic_ai_toolguard-0.1.0-py3-none-any.whl (10.0 kB view details)

Uploaded Python 3

File details

Details for the file pydantic_ai_toolguard-0.1.0.tar.gz.

File metadata

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

File hashes

Hashes for pydantic_ai_toolguard-0.1.0.tar.gz
Algorithm Hash digest
SHA256 9a91f7fcb68f56221f4e894370e37d21ba09f13dfa6915fc5874ea726b4715c4
MD5 05edb9d18e54e0d32829f29c93e1fa83
BLAKE2b-256 d06c89243d04a578ae6fe90726050fb9033a7354042a7e6d3c773217758e0ae8

See more details on using hashes here.

File details

Details for the file pydantic_ai_toolguard-0.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for pydantic_ai_toolguard-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 977ba648512c74859090053bb8aaf515df4e5f2b7785b0a7b2a254ec9bb08708
MD5 d5dd75f55e11eedc558a98b96c09f012
BLAKE2b-256 5dbb0d62289311418c1d6b876ba1981115d39ada812b566c818c1888606ce136

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