A toolkit for emitting and handling events, following the CloudEvent spec.
Project description
eventkit-py
A toolkit for emitting and handling events, following the CloudEvent spec.
Installation
poetry add outcome-eventkit
Usage
It's a good idea to be familiar with the CloudEvent v1.0 spec before using this library.
The library implements the following (but is extensible):
Event Example
from outcome.eventkit import CloudEvent, CloudEventData
from outcome.eventkit.formats.json import JSONCloudEventFormat
from outcome.eventkit.protocol_bindings.http import StructuredHTTPBinding, BinaryHTTPBinding
import requests
# Create a payload, specifying how it will be encoded
data = CloudEventData(
data_content_type='application/json',
data={
'hello': 'world'
}
)
# Create an event
event = CloudEvent(type='co.outcome.events.sample', source='example', data=data)
# Create a JSON representation of the event
serialised_event = JSONCloudEventFormat.encode(event)
# Or...
# Create a HTTP message with the event
http_message = BinaryHTTPBinding.to_http(event)
# Or...
# Create a structured HTTP message with the event and a JSON formatter
http_message = StructuredHTTPBinding.to_http(event, JSONCloudEventFormat)
# Post the event somewhere...
requests.post('http://example.org', headers=http_message.headers, data=http_message.body)
Dispatch Example
from outcome.eventkit import dispatch, CloudEvent
# You can register event handlers that will be called
# when a corresponding event is dispatched
# Explicitly
def my_event_handler(event: CloudEvent) -> None:
...
# Register a handler for an event type
dispatch.register_handler('co.outcome.event', my_event_handler)
# Or via a decorator
@dispatch.handles_events('co.outcome.event', 'co.outcome.other-event')
def my_other_handler(event: CloudEvent) -> None:
...
# Then notify all registered handlers of an event
ev = CloudEvent(type='co.outcome.event', source='example')
dispatch.dispatch(ev)
By default, all handlers are stored in a single registry, but you can provide your own registry to the register_handler
/handles_events
/dispatch
methods with the registry
keyword argument.
from outcome.eventkit import dispatch
from collections import defaultdict
my_registry: dispatch.CloudEventHandlerRegistry = defaultdict(list)
@dispatch.handles_events('co.outcome.event', registry=my_registry)
def my_handler(event: CloudEvent) -> None:
...
ev = CloudEvent(type='co.outcome.event', source='example')
dispatch.dispatch(ev, registry=my_registry)
Development
Remember to run ./pre-commit.sh
when you clone the repository.
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
File details
Details for the file outcome-eventkit-0.2.6.tar.gz
.
File metadata
- Download URL: outcome-eventkit-0.2.6.tar.gz
- Upload date:
- Size: 11.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.1.4 CPython/3.8.6 Linux/5.4.0-1031-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 3e5f1106448d6a7c11aac88618cc811179f2efe10c63be22fca41ca1ae831202 |
|
MD5 | fc1b4dffdcba863e52904395f24be6e1 |
|
BLAKE2b-256 | 71dc8d2123658093efa8e570aa78fcb9d08194fb4cd69c07d73737c6d71c87c4 |
File details
Details for the file outcome_eventkit-0.2.6-py3-none-any.whl
.
File metadata
- Download URL: outcome_eventkit-0.2.6-py3-none-any.whl
- Upload date:
- Size: 14.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.1.4 CPython/3.8.6 Linux/5.4.0-1031-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 7406ef3db091dd0253e235e525ca8beb24e0f68a2b86e3c8e676f532c37357bc |
|
MD5 | 15a1bfa50c214c46b3898aaa1fd1145f |
|
BLAKE2b-256 | 314ee86404543344441653783f0b6aa7b0d3f3a7fb7415d98560764ab104220a |