Public Preview — Agent Governance Toolkit integration for Google ADK: policy enforcement, trust verification, and audit trails for ADK agents
Project description
ADK AgentMesh — Governance for Google ADK Agents
[!IMPORTANT] Public Preview — The
adk-agentmeshpackage on PyPI is a Microsoft-signed public preview release. APIs may change before GA.
Policy enforcement, trust verification, and audit trails for Google ADK agents — powered by the Agent Governance Toolkit.
What It Does
adk-agentmesh implements the PolicyEvaluator protocol
(google/adk-python#4897)
backed by the Agent Governance Toolkit's deterministic policy engine.
- Tool-level governance — block, allow-list, or require approval for any ADK tool call
- Rate limiting — cap tool calls per agent per session
- Delegation scope — monotonic narrowing ensures sub-agents never exceed parent permissions
- Structured audit — every decision is logged with verdict, rule, and timestamp
Installation
pip install adk-agentmesh
Quick Start
1. Define a governance policy
Create a YAML policy file (see examples/policies/adk-governance.yaml):
adk_governance:
blocked_tools:
- execute_shell
- delete_database
max_tool_calls: 100
require_approval_for:
- send_email
- deploy_service
2. Wire into your ADK agent
from adk_agentmesh import ADKPolicyEvaluator, GovernanceCallbacks
# Load policy
evaluator = ADKPolicyEvaluator.from_config("policies/adk-governance.yaml")
callbacks = GovernanceCallbacks(evaluator)
# Attach to ADK agent
from google.adk.agents import LlmAgent
agent = LlmAgent(
model="gemini-2.0-flash",
name="my-governed-agent",
before_tool_callback=callbacks.before_tool,
after_tool_callback=callbacks.after_tool,
before_agent_callback=callbacks.before_agent,
after_agent_callback=callbacks.after_agent,
)
3. Or use the evaluator directly
import asyncio
from adk_agentmesh import ADKPolicyEvaluator
evaluator = ADKPolicyEvaluator(
blocked_tools=["execute_shell"],
max_tool_calls=50,
require_approval_for=["send_email"],
)
decision = asyncio.run(
evaluator.evaluate_tool_call(
tool_name="search_web",
tool_args={"query": "latest news"},
agent_name="research-agent",
)
)
print(decision.verdict) # Verdict.ALLOW
ADK Lifecycle Mapping
| ADK Hook | Governance Check |
|---|---|
before_tool_callback |
Policy evaluation, rate limiting, tool blocking |
after_tool_callback |
Audit logging |
before_agent_callback |
Delegation scope check |
after_agent_callback |
Delegation audit |
Delegation Scope Narrowing
Sub-agents automatically receive narrowed permissions:
from adk_agentmesh import DelegationScope
parent_scope = DelegationScope(
allowed_tools=["search_web", "read_file", "write_file"],
max_tool_calls=100,
max_depth=3,
)
# Child gets strictly fewer permissions
child_scope = parent_scope.narrow(
allowed_tools=["search_web", "read_file"],
read_only=True,
)
# child_scope.max_depth == 2 (always decrements)
# child_scope.read_only == True (once set, cannot be unset)
Audit Events
Every governance decision is recorded:
evaluator = ADKPolicyEvaluator(blocked_tools=["dangerous_tool"])
# ... after agent runs ...
for entry in evaluator.get_audit_log():
print(entry["event"], entry["timestamp"])
For structured audit handling:
from adk_agentmesh import AuditEvent, LoggingAuditHandler
handler = LoggingAuditHandler()
event = AuditEvent(
event_type="tool_call_denied",
agent_name="my-agent",
tool_name="execute_shell",
verdict="deny",
reason="Tool is blocked by policy",
)
handler.handle(event)
Sample Policy
See the full sample policy at
examples/policies/adk-governance.yaml.
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
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 adk_agentmesh-3.2.2.tar.gz.
File metadata
- Download URL: adk_agentmesh-3.2.2.tar.gz
- Upload date:
- Size: 11.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: RestSharp/106.13.0.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b4c4b4fc6195012a715ee3c0951184f4ab31f05b5fc81414875d08c2ec105589
|
|
| MD5 |
62252954373cd1a4b7c5f9206556069c
|
|
| BLAKE2b-256 |
cfd854a2f3b7a05d9843cc629282e8869d209d18124965b6cae44880e2a2d369
|
File details
Details for the file adk_agentmesh-3.2.2-py3-none-any.whl.
File metadata
- Download URL: adk_agentmesh-3.2.2-py3-none-any.whl
- Upload date:
- Size: 8.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: RestSharp/106.13.0.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d72b64dd4659709c415c2bd92d5eb51391bcd72ea15835d65340171c07acbb72
|
|
| MD5 |
0191a94d7d58e79b329c3f4d339e314a
|
|
| BLAKE2b-256 |
e321fc94260e30398954e9bdd69836946e795fc7469cd02aa46988977bfefaf7
|