Skip to main content

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.

PyPI version Python versions License: MIT

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:

  1. The SDK sends the request context to the Ageniz ML Oracle.
  2. If deemed SAFE, the Oracle generates a unique nonce and signs an 86-byte payload containing the exact (amount, recipient, nonce).
  3. The SDK bundles this signature and the transaction into an Atomic Group.
  4. 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


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

agenizai_sdk-2.0.2.tar.gz (6.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

agenizai_sdk-2.0.2-py3-none-any.whl (7.1 kB view details)

Uploaded Python 3

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

Hashes for agenizai_sdk-2.0.2.tar.gz
Algorithm Hash digest
SHA256 e999cd93647236f2538bdeeabce09b36a956504c54ea1db9bc919c7e900417ef
MD5 a3f2a53f2a2d44314a2e17582742e359
BLAKE2b-256 4802e877c4c8713de56ac3725f0d9e53386708db10259e692f1838229fe3d791

See more details on using hashes here.

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

Hashes for agenizai_sdk-2.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 cc7136b072d933a9f464d3a12ea01aa1702d9344be3386cd407f20c418a86a11
MD5 ab4395f919908ec44ea7c63b8a9f2b26
BLAKE2b-256 6f3561d6ccb8f7a77b1c8f30e722895a1aec228a68b591bfa2c01ff66007cbed

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page