Skip to main content

Official Python SDK for the SpreadSpace API.

Project description

SpreadSpace Python SDK

Official Python client for the SpreadSpace API — document extraction and financial spreading for lending.

Some examples below require the generated core (built in CI) or a live sandbox key. They are marked [needs sandbox key] / [needs generated core].

Install

pip install spreadspace

Requires Python 3.9+.

Authentication

from spreadspace import SpreadSpace

client = SpreadSpace(api_key="ss_test_...")   # or omit and set SPREADSPACE_API_KEY

The key prefix selects the environment:

  • ss_test_... — routes to your sandbox tenant (seed data, safe to experiment).
  • ss_live_... — routes to your live tenant (real data).

If api_key is omitted, the client reads SPREADSPACE_API_KEY from the environment. Never hard-code a live key; never commit any key.

Client options

client = SpreadSpace(
    api_key="ss_test_...",
    base_url="https://api.spreadspace.ai",   # override for a private deployment
    api_version="2026-05-03",                # pins the SpreadSpace-Version header
    timeout=60.0,                            # seconds, per request
    max_retries=2,                           # 429 + 5xx + transport errors
)

API version pinning

Every request sends a dated SpreadSpace-Version header. The SDK pins a default version per release (decoupled from the SDK's own semver). Pin it explicitly to insulate your integration from server-side changes, and override per call when you need a newer surface:

client.borrowers.list(api_version="2026-06-01")   # one call on a newer version

Pagination (lazy, auto cursor)

List endpoints return a lazy iterator that walks cursors for you — it fetches the next page only as you consume it.

for borrower in client.borrowers.list():
    print(borrower["id"])

# Filters pass straight through and persist across pages:
for job in client.jobs.list(status="completed", limit=50):
    print(job["id"])

Async export + wait

Exports are asynchronous operations. create returns a handle; wait polls to completion (or raises on timeout).

op = client.exports.create(borrower_id="...", format="xlsx")
result = op.wait(timeout=300)   # seconds
print(result["download_url"])

Upload a document + wait for processing

job = client.documents.upload("statement.pdf", borrower_id="...")
final = job.wait(timeout=600)   # seconds
print(final["status"])

The upload helper requests a presigned URL, PUTs the file bytes directly to storage with the matching Content-Type (part of the V4 signature), then returns a job handle you can wait on.

Error handling

All errors derive from SpreadSpaceError. Match on the typed subclass, never on the message string:

from spreadspace import (
    SpreadSpaceError,       # base
    NetworkError,           # transport failure, no HTTP response
    BadRequestError,        # 400
    AuthenticationError,    # 401
    PermissionDeniedError,  # 403
    NotFoundError,          # 404
    ConflictError,          # 409
    RateLimitError,         # 429
    InternalServerError,    # 5xx
)

try:
    client.borrowers.get("missing-id")
except RateLimitError as e:
    print("retry after", e.retry_after, "seconds")
except NotFoundError as e:
    print("not found")
except SpreadSpaceError as e:
    # Every error carries request_id — quote it in support tickets.
    print(e.message, e.status_code, e.request_id)

request_id comes from the X-Request-ID response header (falling back to the error body). Transient failures (429, 5xx, transport errors) are retried automatically up to max_retries with exponential backoff + full jitter, honoring Retry-After.

Money is exact

Monetary values decode as decimal.Decimal, not float — the SDK reads the literal digits off the wire, so amounts are exact with no float rounding:

b = client.borrowers.get("...")          # [needs sandbox key]
assert b["total_revenue"] == Decimal("1234.56")   # never 1234.5600000000001

Development

The generated OpenAPI core lives in src/spreadspace/_generated/ and is built in CI (scripts/generate.sh, Java-based — not run locally). It is gitignored and must never be hand-edited. The hand-written ergonomic layer (transport, helpers, typed errors) is the only code committed by hand.

pip install -e '.[dev]'
pytest

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

spreadspace-0.1.1.tar.gz (33.6 kB view details)

Uploaded Source

Built Distribution

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

spreadspace-0.1.1-py3-none-any.whl (25.1 kB view details)

Uploaded Python 3

File details

Details for the file spreadspace-0.1.1.tar.gz.

File metadata

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

File hashes

Hashes for spreadspace-0.1.1.tar.gz
Algorithm Hash digest
SHA256 c4bdd0145649386f24731cf1d14984ada4fefbd44b1b39f046eae97f7d811c3c
MD5 6f0c5017333ac6941873921ae7ff0584
BLAKE2b-256 16c835cecaa01f965e44e7e3565b70deb3679f0356078cca1e094b04aa885dcb

See more details on using hashes here.

Provenance

The following attestation bundles were made for spreadspace-0.1.1.tar.gz:

Publisher: sdk.yml on DocDissect/DocDissectOfficial

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

File details

Details for the file spreadspace-0.1.1-py3-none-any.whl.

File metadata

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

File hashes

Hashes for spreadspace-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 10038ff96faece36d3250d0228f073bab47321b45a47e1032a2e1b152ef00a5c
MD5 2dbc2f9a8e04add150f598d4af3cd77d
BLAKE2b-256 327b84fe5af857f72bd5a010102c920d9efe26d9c47d112628c40e99ffcf8af3

See more details on using hashes here.

Provenance

The following attestation bundles were made for spreadspace-0.1.1-py3-none-any.whl:

Publisher: sdk.yml on DocDissect/DocDissectOfficial

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