Skip to main content

Production-ready Python reference SDK for OpenWOP v1.0 compliant servers.

Project description

openwop-client — Python SDK for the Multi-Agent Workflow Orchestration Protocol

openwop is an open, wire-level protocol for multi-agent workflow orchestration — a single contract for runs in which LLM agents, deterministic tools, sub-workflows, and human reviewers collaborate, with durable suspend / resume, replay, version negotiation, and observability owned by the protocol itself. This package is the reference Python client: synchronous, zero runtime deps, typed dataclasses for every spec'd REST endpoint plus a pure-stdlib SSE iterator.

pip install openwop-client

Spec: github.com/openwop/openwop · Status: FINAL v1 (2026-04-27) · Mirrors: the TypeScript SDK at sdk/typescript/

This SDK is hand-authored rather than codegen'd from OpenAPI. Same rationale as the TypeScript SDK — see sdk/typescript/README.md §rationale.


Quickstart

New here? QUICKSTART.md is a 5-minute end-to-end walkthrough that boots the in-memory reference host on your laptop and runs a workflow against it. No managed-service setup. The snippet below is the same flow against an arbitrary OpenWOP host.

from openwop_client import (
    OpenwopClient,
    CreateRunRequest,
    ForkRunRequest,
    ResolveInterruptRequest,
)

client = OpenwopClient(
    base_url="https://api.example.com",
    api_key="hk_test_abc123",
)

# Discovery (no auth required)
caps = client.discovery_capabilities()
print(caps.protocolVersion, caps.limits.envelopesPerTurn)

# Run lifecycle
resp = client.runs_create(CreateRunRequest(workflowId="my-wf", inputs={"foo": "bar"}))
run_id = resp.runId

# Poll for completion (or use SSE — see below)
while True:
    snap = client.runs_get(run_id)
    if snap.status in {"completed", "failed", "cancelled"}:
        break
    import time; time.sleep(0.5)

# HITL approval (run-scoped)
client.interrupts_resolve_by_run(
    run_id, "gate",
    ResolveInterruptRequest(resumeValue={"action": "accept"}),
)

# Replay / fork
fork = client.runs_fork(run_id, ForkRunRequest(fromSeq=5, mode="branch"))

# SSE stream (synchronous generator)
for event in client.runs_events(run_id, stream_mode="updates"):
    print(event.type, event.payload)

Install (dev, from local checkout)

cd sdk/python
python -m venv .venv && source .venv/bin/activate
pip install -e .[dev]

What's Covered In v1.0

Endpoint SDK method
GET /.well-known/openwop client.discovery_capabilities()
GET /v1/openapi.json client.discovery_openapi()
GET /v1/workflows/{id} client.workflows_get(id)
POST /v1/runs client.runs_create(body, idempotency_key=..., dedup=...)
GET /v1/runs/{id} client.runs_get(id)
GET /v1/runs/{id}/events (SSE) client.runs_events(id, stream_mode=...) (sync generator)
GET /v1/runs/{id}/events/poll client.runs_poll_events(id, last_sequence=..., timeout_seconds=...)
POST /v1/runs/{id}/cancel client.runs_cancel(id, body=..., idempotency_key=...)
POST /v1/runs:bulk-cancel client.runs_bulk_cancel(body, idempotency_key=...)
POST /v1/runs/{id}:pause client.runs_pause(id, body=..., idempotency_key=...)
POST /v1/runs/{id}:resume client.runs_resume(id, body=..., idempotency_key=...)
POST /v1/runs/{id}:fork client.runs_fork(id, body, idempotency_key=...)
POST /v1/runs/{id}/interrupts/{nodeId} client.interrupts_resolve_by_run(id, node_id, body)
GET /v1/interrupts/{token} client.interrupts_inspect_by_token(token)
POST /v1/interrupts/{token} client.interrupts_resolve_by_token(token, body)
GET /v1/audit/verify client.audit_verify(from_seq, to_seq)

Idempotency-Key is supported via the idempotency_key= keyword argument on every mutation method.

Trace-ID surfacing: WopError captures the W3C traceparent from response headers and exposes error.trace_id (32-hex). str(error) auto-suffixes (trace=<id>) so logs are searchable against backend traces per observability.md §Trace context propagation.

Error Handling

from openwop_client import HTTP_ERROR_CODES, WopError, is_http_error_code

try:
    client.runs_create(CreateRunRequest(workflowId="my-wf"))
except WopError as error:
    if error.envelope and is_http_error_code(error.envelope.error):
        print(error.envelope.error, error.envelope.details)

HTTP_ERROR_CODES is the canonical REST/MCP error-envelope vocabulary (unauthenticated, validation_error, run_already_active, etc.). Contextual fields live under ErrorEnvelope.details; for example retry hints are details["retryAfter"], not a top-level response field.


v1.x Additions

Feature Why
Async client (AsyncOpenwopClient via httpx) Sync stdlib API is the v1.0 baseline; async needs a non-stdlib HTTP lib.
Webhook subscription helpers v1 specifies webhook delivery, but the SDK keeps endpoint coverage focused on the run lifecycle and conformance-critical surfaces.
Hosted registry publishing helpers Node-pack registry publishing needs operator-specific credentials and policy; use direct HTTP until a dedicated package workflow is warranted.
Auto-retry with exponential backoff Retry policy is application-specific. The SDK exposes structured errors so callers can implement their own retry envelope.

Layout

sdk/python/
  README.md                 — this file
  pyproject.toml            — PEP 621 packaging (hatchling)
  src/openwop_client/
    __init__.py             — public exports + __version__
    types.py                — dataclasses + Literal aliases
    errors.py               — WopError (with traceparent capture)
    client.py               — OpenwopClient sync API
    sse.py                  — generator-based SSE consumer (pure stdlib)

Versioning

Tracks the OpenWOP protocol major. The v1 SDK line is intended to remain backward-compatible across v1.x releases, with additive features and bug fixes landing as minor or patch releases.

References

  • Spec corpus: ../../README.md
  • OpenAPI: ../../api/openapi.yaml (the SDK mirrors this surface)
  • AsyncAPI: ../../api/asyncapi.yaml (the SSE consumer follows these channels)
  • TypeScript counterpart: ../typescript/
  • ../PARITY.md — cross-SDK feature-parity matrix (TS/Python/Go).
  • ../smoke/ — runnable wire-smoke scripts against a reference host.

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

openwop_client-1.1.7.tar.gz (41.3 kB view details)

Uploaded Source

Built Distribution

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

openwop_client-1.1.7-py3-none-any.whl (39.7 kB view details)

Uploaded Python 3

File details

Details for the file openwop_client-1.1.7.tar.gz.

File metadata

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

File hashes

Hashes for openwop_client-1.1.7.tar.gz
Algorithm Hash digest
SHA256 05f22cfa1a3feafbb92c83d79b3b8bb131a8a039a5ae67a34afe847e1c7d6fb5
MD5 4b054da5bc5502691d47c021322f1066
BLAKE2b-256 3383479e13d5b760a3b3d934914f9f7b8cbf97f672bd105306bf91b639ee1059

See more details on using hashes here.

Provenance

The following attestation bundles were made for openwop_client-1.1.7.tar.gz:

Publisher: openwop-publish.yml on openwop/openwop

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

File details

Details for the file openwop_client-1.1.7-py3-none-any.whl.

File metadata

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

File hashes

Hashes for openwop_client-1.1.7-py3-none-any.whl
Algorithm Hash digest
SHA256 a3cfb16f5458b9da79dac89cbe9851ff962a063a693cc470275c8d88030dd9b0
MD5 e1396726807bd4aa65835661f2a747af
BLAKE2b-256 3183d00abf02c0feed9668ee12939ae005e5edcd911ce35b4f9c79619823c2b1

See more details on using hashes here.

Provenance

The following attestation bundles were made for openwop_client-1.1.7-py3-none-any.whl:

Publisher: openwop-publish.yml on openwop/openwop

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