Skip to main content

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
from enact_protocol import (
    EnactClient,
    AgenticWalletProvider,
    generate_agent_keypair,
)

async def main():
    # 1. Generate an operator keypair (open the deeplink and mint the wallet,
    #    then fund it before continuing).
    kp = generate_agent_keypair("my-agent")
    print("Mint your wallet here:", kp["create_deeplink"])

    # 2. After minting, plug the operator key + agentic wallet address in.
    async with EnactClient(api_key="YOUR_TONCENTER_KEY") as client:
        client._agentic_wallet = AgenticWalletProvider(
            operator_secret_key=bytes.fromhex(kp["secret_key_hex"]),
            agentic_wallet_address="EQ...",  # from agents.ton.org after mint
            client=client._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())

Or pass it on the constructor:

agentic = AgenticWalletProvider(
    operator_secret_key=bytes.fromhex(secret_hex),
    agentic_wallet_address="EQ...",
    client=existing_toncenter_client,  # or pass any ToncenterV2Client
)

async with EnactClient(api_key="...", agentic_wallet=agentic) as client:
    ...

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

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

enact_protocol-0.2.0.tar.gz (21.2 kB view details)

Uploaded Source

Built Distribution

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

enact_protocol-0.2.0-py3-none-any.whl (26.7 kB view details)

Uploaded Python 3

File details

Details for the file enact_protocol-0.2.0.tar.gz.

File metadata

  • Download URL: enact_protocol-0.2.0.tar.gz
  • Upload date:
  • Size: 21.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.9

File hashes

Hashes for enact_protocol-0.2.0.tar.gz
Algorithm Hash digest
SHA256 8447da68a65ebcf2e608e02740243cdc4dbe84427314d3224017453eb44bbfa8
MD5 0254919a5df4d44f66fb2514cc080d53
BLAKE2b-256 df44a1809c282837da770a38c89aabab014df7c11ffcbb3ed05be39d15fa0e8a

See more details on using hashes here.

File details

Details for the file enact_protocol-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: enact_protocol-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 26.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.9

File hashes

Hashes for enact_protocol-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 d360d1022b0b6953ba5f6b0b8b8b073de3dede76a96d2c40f2654557fa47a7b7
MD5 6cbd4cf06f6bfb9f140da38cf6568f84
BLAKE2b-256 f9bcd9f39ecf11f8e1b80c811a6970109ef9437d0cce40d7806d8e639757d3f7

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