Official Python SDK for Nirium autonomous agents on Stellar (x402 + MPP)
Project description
nirium
Official Python SDK for the Nirium Protocol — autonomous AI treasury infrastructure on Stellar/Soroban.
Nirium agents rebalance USDC ↔ CETES (tokenized Mexican T-bills via Etherfuse) 24/7 without human intervention. Built for developers who want to integrate autonomous treasury management, agentic payments (x402 + MPP), and real-time market signals into their applications.
Install
pip install nirium
Quick Start
import asyncio
from nirium import Agent
agent = Agent(
api_url="https://api.nirium.xyz",
api_key="sk_inst_your_key_here",
)
async def main():
# Health check
alive = await agent.ping()
print(f"Agent alive: {alive}")
# Real market data from Stellar Horizon
market = await agent.get_market()
print(f"XLM Price: ${market['xlmPrice']:.4f}")
# Execute a treasury rebalance strategy
result = await agent.execute("blend-yield", "USDC", {"amount": 5000})
print(f"Success: {result['success']} | TX: {result.get('txHash')}")
asyncio.run(main())
Real-Time Signals (WebSocket)
agent = Agent(api_url="https://api.nirium.xyz", api_key="sk_inst_...", token="eyJhbG...")
@agent.on("signal")
async def on_signal(data):
print(f"Signal: {data['signal_type']} — {data['data']['details']}")
asyncio.run(agent.subscribe())
Authentication
# API Key for REST endpoints
agent = Agent(api_url="https://api.nirium.xyz", api_key="sk_inst_...")
# With JWT token for WebSocket
agent = Agent(api_url="https://api.nirium.xyz", api_key="sk_inst_...", token="eyJhbG...")
Payment Protocols
x402 — Pay-Per-Request
agent.init_x402(
secret_key="S...", # Stellar secret key
network="stellar:testnet"
)
response = await agent.x402_fetch("https://api.nirium.xyz/api/v1/premium/signals")
MPP — Session-Based Budget Delegation
agent.init_mpp(
secret_key="S...",
network="stellar:testnet",
)
response = await agent.mpp_fetch("https://api.nirium.xyz/api/v1/mpp/signals")
Endpoint Access Model
| Access | Endpoints |
|---|---|
| Public (no key) | health, loop/status, execute-demo, signals/recent, skills list |
| Protected (API key) | execute, market, loop/start|stop|scan, subscriptions, skills/install, webhooks |
| WebSocket (JWT) | /ws/signals — real-time signal stream |
| x402 Premium | /api/v1/premium/signals ($0.02 USDC), /api/v1/premium/market ($0.05 USDC) |
| MPP | /api/v1/mpp/signals, /api/v1/mpp/market |
API Coverage
| Category | Methods |
|---|---|
| Health | ping(), health(), system_health() |
| Execution | execute(), execute_demo() |
| Market | get_tickers(), get_market(), get_stats(), get_loop_status(), start_loop(), stop_loop(), trigger_scan() |
| Signals | create_subscription(), get_subscriptions(), delete_subscription(), get_subscription_stats(), get_recent_signals() |
| Skills | get_skills(), install_skill(), uninstall_skill(), get_skill_marketplace(), execute_skill_action() |
| Strategies | get_strategies() |
| Webhooks | register_webhook(), get_webhooks(), delete_webhook(), test_webhook() |
| Auth | get_auth_token(), create_auth_key(), get_auth_keys(), revoke_auth_key() |
| Revenue | get_revenue(), get_info() |
| Admin | configure_llm() |
| WebSocket | subscribe(), on() decorator |
| x402 Payments | init_x402(), x402_fetch() |
| MPP Payments | init_mpp(), mpp_fetch() |
Requirements
- Python >= 3.10
- aiohttp >= 3.9.0
- websockets >= 13.0
Links
License
MIT — Nirium Protocol
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
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 nirium-0.6.1.tar.gz.
File metadata
- Download URL: nirium-0.6.1.tar.gz
- Upload date:
- Size: 9.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
250ca8d93f97812fd6ef2aef5389c7ad144e7c42fedb0934689c3b9f8ccda5d8
|
|
| MD5 |
338d8b6d703c79f2930a86892d20fb71
|
|
| BLAKE2b-256 |
a9120415bf80c533643986b492042a005c8569e7d65fceeae2ab59dfd837c196
|
File details
Details for the file nirium-0.6.1-py3-none-any.whl.
File metadata
- Download URL: nirium-0.6.1-py3-none-any.whl
- Upload date:
- Size: 8.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e965aa689dbecb9c62bd3ebe37e4e961e49d51ec2f6c93e284b2ef483c65d1aa
|
|
| MD5 |
8cf675e1870405ecf22f30e17661f962
|
|
| BLAKE2b-256 |
9c372f843d88e09553425131d1aef4c97e67165034687ab454358be13284f1e8
|