Zero-trust ML Risk Oracle and Firewall for Algorand AI Agents
Project description
🛡️ Ageniz SDK
The Zero-Trust ML Risk Oracle and Firewall for Algorand AI Agents.
Ageniz is a developer-first security protocol that prevents AI Agents (like trading bots or autonomous assistants) from draining wallets through hallucinations, prompt injections, or malicious intent.
By routing all agent transactions through an off-chain Machine Learning Oracle and validating them on-chain via an immutable Smart Contract Vault, Ageniz provides enterprise-grade "Defense in Depth."
✨ Features
- ML Intent Scoring: Prevents prompt-injection attacks and anomalies before they reach the blockchain.
- Cryptographic Bait-and-Switch Protection: Recipient addresses are bound into the Oracle's Ed25519 signature.
- Replay Attack Immunity: Strict, timestamp-based Nonce tracking stored in Algorand Local State.
- Dynamic Reputation: Agents earn trust scores over time, unlocking lower fees and higher limits.
- Automated x402 Routing: Seamlessly bundles security tolls and Vault payments into a single Atomic Transaction.
📦 Installation
pip install agenizai-sdk
Quickstart
1. Environment Setup
Create a .env file in your project root with your Algorand wallet details and Ageniz configuration:
# Your AI Agent's Wallet
DEPLOYER_MNEMONIC="your twenty five word algorand testnet mnemonic phrase goes here..."
# Ageniz Protocol Config
APP_ID=760267917
ORACLE_URL="https://ageniz-oracle.onrender.com"
2. Basic Implementation
Here is a complete example of initializing the agent, opting into the security contract, and executing a protected payment.
import os
from dotenv import load_dotenv
from ageniz_sdk.core import AgenizSDK
load_dotenv()
# 1. Initialize the Firewall
agent = AgenizSDK(
wallet_mnemonic=os.getenv("DEPLOYER_MNEMONIC"),
ageniz_api_key="your_developer_api_key",
app_id=int(os.getenv("APP_ID")),
oracle_url=os.getenv("ORACLE_URL")
)
# 2. Opt-in to the Vault (Required once per wallet for Nonce tracking)
agent.opt_in()
# 3. Execute a Protected Payment
print("Requesting payment authorization...")
result = agent.pay(
recipient="YZ2L7MGFX35YUGVPB2YF3S4K3KQVNJ4BWYFIB3UVMJNQAPEME3MK7ME2DU",
amount_algo=1.0,
context="Paying external weather API for daily data fetch."
)
# 4. Handle the Verdict
if result["status"] == "SUCCESS":
print(f"✅ Payment cleared firewall! TxID: {result['tx_id']}")
elif result["status"] == "BLOCKED":
print(f"❌ Payment blocked by ML Oracle: {result['reason']}")
else:
print(f"⚠️ Transaction failed: {result.get('reason')}")
🔐 Architecture: The 86-Byte Fortress
Ageniz does not rely solely on off-chain AI. It enforces security on-chain using an 86-byte cryptographic payload.
When agent.pay() is called:
- The SDK sends the request context to the Ageniz ML Oracle.
- If deemed
SAFE, the Oracle generates a uniquenonceand signs an 86-byte payload containing the exact(amount, recipient, nonce). - The SDK bundles this signature and the transaction into an Atomic Group.
- The Ageniz Smart Contract reconstructs the payload on-chain, verifies the Ed25519 signature, checks the nonce against the agent's Local State to prevent replays, and finally releases the funds.
📊 Checking Agent Reputation
You can monitor your agent's standing with the protocol at any time:
status = agent.get_status()
print(f"Reputation Score : {status['reputation_score']}/100")
print(f"Velocity : {status['velocity']} tx/hr")
print(f"Fee Tier : {status['fee_tier']['tier']} ({status['fee_tier']['fee_pct']}%)")
📄 License
This project is licensed under the MIT License.
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 agenizai_sdk-2.0.2.tar.gz.
File metadata
- Download URL: agenizai_sdk-2.0.2.tar.gz
- Upload date:
- Size: 6.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.10
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e999cd93647236f2538bdeeabce09b36a956504c54ea1db9bc919c7e900417ef
|
|
| MD5 |
a3f2a53f2a2d44314a2e17582742e359
|
|
| BLAKE2b-256 |
4802e877c4c8713de56ac3725f0d9e53386708db10259e692f1838229fe3d791
|
File details
Details for the file agenizai_sdk-2.0.2-py3-none-any.whl.
File metadata
- Download URL: agenizai_sdk-2.0.2-py3-none-any.whl
- Upload date:
- Size: 7.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.10
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
cc7136b072d933a9f464d3a12ea01aa1702d9344be3386cd407f20c418a86a11
|
|
| MD5 |
ab4395f919908ec44ea7c63b8a9f2b26
|
|
| BLAKE2b-256 |
6f3561d6ccb8f7a77b1c8f30e722895a1aec228a68b591bfa2c01ff66007cbed
|