class documentation

Base class for worker plugins that can intercept and modify worker behavior.

Plugins allow customization of worker creation and execution processes through a chain of responsibility pattern. Each plugin can modify the worker configuration or intercept worker execution.

WARNING: This is an experimental feature and may change in the future.

Method configure_replayer Hook called when creating a replayer to allow modification of configuration.
Method configure_worker Hook called when creating a worker to allow modification of configuration.
Method name Get the qualified name of this plugin. Can be overridden if desired to provide a more appropriate name.
Method run_replayer Hook called when running a replayer to allow interception of execution.
Async Method run_worker Hook called when running a worker to allow interception of execution.
@abc.abstractmethod
def configure_replayer(self, config: ReplayerConfig) -> ReplayerConfig: (source)

Hook called when creating a replayer to allow modification of configuration.

This should be used to configure anything in ReplayerConfig needed to make execution match the worker and client config. This could include interceptors, DataConverter, workflows, and more.

Parameters
config:ReplayerConfigThe replayer configuration dictionary to potentially modify.
Returns
ReplayerConfigThe modified replayer configuration.
@abc.abstractmethod
def configure_worker(self, config: WorkerConfig) -> WorkerConfig: (source)

Hook called when creating a worker to allow modification of configuration.

This method is called during worker creation and allows plugins to modify the worker configuration before the worker is fully initialized. Plugins can modify task queue names, adjust concurrency settings, add interceptors, or change other worker settings.

Parameters
config:WorkerConfigThe worker configuration dictionary to potentially modify.
Returns
WorkerConfigThe modified worker configuration.
def name(self) -> str: (source)

Get the qualified name of this plugin. Can be overridden if desired to provide a more appropriate name.

Returns
strThe fully qualified name of the plugin class (module.classname).
@abc.abstractmethod
def run_replayer(self, replayer: Replayer, histories: AsyncIterator[WorkflowHistory], next: Callable[[Replayer, AsyncIterator[WorkflowHistory]], AbstractAsyncContextManager[AsyncIterator[WorkflowReplayResult]]]) -> AbstractAsyncContextManager[AsyncIterator[WorkflowReplayResult]]: (source)

Hook called when running a replayer to allow interception of execution.

@abc.abstractmethod
async def run_worker(self, worker: Worker, next: Callable[[Worker], Awaitable[None]]): (source)

Hook called when running a worker to allow interception of execution.

This method is called when the worker is started and allows plugins to intercept or wrap the worker execution. Plugins can add monitoring, custom lifecycle management, or other execution-time behavior.

Parameters
worker:WorkerThe worker instance to run.
next:Callable[[Worker], Awaitable[None]]Callable to continue the worker execution.