| Crates.io | adk-guardrail |
| lib.rs | adk-guardrail |
| version | 0.2.1 |
| created_at | 2025-12-14 10:59:21.216088+00 |
| updated_at | 2026-01-22 03:38:54.0488+00 |
| description | Guardrails framework for ADK agents - input/output validation, content filtering, PII redaction |
| homepage | https://www.zavora.ai |
| repository | https://github.com/zavora-ai/adk-rust |
| max_upload_size | |
| id | 1984259 |
| size | 78,271 |
Guardrails framework for ADK agents - input/output validation, content filtering, PII redaction.
adk-guardrail provides safety and validation for AI agents in the ADK-Rust framework:
[dependencies]
adk-guardrail = "0.2.0"
# With JSON schema validation (default)
adk-guardrail = { version = "0.2.1", features = ["schema"] }
use adk_guardrail::{PiiRedactor, Guardrail};
use adk_core::Content;
let redactor = PiiRedactor::new();
let content = Content::new("user").with_text("Contact me at test@example.com");
let result = redactor.validate(&content).await;
// Result is Transform with "[EMAIL REDACTED]"
use adk_guardrail::ContentFilter;
// Block harmful content
let filter = ContentFilter::harmful_content();
// Keep responses on-topic
let filter = ContentFilter::on_topic("cooking", vec!["recipe".into(), "bake".into()]);
// Limit response length
let filter = ContentFilter::max_length(1000);
// Block specific keywords
let filter = ContentFilter::blocked_keywords(vec!["forbidden".into()]);
Requires guardrails feature on adk-agent:
adk-agent = { version = "0.2.1", features = ["guardrails"] }
use adk_agent::LlmAgentBuilder;
use adk_guardrail::{GuardrailSet, ContentFilter, PiiRedactor};
let input_guardrails = GuardrailSet::new()
.with(ContentFilter::harmful_content())
.with(PiiRedactor::new());
let agent = LlmAgentBuilder::new("assistant")
.input_guardrails(input_guardrails)
.build()?;
Each guardrail returns one of three results:
| Result | Description |
|---|---|
Pass |
Content is valid, continue execution |
Fail |
Content is invalid, block with reason and severity |
Transform |
Content modified (e.g., PII redacted), continue with new content |
| Level | Description |
|---|---|
Low |
Minor issue, may continue |
Medium |
Moderate issue, should review |
High |
Serious issue, should block |
Critical |
Dangerous content, must block |
Detects and redacts personally identifiable information:
Email → [EMAIL REDACTED]Phone → [PHONE REDACTED]Ssn → [SSN REDACTED]CreditCard → [CREDIT CARD REDACTED]IpAddress → [IP REDACTED]Validates content against rules:
harmful_content() - Blocks common harmful patternson_topic(topic, keywords) - Ensures topic relevancemax_length(n) - Limits content lengthblocked_keywords(list) - Blocks specific wordsValidates JSON output against a schema (requires schema feature):
use adk_guardrail::SchemaValidator;
use serde_json::json;
let schema = json!({
"type": "object",
"properties": {
"name": { "type": "string" },
"age": { "type": "integer" }
},
"required": ["name"]
});
let validator = SchemaValidator::new("user_schema", schema)?;
GuardrailSet builder patternLlmAgentBuilder via input_guardrails() / output_guardrails()Guardrail traitApache-2.0
This crate is part of the ADK-Rust framework for building AI agents in Rust.