Skip to main content

WorkOS Python Client

Project description

WorkOS Python Library

PyPI Build Status

The WorkOS library for Python provides convenient access to the WorkOS API from applications written in Python, hosted on PyPI.

Documentation

See the API Reference for Python usage examples.

Installation

pip install workos

Quick Start

from workos import WorkOSClient

client = WorkOSClient(api_key="sk_1234", client_id="client_1234")

# List organizations
page = client.organizations.list_organizations()
for org in page.auto_paging_iter():
    print(org.name)

# Create an organization
org = client.organizations.create_organizations(name="Acme Corp")
print(org.id)

Async Client

Every method has an identical async counterpart:

from workos import AsyncWorkOSClient

async_client = AsyncWorkOSClient(api_key="sk_1234", client_id="client_1234")

page = await async_client.organizations.list_organizations()
async for org in page.auto_paging_iter():
    print(org.name)

Environment Variables

The client reads credentials from the environment when not passed explicitly:

Variable Description
WORKOS_API_KEY WorkOS API key
WORKOS_CLIENT_ID WorkOS client ID
WORKOS_BASE_URL Override the API base URL (defaults to https://api.workos.com/)
WORKOS_REQUEST_TIMEOUT HTTP timeout in seconds (defaults to 60)

Available Resources

The client exposes the full WorkOS API through typed namespace properties:

Property Description
client.sso Single Sign-On connections and authorization
client.organizations Organization management
client.user_management Users, identities, auth methods, invitations
client.directory_sync Directory connections and directory users/groups
client.admin_portal Admin Portal link generation
client.audit_logs Audit log events, exports, and schemas
client.authorization Fine-Grained Authorization (FGA) resources, roles, permissions, and checks
client.webhooks Webhook event verification
client.feature_flags Feature flag evaluation
client.api_keys Organization API key management
client.connect OAuth application management
client.widgets Widget session tokens
client.multi_factor_auth MFA enrollment and verification (also available as client.mfa)
client.pipes Data Integrations
client.radar Radar risk scoring
client.passwordless Passwordless authentication sessions
client.vault Encrypted data vault

Pagination

Paginated endpoints return SyncPage[T] (or AsyncPage[T]) with built-in auto-pagination:

# Iterate through all pages automatically
for user in client.user_management.list_users().auto_paging_iter():
    print(user.email)

# Or work with a single page
page = client.user_management.list_users(limit=10)
print(page.data)        # List of items on this page
print(page.has_more())  # Whether more pages exist
print(page.after)       # Cursor for the next page

Error Handling

All API errors map to typed exception classes with rich context:

from workos._errors import NotFoundError, RateLimitExceededError

try:
    client.organizations.get_organization("org_nonexistent")
except NotFoundError as e:
    print(f"Not found: {e.message}")
    print(f"Request ID: {e.request_id}")
except RateLimitExceededError as e:
    print(f"Retry after: {e.retry_after} seconds")
Exception Status Code
BadRequestError 400
AuthenticationError 401
AuthorizationError 403
NotFoundError 404
ConflictError 409
UnprocessableEntityError 422
RateLimitExceededError 429
ServerError 5xx

Per-Request Options

Every method accepts request_options for per-call overrides:

result = client.organizations.list_organizations(
    request_options={
        "timeout": 10,
        "max_retries": 5,
        "extra_headers": {"X-Custom": "value"},
        "idempotency_key": "my-key",
        "base_url": "https://staging.workos.com/",
    }
)

Type Safety

This SDK ships with full type annotations (py.typed / PEP 561) and works with mypy, pyright, and IDE autocompletion out of the box. All models are @dataclass(slots=True) classes with from_dict() / to_dict() for serialization.

SDK Versioning

WorkOS follows Semantic Versioning. Breaking changes are only released in major versions. We strongly recommend reading changelogs before making major version upgrades.

Beta Releases

WorkOS has features in Beta that can be accessed via Beta releases. We would love for you to try these and share feedback with us before these features reach general availability (GA). To install a Beta version, please follow the installation steps above using the Beta release version.

Note: there can be breaking changes between Beta versions. We recommend pinning the package version to a specific version.

More Information

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

workos-8.1.0.tar.gz (194.2 kB view details)

Uploaded Source

Built Distribution

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

workos-8.1.0-py3-none-any.whl (572.4 kB view details)

Uploaded Python 3

File details

Details for the file workos-8.1.0.tar.gz.

File metadata

  • Download URL: workos-8.1.0.tar.gz
  • Upload date:
  • Size: 194.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.21 {"installer":{"name":"uv","version":"0.11.21","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for workos-8.1.0.tar.gz
Algorithm Hash digest
SHA256 ff6583bdc55a10ceed2c66a528c7864a21fb7f3563c42ee30e3cabf66188f216
MD5 65e91a7fd2c097b3c380c59c5fa257c5
BLAKE2b-256 90a531244fef7e1c0f26199b947e6bbc85864598ef8ba4975cec1937addc2e97

See more details on using hashes here.

File details

Details for the file workos-8.1.0-py3-none-any.whl.

File metadata

  • Download URL: workos-8.1.0-py3-none-any.whl
  • Upload date:
  • Size: 572.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.21 {"installer":{"name":"uv","version":"0.11.21","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for workos-8.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 22253fe064c1befbfce87680bcf5f6d7fdc0368671291b7118079faf8c094927
MD5 ed2d428755c71bb9e4cbc908cf535894
BLAKE2b-256 03d60f21073fd9e10ed20d9350a653b662baf4b15ff8c0645b827ddb7682a318

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