Messaging abstractions for publisher/consumer workflows with optional RabbitMQ and Kafka extras
Project description
csrd.message
Transport-agnostic message abstractions for publish/consume workflows.
Why this package exists
- Provide a stable API for messaging behavior independent of broker choice
- Enable optional broker installs with extras (
rabbit,kafka) - Keep service code portable across RabbitMQ and Kafka backends
Installation
# Core abstractions only
uv add csrd-message
# RabbitMQ support
uv add 'csrd-message[rabbit]'
# Kafka support
uv add 'csrd-message[kafka]'
# Both brokers
uv add 'csrd-message[all]'
Important extras note
Python extras are part of the same PyPI project, not a separate project.
csrd-messageandcsrd-message[rabbit]resolve to the same package name (csrd-message)- The extra only adds optional dependencies declared by this package
- Extras do not create new package names on PyPI
Initial API surface
Message- immutable message envelopeMessagePublisher- protocol for publishing messagesMessageConsumer- protocol for consuming messagesAcknowledgement- ack/retry/reject semantics
Quick example
from csrd.message import Acknowledgement, Message, MessagePublisher
class InMemoryPublisher:
async def publish(self, message: Message) -> None:
print(message.topic, message.payload)
async def send(publisher: MessagePublisher) -> None:
await publisher.publish(Message(topic="orders.created", payload={"order_id": "o-1"}))
Status
This is a v0 skeleton package to reserve naming and establish contracts. Concrete RabbitMQ/Kafka adapters are planned follow-up work, while the shared envelope/protocol API is considered stable for early adopters.
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 csrd_message-0.3.12.tar.gz.
File metadata
- Download URL: csrd_message-0.3.12.tar.gz
- Upload date:
- Size: 4.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
34ea98ca56f5521a16a223c392e5f1b4060e2f2db9450cee16281e200cbfdc65
|
|
| MD5 |
b47897802bc3cf14fbad01cb2b1a146c
|
|
| BLAKE2b-256 |
1cd08afb2b1f4d76c23523e84be1cfc0c32ad63f4e0ce10fe0e072aafb4d2340
|
Provenance
The following attestation bundles were made for csrd_message-0.3.12.tar.gz:
Publisher:
release.yml on csrd-api/fastapi-common
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
csrd_message-0.3.12.tar.gz -
Subject digest:
34ea98ca56f5521a16a223c392e5f1b4060e2f2db9450cee16281e200cbfdc65 - Sigstore transparency entry: 1421808947
- Sigstore integration time:
-
Permalink:
csrd-api/fastapi-common@368b9bed4e3681b8dacf7140c18054446c806cee -
Branch / Tag:
refs/tags/v0.3.12 - Owner: https://github.com/csrd-api
-
Access:
private
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@368b9bed4e3681b8dacf7140c18054446c806cee -
Trigger Event:
workflow_dispatch
-
Statement type:
File details
Details for the file csrd_message-0.3.12-py3-none-any.whl.
File metadata
- Download URL: csrd_message-0.3.12-py3-none-any.whl
- Upload date:
- Size: 3.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0623e01e53e51be7eff6e2fdaf27be93d11605c42747f8594c85b0af1f91bf76
|
|
| MD5 |
2571559c681366c293c7e0955d971c19
|
|
| BLAKE2b-256 |
c246b355d00be32a527fc52a4e6dfbd5ec9bf95367a3f16add3af1e99ba41344
|
Provenance
The following attestation bundles were made for csrd_message-0.3.12-py3-none-any.whl:
Publisher:
release.yml on csrd-api/fastapi-common
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
csrd_message-0.3.12-py3-none-any.whl -
Subject digest:
0623e01e53e51be7eff6e2fdaf27be93d11605c42747f8594c85b0af1f91bf76 - Sigstore transparency entry: 1421809897
- Sigstore integration time:
-
Permalink:
csrd-api/fastapi-common@368b9bed4e3681b8dacf7140c18054446c806cee -
Branch / Tag:
refs/tags/v0.3.12 - Owner: https://github.com/csrd-api
-
Access:
private
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@368b9bed4e3681b8dacf7140c18054446c806cee -
Trigger Event:
workflow_dispatch
-
Statement type: