Skip to main content

Python API client for the Rossum platform.

Project description

PyPI version Python versions Build Status Coverage Code style: Ruff Documentation MIT licence

rossum-api provides Python programmatic access to the Rossum API and other useful tooling enabling seamless integration of the Rossum platform into Python applications.

It is a replacement for Rossum package. In case of any missing functionality, please open an issue or a pull request.

For comprehensive API reference and detailed examples, visit our documentation.

Key Features

  • Minimal dependencies: Lightweight with minimal external dependencies

  • API-aligned naming: Method names map closely to the official API documentation

  • Dual API support: Choose between synchronous and asynchronous clients

  • Authentication: Built-in authentication handling

  • Retry mechanism: Built-in retry mechanism handling throttling API errors

  • Pagination handling: Automatically merges paginated results into one list

  • Rich methods: Includes methods for frequent API operations

  • Type-safe: Returns results as Python dataclasses with full type hints

Installation

The easiest way is to install the package from PyPI:

pip install rossum-api

or from the github repo:

pip install git+https://github.com/rossumai/rossum-sdk#egg=rossum-api

You can eventually download an installation file from GitHub releases and install it manually.

Usage

Python API

The rossum-api library can be used to communicate with Rossum API, instead of using requests library directly. The advantages of using rossum-api:

  • it contains a function that merges the paginated results into a single list so the user does not need to get results page by page and take care of their merging,

  • it comes with both synchronous and asynchronous API, so you can choose the approach you need,

  • it takes care of authenticating the user,

  • it includes many methods for common actions that you don’t need to write by yourself from scratch,

  • it returns the result as a Python first-class object (dataclass), so you don’t need to parse the JSON by yourself,

  • it maps method naming as close as possible to API docs,

  • in case the API version changes, the change will be implemented in the library by the Rossum team for all users.

  • it has minimal dependencies

Examples

You can choose between asynchronous and synchronous clients. Both are exactly the same in terms of features.

Async version

import asyncio
import os
from rossum_api import AsyncRossumAPIClient
from rossum_api.dtos import UserCredentials

WORKSPACE = {
    "name": "Rossum Client NG Test",
    "organization": "https://elis.rossum.ai/api/v1/organizations/116390",
}


async def main_with_async_client() -> None:
    client = AsyncRossumAPIClient(
        base_url="https://elis.rossum.ai/api/v1",
        credentials=UserCredentials(os.environ["ELIS_USERNAME"], os.environ["ELIS_PASSWORD"]),
    )
    ws = await client.create_new_workspace(data=WORKSPACE)
    workspace_id = ws.id
    ws = await client.retrieve_workspace(workspace_id)
    print("GET result:", ws)
    print("LIST results:")
    async for w in client.list_workspaces(ordering=["-id"], name=WORKSPACE["name"]):
        print(w)
    await client.delete_workspace(workspace_id)
    print(f"Workspace {workspace_id} deleted.")


asyncio.run(main_with_async_client())

Sync version

import os

from rossum_api import SyncRossumAPIClient
from rossum_api.dtos import UserCredentials

WORKSPACE = {
    "name": "Rossum Client NG Test",
    "organization": "https://elis.rossum.ai/api/v1/organizations/116390",
}


def main_with_sync_client() -> None:
    client = SyncRossumAPIClient(
        base_url="https://elis.rossum.ai/api/v1",
        credentials=UserCredentials(os.environ["ELIS_USERNAME"], os.environ["ELIS_PASSWORD"]),
    )
    ws = client.create_new_workspace(data=WORKSPACE)
    workspace_id = ws.id
    ws = client.retrieve_workspace(workspace_id)
    print("GET result:", ws)
    print("LIST results:")
    for w in client.list_workspaces(ordering=["-id"], name=WORKSPACE["name"]):
        print(w)
    client.delete_workspace(workspace_id)
    print(f"Workspace {workspace_id} deleted.")


main_with_sync_client()

Local development

Pull the repository, create a virtual environment, and install the package from the source with test dependencies:

# Create and activate virtual environment
python -m venv .env
source .env/bin/activate

# Install in editable mode with test dependencies
pip install -e .[tests]

We use ruff for linting and formatting. Run all pre-commit hooks with:

pre-commit run --all-files

Or run specific tools:

# Linting and formatting
pre-commit run ruff --all-files
pre-commit run ruff-format --all-files

# Type checking
pre-commit run mypy --all-files

# Run tests
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

rossum_api-3.7.1.tar.gz (155.7 kB view details)

Uploaded Source

Built Distribution

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

rossum_api-3.7.1-py3-none-any.whl (67.9 kB view details)

Uploaded Python 3

File details

Details for the file rossum_api-3.7.1.tar.gz.

File metadata

  • Download URL: rossum_api-3.7.1.tar.gz
  • Upload date:
  • Size: 155.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for rossum_api-3.7.1.tar.gz
Algorithm Hash digest
SHA256 f9c45c8f5f652badfa0c6df0c7405c55118305124776f8d52492d94e82a084e0
MD5 0275758fc9895499e850e2ef6b9ebd19
BLAKE2b-256 f17ecb42cd6a7867fef1b6ae08b2cf9c97e5639b99715f0820d1e11e51af11f4

See more details on using hashes here.

File details

Details for the file rossum_api-3.7.1-py3-none-any.whl.

File metadata

  • Download URL: rossum_api-3.7.1-py3-none-any.whl
  • Upload date:
  • Size: 67.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for rossum_api-3.7.1-py3-none-any.whl
Algorithm Hash digest
SHA256 5e42b1f303077d63ffd6d61bc79e413f12c30ab9a5cb9f1845ac09b8f869bde0
MD5 3043a799563afa3c25d70d9b9de57b02
BLAKE2b-256 8199d9f21698a45474a8341c24254239be4bd22a6ad515846d6dde8f16bf2bbd

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