Process Events In Style
This library aims to simplify the common pattern of event processing. It simplifies the process of filtering, dispatching and pre-processing events as well as injecting dependencies in event processors.
The only requirement is that your events are regular python dictionaries.
Take a look at the following examples to get an overview of the features available! Of course, you can mix and combine them in any way you like to create more complex scenarios.
from event_processor import EventProcessor, Event
from event_processor.filters import Eq
event_processor = EventProcessor()
@event_processor.processor(Eq("service.type", "service_a"))
def process_service_a(event: Event):
return event["service"]["status"] == "up"
@event_processor.processor(Eq("service.type", "service_b"))
def process_service_b(event: Event):
return event["authorized"]
service_a_event = {
"service": {
"type": "service_a",
"status": "down"
}
}
service_b_event = {
"service": {
"type": "service_b",
"authorized": False
}
}
event_processor.invoke(service_a_event) # False
event_processor.invoke(service_b_event) # False
Documentation
Find the full documentation on Read the Docs.