events

class litestar.events.BaseEventEmitterBackend[source]

Bases: AbstractAsyncContextManager[BaseEventEmitterBackend], ABC

Abstract class used to define event emitter backends.

__init__(listeners: Sequence[EventListener]) None[source]

Create an event emitter instance.

Parameters:

listeners – A list of listeners.

abstractmethod emit(event_id: str, *args: Any, **kwargs: Any) None[source]

Emit an event to all attached listeners.

Parameters:
  • event_id – The ID of the event to emit, e.g ‘my_event’.

  • *args – args to pass to the listener(s).

  • **kwargs – kwargs to pass to the listener(s)

Returns:

None

class litestar.events.EventListener[source]

Bases: object

Decorator for event listeners

__call__(fn: AnyCallable) EventListener[source]

Decorate a callable by wrapping it inside an instance of EventListener.

Parameters:

fn – Callable to decorate.

Returns:

An instance of EventListener

__init__(*event_ids: str) None[source]

Create a decorator for event handlers.

Parameters:

*event_ids – The id of the event to listen to or a list of event ids to listen to.

static wrap_in_error_handler(fn: AsyncAnyCallable) AsyncAnyCallable[source]

Wrap a listener function to handle errors.

Listeners are executed concurrently in a TaskGroup, so we need to ensure that exceptions do not propagate to the task group which results in any other unfinished listeners to be cancelled, and the receive stream to be closed.

See https://github.com/litestar-org/litestar/issues/2809

Parameters:

fn – The listener function to wrap.

class litestar.events.SimpleEventEmitter[source]

Bases: BaseEventEmitterBackend

Event emitter the works only in the current process

__init__(listeners: Sequence[EventListener]) None[source]

Create an event emitter instance.

Parameters:

listeners – A list of listeners.

emit(event_id: str, *args: Any, **kwargs: Any) None[source]

Emit an event to all attached listeners.

Parameters:
  • event_id – The ID of the event to emit, e.g ‘my_event’.

  • *args – args to pass to the listener(s).

  • **kwargs – kwargs to pass to the listener(s)

Returns:

None

litestar.events.listener

alias of EventListener