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-6.0.4.tar.gz (172.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-6.0.4-py3-none-any.whl (511.4 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: workos-6.0.4.tar.gz
  • Upload date:
  • Size: 172.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.7 {"installer":{"name":"uv","version":"0.11.7","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-6.0.4.tar.gz
Algorithm Hash digest
SHA256 b0bfe8fd212b8567422c4ea3732eb33608794033eb3a69900c6b04db183c32d6
MD5 6994c75b8020531f1e8011d6184dee03
BLAKE2b-256 3c2f99fb8718274116c5c146c745755620fd5c5943f78ca52ca9b17e94348286

See more details on using hashes here.

File details

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

File metadata

  • Download URL: workos-6.0.4-py3-none-any.whl
  • Upload date:
  • Size: 511.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.7 {"installer":{"name":"uv","version":"0.11.7","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-6.0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 548668b3702673536f853ba72a7b5bbbc269e467aaf9ac4f477b6e0177df5e21
MD5 300cb96d45910ea9fa92e10f9383a849
BLAKE2b-256 faf1d2ab661e6dc2828a4c73e38f12630c3b109cfe2bc664ab70631c04f0db4b

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