Skip to main content

Official Python SDK for the OpenSettle API. Stablecoin billing on Base, Ethereum, Polygon, Arbitrum, Solana, and Tron.

Project description

opensettle

Official Python SDK for the OpenSettle API.

Non-custodial stablecoin billing on Base, Ethereum, Polygon, Arbitrum, Solana and Tron. Typed end-to-end, sync and async, signed-webhook verifier included, idempotent writes by default.

Install

pip install opensettle

Requires Python 3.9+.

Conventions

  • Method names are snake_case (Python idiom): os.customers.create(...).
  • Body fields and response keys are camelCase, matching the API's wire format exactly. Pass customerEmail=... not customer_email=.... Read result["createdAt"] not result["created_at"]. Zero translation, no surprises.

Quickstart

from opensettle import OpenSettle

os = OpenSettle(
    api_key="sk_test_…",      # or os.environ["OPENSETTLE_KEY"]
    workspace_id="ws_…",       # or os.environ["OPENSETTLE_WORKSPACE"]
)

# 1. Create a customer.
customer = os.customers.create(
    email="ada@example.com",
    name="Ada Lovelace",
    country="GB",
)
print(customer["id"])           # cus_…
print(customer["createdAt"])    # ISO-8601

# 2. Create a product + price.
product = os.products.create(name="Pro plan")
price = os.products.create_price(
    product["id"],
    amount=19_900,              # minor units
    currency="USD",
    interval="month",
)

# 3. Start a hosted-checkout subscription.
checkout = os.checkouts.create(
    mode="subscription",
    customerId=customer["id"],
    priceId=price["id"],
    chain="base",
    token="USDC",
    successUrl="https://merchant.com/ok",
    cancelUrl="https://merchant.com/cancel",
)
print(checkout["hostedUrl"])    # link to send the customer

Async

import asyncio
from opensettle import AsyncOpenSettle

async def main() -> None:
    async with AsyncOpenSettle(api_key="sk_test_…", workspace_id="ws_…") as os:
        customer = await os.customers.create(email="ada@example.com")
        print(customer["id"])

asyncio.run(main())

Webhooks

from opensettle import verify_webhook, WebhookVerificationError

@app.post("/webhooks/opensettle")
async def handler(request):
    raw = await request.body()
    try:
        event = verify_webhook(
            raw_body=raw,
            signature_header=request.headers.get("x-opensettle-signature"),
            secret=os.environ["WHSEC"],
        )
    except WebhookVerificationError as e:
        return Response(status=400, content=f"bad signature: {e.reason}")
    # event.data is the decoded JSON; event.timestamp is the signed epoch
    return Response(status=200)

Error handling

from opensettle import OpenSettle, RateLimitError, SettlementError

try:
    os.payments.refund("pay_…", amountMinor=500)
except RateLimitError as e:
    time.sleep(e.retry_after or 1)
    retry()
except SettlementError as e:
    if e.code == "insufficient_confirmations":
        wait_and_retry()

The full error hierarchy:

OpenSettleError
├── InvalidRequestError
├── InvalidStateTransitionError
├── AuthenticationError
├── ForbiddenError
├── NotFoundError
├── ConflictError
├── RateLimitError              # carries `retry_after: float | None`
├── SettlementError             # chain_reverted | insufficient_confirmations | signing_required
├── StepUpRequiredError         # aal_required
├── APIError                    # internal_error or forward-compat unknown codes
└── NetworkError                # transport-layer / timeout

Every error carries code, status, request_id, and param so you can quote the request ID in support tickets.

Configuration

os = OpenSettle(
    api_key="sk_test_…",
    workspace_id="ws_…",
    base_url="https://api.opensettle.io",   # default; override for self-host
    test_mode=None,                          # None | True | False env-assertion gate
    timeout=30.0,                            # seconds; default 30s
    max_network_retries=3,                   # 0 to disable retries
)

test_mode=True refuses sk_live_… keys; test_mode=False refuses sk_test_…. Leave None to accept either and let the API decide.

Resources

Resource Methods
customers list, retrieve, create, update, delete
products list, retrieve, create, update, list_prices, create_price, update_price, delete, delete_price
invoices list, retrieve, create, send, remind, void
payments list, retrieve, refund, refund_broadcast
subscriptions list, retrieve, create, pause, resume, cancel, change_plan
checkouts create, retrieve
webhook_endpoints list, retrieve, create, update, delete, rotate_secret, test

License

MIT — see LICENSE.

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

opensettle-0.3.0.tar.gz (43.0 kB view details)

Uploaded Source

Built Distribution

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

opensettle-0.3.0-py3-none-any.whl (31.5 kB view details)

Uploaded Python 3

File details

Details for the file opensettle-0.3.0.tar.gz.

File metadata

  • Download URL: opensettle-0.3.0.tar.gz
  • Upload date:
  • Size: 43.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for opensettle-0.3.0.tar.gz
Algorithm Hash digest
SHA256 cdd5793e1472f346c5c25e1bb04fc4ec2961cfc0dcfdb92df4e8a3749ebb1095
MD5 3313d5e5311339956f377309c454504f
BLAKE2b-256 c895244dd5b72c2c91ab09c96cd12bd60e60dd854fc5a0c5286a2f3b7f8bc6dd

See more details on using hashes here.

Provenance

The following attestation bundles were made for opensettle-0.3.0.tar.gz:

Publisher: publish.yml on OpenSettle/opensettle-sdk-python

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file opensettle-0.3.0-py3-none-any.whl.

File metadata

  • Download URL: opensettle-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 31.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for opensettle-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 6705389fd8c172e60f585df1081463851c02644a0b93f3f0e79fa39a968e7352
MD5 74936bc519fcaa83256a04ac1caabc0b
BLAKE2b-256 3bb40d7041f3d02ca68fa673662c360296a52235d328325bd8565ad8fd4dbfb2

See more details on using hashes here.

Provenance

The following attestation bundles were made for opensettle-0.3.0-py3-none-any.whl:

Publisher: publish.yml on OpenSettle/opensettle-sdk-python

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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