Skip to main content

A library that provides users the ability to create event (loop) driven systems within the asyncio framework.

Project description

Asyncio Event Hub is a library that provides users with a way to easily create event-driven applications within the asyncio framework. It provides one main class asyncio_event_hub.controller.EventController, which can be used to emit events and add listeners (functions) to events that get called from the event loop in the same order they were added.

Installation

pip install asyncio-event-hub

Example

import asyncio_event_hub as aeh
import asyncio


# Create event controllers
main_controller = aeh.EventController()
sub_controller = aeh.EventController()

# Register sub_controller as a sub-controller of the main_controller
main_controller.add_subcontroller(sub_controller)


# Add listener via a decorator
@main_controller.listen("my_event")
async def listener1(a, b):
    print(f"listener1({a}, {b})")


# Add listeners via a decorator
@main_controller.listen("my_event")
@sub_controller.listen("my_event")
def listener2(a, b):
    print(f"listener2({a}, {b})")


async def stop(a):
    main_controller.stop()  # Stop main_controller and it's sub-controllers.


# Add listener through function
main_controller.add_listener("stop_event", stop, predicate=lambda a: a == 5)  # Only call stop(a) if a is equal to 5


async def main():
    main_controller.start()  # Start main_controller and it's sub-controllers.

    # Emit events into the event loop, executed asynchronously.
    # listener1 is called once, listener2 is caller twice -
    # once from main controller's event loop and once sub-controller's event loop. (not at this line, but asynchronously)
    main_controller.emit("my_event", a=9, b =10)

    # listener2 is called once from sub-controller's event loop. (not at this line, but asynchronously)
    sub_controller.emit("my_event", a=1, b=2)

    # await used to await for all listeners to finish processing event.
    await main_controller.emit("stop_event", a=1)  # Does not actually call anything since we have a predicate of a == 5.
    await main_controller.emit("stop_event", a=5)  # Stops controller asynchronously

asyncio.run(main())

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

asyncio-event-hub-1.1.0.tar.gz (6.9 kB view hashes)

Uploaded Source

Built Distribution

asyncio_event_hub-1.1.0-py3-none-any.whl (7.4 kB view hashes)

Uploaded Python 3

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page