ARGUS Python SDK - Framework-agnostic AI agent guardrails and safety tool
Project description
ARGUS Python SDK
The official Python SDK for ARGUS — the Agent Runtime Guardrail & Unauthorized-action Stopper.
Securing what AI agents do — not just what they hear.
Installation
You can install the SDK via pip:
pip install argus-sdk
Or using uv:
uv add argus-sdk
Quick Start
1. Set your Environment Variables
export ARGUS_API_KEY="your-api-key"
export ARGUS_BASE_URL="http://localhost:8000"
2. Protect Your Tools
Wrap your critical agent tools with the @argus.protect decorator.
import argus
@argus.protect(action_type="send_email", target_type="email")
def send_email(to_address: str, subject: str, body: str):
# This function will ONLY execute if ARGUS approves the action
print(f"Sending email to {to_address}...")
return True
3. Run the Agent within a Session
When a user submits a prompt, wrap the execution in an argus.Session. This automatically extracts the user's intent and establishes a temporary authorization boundary.
import argus
from argus import ArgusQuarantineException
prompt = "Send the Q3 report to alice@example.com"
# 1. Extract Intent and start session
with argus.Session(user_prompt=prompt):
try:
# Agent decides to execute the tool
send_email(to_address="alice@example.com", subject="Q3 Report", body="Attached.")
print("Success!")
# If the agent goes rogue and tries to email someone else:
send_email(to_address="eve@example.com", subject="Q3 Report", body="Attached.")
except ArgusQuarantineException as e:
print(f"Agent was stopped! Reason: {e.explanation}")
Integrations
LangChain
ARGUS provides native wrappers for LangChain tools.
from argus.integrations.langchain import wrap_langchain_tool
from langchain_core.tools import tool
@tool
def read_patient_record(patient_id: str) -> str:
"""Reads a patient record."""
return "Patient Data"
# Wrap the tool
protected_tool = wrap_langchain_tool(
tool=read_patient_record,
action_type="read_patient_record",
target_type="patient_record"
)
# Use it within an argus.Session normally!
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 argus_shield-0.2.0.tar.gz.
File metadata
- Download URL: argus_shield-0.2.0.tar.gz
- Upload date:
- Size: 19.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.14
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f008ce57141940c17eac82f57f7e747c0dbb70b5bd42a1c023a762631e68e49d
|
|
| MD5 |
192be133a9acb069fe75308c4e8e96df
|
|
| BLAKE2b-256 |
ba590a9b057eb1bfa355167dd8dce3f3895327dbfeac3dc3ee7a5fc3a4bfb4e8
|
File details
Details for the file argus_shield-0.2.0-py3-none-any.whl.
File metadata
- Download URL: argus_shield-0.2.0-py3-none-any.whl
- Upload date:
- Size: 17.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.14
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f28c9fbdb1c65759157e3bba9590ba7d426a2adcd5aa9400db2022f3c51e8afe
|
|
| MD5 |
6f59859e85a613ba851573c383a50dbb
|
|
| BLAKE2b-256 |
4de54664bca2b102cfe7caa066352660554f49c3e1a6d43ec44a8b8edbb87cdc
|