Skip to main content

Accumulate Python SDK (V2/V3 unified) with DevNet-first flows

Project description

OpenDLT Accumulate Python SDK

Python License

Production-ready Python SDK for the Accumulate blockchain protocol. Supports all signature types, V2/V3 API endpoints, and provides a high-level signing API with automatic version tracking.

Features

  • Multi-Signature Support: Ed25519, RCD1, BTC, ETH, RSA-SHA256, ECDSA-SHA256
  • Smart Signing: Automatic signer version tracking with SmartSigner
  • Complete Protocol: All 33 transaction types and account operations
  • Cross-Platform: Pure Python implementation
  • Network Ready: Mainnet, Testnet (Kermit), and local DevNet support

Installation

pip install accumulate-client

Or install from source:

git clone https://github.com/opendlt/accumulate-python.git
cd accumulate-python/unified
pip install -e ".[dev]"

Quick Start

from accumulate_client import AccumulateClient
from accumulate_client.crypto.ed25519 import Ed25519KeyPair
from accumulate_client.signing.smart_signer import SmartSigner

# Connect to Kermit testnet
client = AccumulateClient("https://kermit.accumulatenetwork.io/v3")

# Generate key pair and derive lite account URLs
kp = Ed25519KeyPair.generate()
lid = kp.lite_identity_url()
lta = kp.lite_token_account_url()

print(f"Lite Identity: {lid}")
print(f"Lite Token Account: {lta}")

# Query account
account = client.query(lta)
print(f"Account: {account}")

Smart Signing API

The SmartSigner class handles version tracking automatically:

from accumulate_client import AccumulateClient
from accumulate_client.crypto.ed25519 import Ed25519KeyPair
from accumulate_client.signing.smart_signer import SmartSigner
from accumulate_client.convenience import TxBody

# Connect to testnet
client = AccumulateClient("https://kermit.accumulatenetwork.io/v3")
kp = Ed25519KeyPair.generate()
lid = kp.lite_identity_url()
lta = kp.lite_token_account_url()

# Create SmartSigner - automatically queries and tracks signer version
signer = SmartSigner(
    client=client,
    keypair=kp,
    signer_url=lid,
)

# Sign, submit, and wait for delivery in one call
result = signer.sign_submit_and_wait(
    principal=lta,
    body=TxBody.send_tokens_single(
        to_url="acc://recipient.acme/tokens",
        amount="100000000",  # 1 ACME
    ),
    memo="Payment",
)

if result.success:
    print(f"Transaction delivered: {result.txid}")

Supported Signature Types

Type Key Pair Class Use Case
Ed25519 Ed25519KeyPair Default, recommended
RCD1 RCD1KeyPair Factom compatibility
BTC Secp256k1KeyPair Bitcoin ecosystem
ETH Secp256k1KeyPair Ethereum ecosystem
RSA-SHA256 RsaKeyPair Enterprise/legacy systems
ECDSA-SHA256 EcdsaKeyPair P-256 curve operations

Transaction Builders

Build transactions using the TxBody class:

from accumulate_client.convenience import TxBody

# Send tokens
TxBody.send_tokens_single(to_url="acc://...", amount="100000000")

# Add credits
TxBody.add_credits(recipient="acc://...", amount=1000000, oracle=oracle_price)

# Create ADI
TxBody.create_identity(url="acc://my-adi.acme", key_book_url="acc://my-adi.acme/book", public_key_hash=key_hash)

# Create token account
TxBody.create_token_account(url="acc://my-adi.acme/tokens", token_url="acc://ACME")

# Create custom token
TxBody.create_token(url="acc://my-adi.acme/mytoken", symbol="MTK", precision=8)

# Write data
TxBody.write_data(entries_hex=[data_hex])

Network Endpoints

from accumulate_client import AccumulateClient

# Public networks
mainnet = AccumulateClient("https://mainnet.accumulatenetwork.io/v3")
testnet = AccumulateClient("https://kermit.accumulatenetwork.io/v3")

# Local development
devnet = AccumulateClient("http://localhost:26660/v3")

Examples

See examples/ for complete working examples:

Example Description
example01_lite_identities.py Lite identity and token account operations
example02_accumulate_identities.py ADI creation
example03_adi_token_accounts.py ADI token account management
example04_data_accounts.py Data account operations
example05_send_acme_adi_to_adi.py ADI-to-ADI transfers
example06_custom_tokens.py Custom token creation
example09_key_management.py Key page and key book management
example12_quickstart_demo.py Complete zero-to-hero workflow

Run any example:

python examples/example01_lite_identities.py

Project Structure

src/accumulate_client/
├── api_client.py      # V2/V3 API client
├── convenience.py     # TxBody builders and helpers
├── crypto/            # Key pair implementations
├── signing/           # SmartSigner, signature management
├── signers/           # Signature type classes
├── tx/                # Transaction builders
├── types.py           # Protocol types (103 types)
├── enums.py           # Protocol enums (14 enums)
└── runtime/           # URL handling, codecs, validation
examples/
├── example01_*.py     # V3 API examples with SmartSigner
└── ...                # 12 complete workflow examples
tests/
├── unit/              # Unit tests
├── integration/       # Network integration tests
└── conformance/       # Cross-implementation compatibility

Development

Running Tests

pytest tests/                    # All tests
pytest tests/unit/               # Unit tests only
pytest tests/integration/        # Integration tests (requires network)

Code Quality

ruff check src/
mypy src/
ruff format src/

Self-Check

python scripts/selfcheck.py

Expected output:

Status: PASS
Checks: 11/11 passed (100.0%)
Enums=14, Types=103, Signatures=16, Transactions=33, API methods=35

Error Handling

from accumulate_client.api_client import (
    AccumulateAPIError,
    AccumulateNetworkError,
    AccumulateValidationError,
)

try:
    result = client.submit(envelope)
except AccumulateValidationError as e:
    print(f"Validation error: {e}")
except AccumulateNetworkError as e:
    print(f"Network error: {e}")
except AccumulateAPIError as e:
    print(f"API error: {e.code} - {e}")

License

MIT License - see LICENSE for details.

Links

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

accumulate_sdk_opendlt-2.0.2.tar.gz (229.8 kB view details)

Uploaded Source

Built Distribution

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

accumulate_sdk_opendlt-2.0.2-py3-none-any.whl (271.2 kB view details)

Uploaded Python 3

File details

Details for the file accumulate_sdk_opendlt-2.0.2.tar.gz.

File metadata

  • Download URL: accumulate_sdk_opendlt-2.0.2.tar.gz
  • Upload date:
  • Size: 229.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.1

File hashes

Hashes for accumulate_sdk_opendlt-2.0.2.tar.gz
Algorithm Hash digest
SHA256 5e14bc9811580a531648ec47d5c9d2ab6e9bb87cba0f487a86ef3cd44252005f
MD5 73f860900850149c36dc19668f2f5a7d
BLAKE2b-256 0aa721477edd63370abe43cb542a1a9d8efe688c0c03999fac93b8b6008c2555

See more details on using hashes here.

File details

Details for the file accumulate_sdk_opendlt-2.0.2-py3-none-any.whl.

File metadata

File hashes

Hashes for accumulate_sdk_opendlt-2.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 081e60b5dd7e4824c74918625514d78e0d396bfe70d979a758a544f098eb4ed3
MD5 87101d4520b60c6edccc3e9c91b20d6a
BLAKE2b-256 b478503dc09ad565d2a5d6e3a0751475a9604e32eb82535f8959642367537e10

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