Mycelium on-chain agent SDK (signing, contract calls, hive discovery, x402)
Project description
Mycelium SDK
The Mycelium SDK provides a clean, Python-first interface for orchestrating autonomous agents, verifying cryptographically signed payloads, querying the Swarm Hive Registry, and settling M2M payments via the x402 Commerce Protocol on the Stellar/Soroban network.
Installation
The SDK can be installed directly from PyPI (or via the wrapper mycelium-stellar package):
pip install mycelium-sdk
Core Architecture
The SDK handles all off-chain agent logic, cryptography, AI orchestration, and RPC interactions with Soroban.
┌──────────────────────────────┐
│ AI Framework │
│ (LangGraph/Gemini/etc.) │
└──────────────┬───────────────┘
│
▼
┌──────────────────────────────┐
│ Mycelium SDK │
│ (AgentContext & HiveClient) │
└──────────────┬───────────────┘
│
▼
┌──────────────────────────────┐
│ Stellar Soroban Network │
│ (RPC, Ledger Queries) │
└──────────────────────────────┘
Primary APIs
1. AgentContext
Manages on-chain identity, cryptographic keypairs, and transaction orchestration.
AgentContext(keypair_path: str, network_type: str = "testnet")- Loads an encrypted wallet keypair from local storage.
AgentContext.read_only(network_type: str = "testnet")- Initializes a read-only context (does not require a keypair; ideal for registry scans).
AgentContext.from_keypair(keypair: Keypair, network_type: str = "testnet")- Initializes a context from an in-memory
stellar_sdk.Keypairobject.
- Initializes a context from an in-memory
call_contract(contract_id: str, function_name: str, args: list, send: bool = False)- Invokes an on-chain smart contract function.
acall_contract(contract_id: str, function_name: str, args: list)- Asynchronous contract invocation wrapper.
2. HiveClient
Interfaces with the on-chain Hive Registry to register, discover, and resolve agents.
register_agent(name: str, capability_hash: str, endpoint: str)- Registers the agent's unique name, capabilities, and HTTPS service endpoint.
resolve_agent(name: str) -> dict- Resolves an agent name to its public address, capabilities, endpoint, and reputation.
lookup_partner_agent(capability: str) -> list[dict]- Scans the ledger to discover agents matching a specific service capability.
3. EscrowPaymentRouter (x402 Commerce)
Manages multi-agent escrow settlements and trustless commerce routing.
create_locked_escrow(recipient: str, amount: str, token: str = None) -> str- Locks funds on-chain under an escrow contract router.
release_escrow(escrow_id: str, signature: str)- Releases locked funds to the recipient agent after cryptographic validation.
refund_escrow(escrow_id: str)- Reclaims locked funds after a predetermined expiry period.
- Note:
EscrowPaymentManageris maintained as a backward-compatible alias.
4. run_agent_loop
Executes autonomous agent orchestration loops wired to cloud LLM APIs (Anthropic, Gemini, etc.) and exposes on-chain interactions as executable LLM tools.
Code Example: Autonomous Payment Agent
import os
from mycelium import AgentContext, HiveClient, run_agent_loop, ContractTool
# Load sovereign on-chain identity
context = AgentContext(keypair_path=".mycelium/wallet.json", network_type="testnet")
hive = HiveClient(context)
# On-chain contract ID
CONTRACT_ID = os.environ.get("MYCELIUM_CONTRACT_ID")
def main():
print(f"Agent online as: {context.keypair.public_key}")
# Run the autonomous execution loop
response = run_agent_loop(
"Scan the registry for an agent offering translation capabilities, "
"negotiate a settlement, and execute the payment.",
context=context,
provider="gemini",
model="gemini-1.5-pro",
api_key=os.environ.get("GEMINI_API_KEY"),
contract_id=CONTRACT_ID,
tools=[
ContractTool("increment"),
ContractTool("get_count", read_only=True),
],
hive=hive
)
print(f"Loop Response:\n{response}")
if __name__ == "__main__":
main()
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 mycelium_sdk-0.1.0.tar.gz.
File metadata
- Download URL: mycelium_sdk-0.1.0.tar.gz
- Upload date:
- Size: 45.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5aa50dc669c4073fc0cc574b9fb04e364157f0640871d41a7f7befb77285c7fc
|
|
| MD5 |
2a273438a6a71f4c9fd78c61e38446d5
|
|
| BLAKE2b-256 |
37a15b7f1343bf4873008de7f67aee5d586098174316346e4775e3233822e883
|
File details
Details for the file mycelium_sdk-0.1.0-py3-none-any.whl.
File metadata
- Download URL: mycelium_sdk-0.1.0-py3-none-any.whl
- Upload date:
- Size: 42.1 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 |
c257bc00f1e6c96bb7acbf6fb013270ff3fb8ab12210d95891898fff216f14d9
|
|
| MD5 |
a289672c1dc1eca42aff8830d3f0800b
|
|
| BLAKE2b-256 |
0391c8ff8f104b3e068a3c4acaef7d6947ff638d93fa4f8e45cfe4af1307f73c
|