Capability Exchange Protocol
Project description
CXP: Capability Exchange Protocol
CXP is a semantic interoperability protocol for software components. It allows libraries, runtimes, and services to publish their capabilities and telemetry through a small shared contract.
Why CXP?
Modern components are often black boxes. CXP gives them two explicit surfaces:
- Capabilities: So an orchestrator can understand what a component can do.
- Telemetry: So an orchestrator can observe what is happening at runtime.
CXP acts as a semantic bridge, allowing tools like AI agents, test runners, or orchestrators to operate against a shared contract instead of provider-specific assumptions.
Design Goals
- Small Core: Keep the protocol surface narrow and stable.
- High Fidelity: Support expressive catalogs with metadata schemas, shared DTOs, and structured telemetry vocabularies.
- Data-Oriented: Exchange typed data using
msgspecfor high performance. - Omnichannel: From cloud runtimes (ASGI/SQL) to industrial hardware (Zebra/Konica).
Installation
pip install cxp
Catalog Layers
CXP includes a growing suite of first-party catalogs organized in six logical layers:
Each layer exposes a family catalog (the abstract contract) plus one or more concrete catalogs that satisfy it.
- Computing:
execution/plan-run,runtime/environment(secrets/resources), and theapplication/httpfamily with concreteapplication/asgi,application/wsgi, andapplication/http-frameworkcatalogs. - Persistence:
database/sql,database/mongodb(both satisfyingdatabase/common),storage/blob,cache/key-value. - Communications:
transport/http(with thetransport/http-familyumbrella andtransport/websocketsibling),messaging/event-bus(concrete:messaging/nats), andnotification/common(concrete:notification/web-push,notification/mobile-push). - Queueing:
queue/task-enginefor background processing. - Experience & Media:
browser/automation(concrete:browser/playwright),media/video-streaming(HLS/DASH). - Industrial:
printing/manager(concrete:printing/labelfor Zebra/ZPL,printing/productionfor Konica Minolta).
For the full list of registered interfaces and operations, see docs/catalogs/index.md.
Quick Start
from cxp import (
Capability,
CapabilityMatrix,
ComponentIdentity,
HandshakeRequest,
get_catalog,
negotiate_with_provider_catalog,
)
# Resolve the standard catalog for the interface
catalog = get_catalog("database/sql")
assert catalog is not None
# Build the orchestrator request
request = HandshakeRequest(
client_identity=ComponentIdentity(
interface="database/sql",
provider="my-orchestrator",
version="1.0.0",
),
required_capabilities=("transactions",),
)
# Negotiate with a provider
# response = negotiate_with_provider_catalog(request, my_sql_provider, catalog)
Key Features
1. Structured Error Reporting (CxpError)
Shared machine-readable error envelopes for catalogs that opt into the semantic layer.
if response.error and response.error.retryable:
# Orchestrator can decide to retry automatically
await retry_operation()
2. High-Fidelity Results
Many first-party operations return structured data defined in results.py (for example HttpResponse, DbCursor, AsyncWorkReport).
3. Bidirectional Validation
Catalogs can define input_schema and result_schema for operations when the domain benefits from explicit request/response contracts.
Documentation
See docs/index.md for the full documentation set:
License
MIT
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file cxp-3.0.0.tar.gz.
File metadata
- Download URL: cxp-3.0.0.tar.gz
- Upload date:
- Size: 91.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
fef5a3743a42de5ee3cd7ee301f9ffe5951c241412b023ab4af7ca1f222b6193
|
|
| MD5 |
89985c55629efa728f2ff33c2f6651aa
|
|
| BLAKE2b-256 |
87795b5ccfd1c3075f3966cf2d290432f74f06e6190221f3bec9a96c14eb1ce6
|
File details
Details for the file cxp-3.0.0-py3-none-any.whl.
File metadata
- Download URL: cxp-3.0.0-py3-none-any.whl
- Upload date:
- Size: 91.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
57d9976fefd692b4acb7bf55879208b43c785415ca42283fbbcd8f2c1daf3f1b
|
|
| MD5 |
6482bbd7d933dfa3c35c440c6acbca30
|
|
| BLAKE2b-256 |
d89ec7f0aeb597e06b40ffe11cd1651fe5195b2267bc81f54fc83ccc74c388cc
|