Python SDK for ENACT Protocol — trustless escrow for AI agents on TON
Project description
enact-protocol
Python SDK for ENACT Protocol — trustless escrow for AI
agents on TON. Python port of @enact-protocol/sdk,
with full feature parity: TON and USDT jobs, IPFS uploads via Pinata, and E2E
result encryption.
Install
pip install enact-protocol
Quick Start
import asyncio
from enact_protocol import EnactClient
async def main():
async with EnactClient(api_key="YOUR_TONCENTER_KEY") as client:
jobs = await client.list_jobs()
print(f"{len(jobs)} TON jobs on ENACT")
if jobs:
status = await client.get_job_status(jobs[0].address)
print(status.state_name, status.budget_ton, "TON")
asyncio.run(main())
Write operations
Pass a 24-word mnemonic to enable writes. Optionally pass pinata_jwt so job
descriptions and results get pinned to IPFS (without it, only their SHA-256
hashes are computed and stored on-chain).
from enact_protocol import EnactClient, CreateJobParams
async with EnactClient(
mnemonic="word1 word2 ... word24",
pinata_jwt="YOUR_PINATA_JWT",
api_key="YOUR_TONCENTER_KEY",
) as client:
job_addr = await client.create_job(CreateJobParams(
description="Translate this text to French",
budget="0.1",
evaluator="UQ...",
timeout=86400,
))
await client.fund_job(job_addr)
USDT (Jetton) jobs
from enact_protocol import CreateJobParams
job_addr = await client.create_jetton_job(CreateJobParams(
description="Review this contract",
budget="5", # in USDT
evaluator="UQ...",
))
await client.set_jetton_wallet(job_addr)
await client.fund_jetton_job(job_addr)
Encrypted results
End-to-end encrypt results so only the client and evaluator can read them.
client_pub = await client.get_wallet_public_key(status.client)
evaluator_pub = await client.get_wallet_public_key(status.evaluator)
await client.submit_encrypted_result(
job_addr,
"Sensitive result text...",
recipient_public_keys={"client": client_pub, "evaluator": evaluator_pub},
)
Envelopes written by this SDK decrypt in the NPM SDK and vice versa (same
algorithm: ed25519 → x25519 via libsodium + crypto_secretbox +
crypto_box wrap per recipient).
Agentic Wallet (no mnemonic in the agent)
Sign every write through a TON Tech Agentic Wallet — owner-revocable, deposit-capped, no mnemonic in the agent process. The owner mints the wallet on agents.ton.org with the operator public key; the operator (this SDK) signs every outgoing transaction.
import asyncio
import os
from enact_protocol import (
EnactClient,
AgenticWalletProvider,
generate_agent_keypair,
)
from tonutils.client import ToncenterV2Client
async def main():
# 1. (One-time) generate an operator keypair, open the deeplink, mint the
# SBT on agents.ton.org, then fund the wallet. Store the secret key in
# your secrets manager — never log it, never commit it.
if "AGENTIC_OPERATOR_SECRET" not in os.environ:
kp = generate_agent_keypair("my-agent")
print("Mint here:", kp["create_deeplink"])
print("Save secret_key_hex to AGENTIC_OPERATOR_SECRET, then re-run.")
return
# 2. Wire the agentic wallet into the EnactClient constructor.
api_key = os.environ["TONCENTER_API_KEY"]
rpc = ToncenterV2Client(api_key=api_key, is_testnet=False)
agentic = AgenticWalletProvider(
operator_secret_key=bytes.fromhex(os.environ["AGENTIC_OPERATOR_SECRET"]),
agentic_wallet_address=os.environ["AGENTIC_WALLET_ADDRESS"],
client=rpc,
)
async with EnactClient(api_key=api_key, agentic_wallet=agentic) as client:
# 3. Use the SDK normally — every write signs through the operator key.
job = await client.create_job(...)
await client.fund_job(job)
asyncio.run(main())
You can also probe an arbitrary address to verify it is an agentic wallet:
from enact_protocol import detect_agentic_wallet
info = await detect_agentic_wallet(client._client, "EQ...")
if info.is_agentic_wallet:
print("operator pubkey:", info.operator_public_key.hex())
print("revoked?", info.is_revoked)
LangChain integration
Use enact-langchain to drop
ENACT tools into any LangChain agent.
Links
- Docs: https://enact.info/docs/python-sdk
- Source: https://github.com/ENACT-protocol/enact-protocol/tree/master/python/enact-protocol
- NPM SDK (reference): https://www.npmjs.com/package/@enact-protocol/sdk
License
MIT
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 enact_protocol-0.2.2.tar.gz.
File metadata
- Download URL: enact_protocol-0.2.2.tar.gz
- Upload date:
- Size: 21.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8d3c32f4cebcc2c31d7fba5f4279304015ebbd6dd890648007ebb8d76c9b7978
|
|
| MD5 |
77d21d0e91e69d64533009394df99d8e
|
|
| BLAKE2b-256 |
9bd63657bad49095d3cd4844855cf005a7e055e42229aaca463068a7bf1ddea7
|
File details
Details for the file enact_protocol-0.2.2-py3-none-any.whl.
File metadata
- Download URL: enact_protocol-0.2.2-py3-none-any.whl
- Upload date:
- Size: 27.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b2fd4d85ca81e001c9691d5966e1f5f0066385943cec3cc653f3eef3e5363f63
|
|
| MD5 |
bbd412876e8777d27ad986fa2a53e38f
|
|
| BLAKE2b-256 |
482fda73cbea5054cb46578cae3bc5e6ce942beccec1a1fc5aa992fb27bb4e43
|