faust.joins

Join strategies.

class faust.joins.Join(*, stream: JoinableT, fields: Tuple[FieldDescriptorT, ...])[source]

Base class for join strategies.

fields: MutableMapping[Type[ModelT], FieldDescriptorT]
stream: JoinableT
async process(event: EventT) Optional[EventT][source]

Process event to be joined with another event.

Return type:

_GenericAlias[EventT, None]

class faust.joins.RightJoin(*, stream: JoinableT, fields: Tuple[FieldDescriptorT, ...])[source]

Right-join strategy.

fields: MutableMapping[Type[ModelT], FieldDescriptorT]
stream: JoinableT
class faust.joins.LeftJoin(*, stream: JoinableT, fields: Tuple[FieldDescriptorT, ...])[source]

Left-join strategy.

fields: MutableMapping[Type[ModelT], FieldDescriptorT]
stream: JoinableT
class faust.joins.InnerJoin(*, stream: JoinableT, fields: Tuple[FieldDescriptorT, ...])[source]

Inner-join strategy.

fields: MutableMapping[Type[ModelT], FieldDescriptorT]
stream: JoinableT
class faust.joins.OuterJoin(*, stream: JoinableT, fields: Tuple[FieldDescriptorT, ...])[source]

Outer-join strategy.

fields: MutableMapping[Type[ModelT], FieldDescriptorT]
stream: JoinableT