Official Driftgard Python SDK — evaluate LLM interactions against your compliance policy
Project description
driftgard
Official Python SDK for Driftgard — evaluate LLM interactions against your compliance policy.
Install
pip install driftgard
Quick start
from driftgard import Driftgard
dg = Driftgard(api_key="your-api-key")
result = dg.evaluate(
project_id="your-project-id",
prompt="What stocks should I buy?",
response="Based on current trends, you should invest in...",
model_id="gpt-4o",
)
if result["evaluation"]["allowed"]:
print("Safe to return to user")
else:
# Use the fallback message if configured in your control pack
if "fallback" in result:
print("Show to user:", result["fallback"]["message"])
print("Blocked:", result["evaluation"]["violations"])
Conversation tracking
Link evaluations within an agent session using session_id and parent_evaluation_id:
result = dg.evaluate(
project_id="your-project-id",
prompt="Transfer $500 to account 12345",
response="I've initiated the transfer.",
model_id="gpt-4o",
session_id="sess_abc123", # groups evals in a conversation
parent_evaluation_id="eval_prev_id", # chains to the previous eval
)
This enables chain depth protection (prevents infinite agent loops) and lets you trace evaluation lineage in the dashboard.
A/B experiments
Tag evaluations with an experiment_id to compare governance metrics across models:
result = dg.evaluate(
project_id="your-project-id",
prompt="Can I get a loan to invest in crypto?",
response="Sure, taking out a personal loan to invest in crypto is a great way to maximise returns.",
model_id="gpt-4o",
experiment_id="financial-advisor-v1", # optional
)
View experiment results on the Experiments page in the Driftgard dashboard.
Cost attribution
Pass optional usage metadata to track token consumption and cost per evaluation:
result = dg.evaluate(
project_id="your-project-id",
prompt="What stocks should I buy?",
response="Based on current trends, you should invest in...",
model_id="gpt-4o",
usage={
"prompt_tokens": 150,
"completion_tokens": 320,
"total_tokens": 470,
"cost": 0.0047, # USD
},
)
All fields in usage are optional. When provided, token and cost data appears in the evaluation detail and is aggregated in experiment comparisons.
Features
- Single
evaluate()method — send prompt/response, get verdict - Failure mode:
fail-openorfail-closedwhen API is unreachable - Circuit breaker: skips API after consecutive failures, auto-recovers
- Idempotency: deduplicates retried requests via
x-idempotency-key - Auto-retry with exponential backoff on 5xx and network errors
- Typed exceptions:
AuthError,RateLimitError,FeatureNotAvailableError,ChainDepthExceededError - Works with Python 3.8+
Configuration
dg = Driftgard(
api_key="your-api-key", # required
base_url="https://api.driftgard.com", # optional
timeout=30, # optional, seconds (default 30)
max_retries=2, # optional (default 2)
failure_mode="open", # "open" = allow if API down, "closed" = block (default "open")
circuit_breaker_threshold=5, # open circuit after 5 failures (default 5)
circuit_breaker_reset_seconds=30, # try again after 30s (default 30)
)
Failure mode & circuit breaker
The SDK never throws on network/server errors during evaluate(). Instead, it returns a synthetic response:
result = dg.evaluate(...)
# Check where the decision came from
print(result["decision_source"])
# "policy" — normal API evaluation
# "failure_mode" — API unreachable, failure_mode applied
# "circuit_open" — circuit breaker open, failure_mode applied
# "idempotency_cache" — duplicate request, cached result returned
# Monitor circuit breaker state
print(dg.circuit_breaker_state)
# {"state": "closed", "failures": 0, "opened_at": 0}
With failure_mode="open" (default), the SDK allows requests through when Driftgard is unavailable. With failure_mode="closed", it blocks them with a fallback message.
Error handling
from driftgard import Driftgard, AuthError, RateLimitError, FeatureNotAvailableError, ChainDepthExceededError
try:
result = dg.evaluate(...)
except AuthError:
# Invalid or revoked API key (401)
pass
except RateLimitError:
# Too many requests (429)
pass
except ChainDepthExceededError as e:
# Agent loop detected — chain depth exceeded (429)
print(f"Depth {e.depth} exceeds max {e.max_depth}")
except FeatureNotAvailableError as e:
# API evaluate requires Compliance+ tier (403)
print(e.tier)
Requirements
- Python 3.8+
requestslibrary- API key from Driftgard (Settings → API Keys)
- Compliance or Enterprise tier for API evaluation
License
MIT
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 driftgard-1.5.1.tar.gz.
File metadata
- Download URL: driftgard-1.5.1.tar.gz
- Upload date:
- Size: 6.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.9.6
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a23ad841d8baf536b1c3e763b823f9b0cb787e675ada44921b49d7f3afb951f8
|
|
| MD5 |
58e797622d0631532e3650543f476225
|
|
| BLAKE2b-256 |
8ff5e4fd2f037a678ebda1a0857a7d5f25eb9d7dd2fd72c6040608ed27ac134f
|
File details
Details for the file driftgard-1.5.1-py3-none-any.whl.
File metadata
- Download URL: driftgard-1.5.1-py3-none-any.whl
- Upload date:
- Size: 6.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.9.6
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
cd031417033747264363d6cd9fb1145b7c78deed966a5475fc099e52dfd5517f
|
|
| MD5 |
8fc362767c38672125912973176e594a
|
|
| BLAKE2b-256 |
f2ed96f1d8cd00846e7faf510125c6137a9381302c0bcc8f7f29629e5ba2a6b4
|