Client Reference

class pyzeebe.ZeebeClient(grpc_channel: Channel, max_connection_retries: int = 10)

A zeebe client that can connect to a zeebe instance and perform actions.

__init__(grpc_channel: Channel, max_connection_retries: int = 10) None
Parameters:
  • grpc_channel (grpc.aio.Channel) – GRPC Channel connected to a Zeebe gateway

  • max_connection_retries (int) – Amount of connection retries before client gives up on connecting to zeebe. To setup with infinite retries use -1

async broadcast_signal(signal_name: str, variables: Variables | None = None, tenant_id: str | None = None) BroadcastSignalResponse

Broadcasts a signal

Parameters:
  • signal_name (str) – The name of the signal

  • variables (dict) – The variables the signal should contain.

  • tenant_id (str) – The tenant ID of the message. New in Zeebe 8.4.

Returns:

response from Zeebe.

Return type:

BroadcastSignalResponse

Raises:
async cancel_process_instance(process_instance_key: int) CancelProcessInstanceResponse

Cancel a running process instance

Parameters:

process_instance_key (int) – The key of the running process to cancel

Returns:

response from Zeebe.

Return type:

CancelProcessInstanceResponse

Raises:
async deploy_resource(*resource_file_path: str | PathLike[str], tenant_id: str | None = None) DeployResourceResponse

Deploy one or more processes

New in Zeebe 8.0.

Parameters:
  • resource_file_path (str) – The file path to a resource definition file (bpmn/dmn/form)

  • tenant_id (str) – The tenant ID of the resources to deploy. New in Zeebe 8.3.

Returns:

response from Zeebe.

Return type:

DeployResourceResponse

Raises:
async evaluate_decision(decision_key: int | None, decision_id: str | None, variables: Variables | None = None, tenant_id: str | None = None) EvaluateDecisionResponse

Evaluates a decision.

You specify the decision to evaluate either by using its unique KEY (as returned by ZeebeClient.deploy_resource()), or using the decision ID. When using the decision ID, the latest deployed version of the decision is used.

Parameters:
  • decision_key (int) – The unique key identifying the decision to be evaluated (e.g. returned from a decision in the DeployResourceResponse message)

  • decision_id (str) – The ID of the decision to be evaluated

  • variables (dict) – A dictionary containing all variables for the decision to be evaluated. Must be JSONable.

  • tenant_id (strc) – The tenant ID of the resources to deploy. New in Zeebe 8.3.

Returns:

response from Zeebe.

Return type:

EvaluateDecisionResponse

Raises:
async publish_message(name: str, correlation_key: str, variables: Variables | None = None, time_to_live_in_milliseconds: int = 60000, message_id: str | None = None, tenant_id: str | None = None) PublishMessageResponse

Publish a message

Parameters:
  • name (str) – The message name

  • correlation_key (str) – The correlation key. For more info: https://docs.zeebe.io/glossary.html?highlight=correlation#correlation-key

  • variables (dict) – The variables the message should contain.

  • time_to_live_in_milliseconds (int) – How long this message should stay active. Default: 60000 ms (60 seconds)

  • message_id (str) – A unique message id. Useful for avoiding duplication. If a message with this id is still active, a MessageAlreadyExists will be raised.

  • tenant_id (str) – The tenant ID of the message. New in Zeebe 8.3.

Returns:

response from Zeebe.

Return type:

PublishMessageResponse

Raises:
async run_process(bpmn_process_id: str, variables: Variables | None = None, version: int = -1, tenant_id: str | None = None) CreateProcessInstanceResponse

Run process

Parameters:
  • bpmn_process_id (str) – The unique process id of the process.

  • variables (dict) – A dictionary containing all the starting variables the process needs. Must be JSONable.

  • version (int) – The version of the process. Default: -1 (latest)

  • tenant_id (str) – The tenant ID of the process definition. New in Zeebe 8.3.

Returns:

response from Zeebe.

Return type:

CreateProcessInstanceResponse

Raises:
async run_process_with_result(bpmn_process_id: str, variables: Variables | None = None, version: int = -1, timeout: int = 0, variables_to_fetch: Iterable[str] | None = None, tenant_id: str | None = None) CreateProcessInstanceWithResultResponse

Run process and wait for the result.

Parameters:
  • bpmn_process_id (str) – The unique process id of the process.

  • variables (dict) – A dictionary containing all the starting variables the process needs. Must be JSONable.

  • version (int) – The version of the process. Default: -1 (latest)

  • timeout (int) – How long to wait until a timeout occurs. Default: 0 (Zeebe default timeout)

  • variables_to_fetch (list[str]) – Which variables to get from the finished process

  • tenant_id (str) – The tenant ID of the process definition. New in Zeebe 8.3.

Returns:

response from Zeebe.

Return type:

CreateProcessInstanceWithResultResponse

Raises:
async topology() TopologyResponse

Obtains the current topology of the cluster the gateway is part of.

Returns:

response from Zeebe.

Return type:

TopologyResponse

Raises:
class pyzeebe.SyncZeebeClient(grpc_channel: Channel, max_connection_retries: int = 10)
__init__(grpc_channel: Channel, max_connection_retries: int = 10) None
broadcast_signal(signal_name: str, variables: Variables | None = None, tenant_id: str | None = None) BroadcastSignalResponse

Broadcasts a signal

Parameters:
  • signal_name (str) – The name of the signal

  • variables (dict) – The variables the signal should contain.

  • tenant_id (str) – The tenant ID of the message. New in Zeebe 8.4.

Returns:

response from Zeebe.

Return type:

BroadcastSignalResponse

Raises:
cancel_process_instance(process_instance_key: int) CancelProcessInstanceResponse

Cancel a running process instance

Parameters:

process_instance_key (int) – The key of the running process to cancel

Returns:

response from Zeebe.

Return type:

CancelProcessInstanceResponse

Raises:
deploy_resource(*resource_file_path: str | PathLike[str], tenant_id: str | None = None) DeployResourceResponse

Deploy one or more processes

New in Zeebe 8.0.

Parameters:
  • resource_file_path (str) – The file path to a resource definition file (bpmn/dmn/form)

  • tenant_id (str) – The tenant ID of the resources to deploy. New in Zeebe 8.3.

Returns:

response from Zeebe.

Return type:

DeployResourceResponse

Raises:
evaluate_decision(decision_key: int | None, decision_id: str | None, variables: Variables | None = None, tenant_id: str | None = None) EvaluateDecisionResponse

Evaluates a decision.

You specify the decision to evaluate either by using its unique KEY (as returned by ZeebeClient.deploy_resource()), or using the decision ID. When using the decision ID, the latest deployed version of the decision is used.

Parameters:
  • decision_key (int) – The unique key identifying the decision to be evaluated (e.g. returned from a decision in the DeployResourceResponse message)

  • decision_id (str) – The ID of the decision to be evaluated

  • variables (dict) – A dictionary containing all variables for the decision to be evaluated. Must be JSONable.

  • tenant_id (strc) – The tenant ID of the resources to deploy. New in Zeebe 8.3.

Returns:

response from Zeebe.

Return type:

EvaluateDecisionResponse

Raises:
publish_message(name: str, correlation_key: str, variables: Variables | None = None, time_to_live_in_milliseconds: int = 60000, message_id: str | None = None, tenant_id: str | None = None) PublishMessageResponse

Publish a message

Parameters:
  • name (str) – The message name

  • correlation_key (str) – The correlation key. For more info: https://docs.zeebe.io/glossary.html?highlight=correlation#correlation-key

  • variables (dict) – The variables the message should contain.

  • time_to_live_in_milliseconds (int) – How long this message should stay active. Default: 60000 ms (60 seconds)

  • message_id (str) – A unique message id. Useful for avoiding duplication. If a message with this id is still active, a MessageAlreadyExists will be raised.

  • tenant_id (str) – The tenant ID of the message. New in Zeebe 8.3.

Returns:

response from Zeebe.

Return type:

PublishMessageResponse

Raises:
run_process(bpmn_process_id: str, variables: Variables | None = None, version: int = -1, tenant_id: str | None = None) CreateProcessInstanceResponse

Publish a message

Parameters:
  • name (str) – The message name

  • correlation_key (str) – The correlation key. For more info: https://docs.zeebe.io/glossary.html?highlight=correlation#correlation-key

  • variables (dict) – The variables the message should contain.

  • time_to_live_in_milliseconds (int) – How long this message should stay active. Default: 60000 ms (60 seconds)

  • message_id (str) – A unique message id. Useful for avoiding duplication. If a message with this id is still active, a MessageAlreadyExists will be raised.

  • tenant_id (str) – The tenant ID of the message. New in Zeebe 8.3.

Returns:

response from Zeebe.

Return type:

PublishMessageResponse

Raises:
run_process_with_result(bpmn_process_id: str, variables: Variables | None = None, version: int = -1, timeout: int = 0, variables_to_fetch: list[str] | None = None, tenant_id: str | None = None) CreateProcessInstanceWithResultResponse

Publish a message

Parameters:
  • name (str) – The message name

  • correlation_key (str) – The correlation key. For more info: https://docs.zeebe.io/glossary.html?highlight=correlation#correlation-key

  • variables (dict) – The variables the message should contain.

  • time_to_live_in_milliseconds (int) – How long this message should stay active. Default: 60000 ms (60 seconds)

  • message_id (str) – A unique message id. Useful for avoiding duplication. If a message with this id is still active, a MessageAlreadyExists will be raised.

  • tenant_id (str) – The tenant ID of the message. New in Zeebe 8.3.

Returns:

response from Zeebe.

Return type:

PublishMessageResponse

Raises:
topology() TopologyResponse

Obtains the current topology of the cluster the gateway is part of.

Returns:

response from Zeebe.

Return type:

TopologyResponse

Raises: