Zeebe command binding spec

Detailed documentation on the Zeebe command binding component

Component format

To setup Zeebe command binding create a component of type bindings.zeebe.command. See this guide on how to create and apply a binding configuration.

See this for Zeebe documentation.

  1. apiVersion: dapr.io/v1alpha1
  2. kind: Component
  3. metadata:
  4. name: <NAME>
  5. spec:
  6. type: bindings.zeebe.command
  7. version: v1
  8. metadata:
  9. - name: gatewayAddr
  10. value: "<host>:<port>"
  11. - name: gatewayKeepAlive
  12. value: "45s"
  13. - name: usePlainTextConnection
  14. value: "true"
  15. - name: caCertificatePath
  16. value: "/path/to/ca-cert"
  17. - name: direction
  18. value: "output"

Spec metadata fields

FieldRequiredBinding supportDetailsExample
gatewayAddrYOutputZeebe gateway address“localhost:26500”
gatewayKeepAliveNOutputSets how often keep alive messages should be sent to the gateway. Defaults to 45 seconds“45s”
usePlainTextConnectionNOutputWhether to use a plain text connection or not“true”, “false”
caCertificatePathNOutputThe path to the CA cert“/path/to/ca-cert”
directionNOutputThe direction of the binding“output”

Binding support

This component supports output binding with the following operations:

  • topology
  • deploy-process
  • deploy-resource
  • create-instance
  • cancel-instance
  • set-variables
  • resolve-incident
  • publish-message
  • activate-jobs
  • complete-job
  • fail-job
  • update-job-retries
  • throw-error

Output binding

Zeebe uses gRPC under the hood for the Zeebe client we use in this binding. Please consult the gRPC API reference for more information.

topology

The topology operation obtains the current topology of the cluster the gateway is part of.

To perform a topology operation, invoke the Zeebe command binding with a POST method, and the following JSON body:

  1. {
  2. "data": {},
  3. "operation": "topology"
  4. }
Response

The binding returns a JSON with the following response:

  1. {
  2. "brokers": [
  3. {
  4. "nodeId": null,
  5. "host": "172.18.0.5",
  6. "port": 26501,
  7. "partitions": [
  8. {
  9. "partitionId": 1,
  10. "role": null,
  11. "health": null
  12. }
  13. ],
  14. "version": "0.26.0"
  15. }
  16. ],
  17. "clusterSize": 1,
  18. "partitionsCount": 1,
  19. "replicationFactor": 1,
  20. "gatewayVersion": "0.26.0"
  21. }

The response values are:

  • brokers - list of brokers part of this cluster
    • nodeId - unique (within a cluster) node ID for the broker
    • host - hostname of the broker
    • port - port for the broker
    • port - port for the broker
    • partitions - list of partitions managed or replicated on this broker
      • partitionId - the unique ID of this partition
      • role - the role of the broker for this partition
      • health - the health of this partition
    • version - broker version
  • clusterSize - how many nodes are in the cluster
  • partitionsCount - how many partitions are spread across the cluster
  • replicationFactor - configured replication factor for this cluster
  • gatewayVersion - gateway version

deploy-process

Deprecated alias of ‘deploy-resource’.

deploy-resource

The deploy-resource operation deploys a single resource to Zeebe. A resource can be a process (BPMN) or a decision and a decision requirement (DMN).

To perform a deploy-resource operation, invoke the Zeebe command binding with a POST method, and the following JSON body:

  1. {
  2. "data": "YOUR_FILE_CONTENT",
  3. "metadata": {
  4. "fileName": "products-process.bpmn"
  5. },
  6. "operation": "deploy-resource"
  7. }

The metadata parameters are:

  • fileName - the name of the resource file
Response

The binding returns a JSON with the following response:

  1. {
  2. "key": 2251799813685252,
  3. "deployments": [
  4. {
  5. "Metadata": {
  6. "Process": {
  7. "bpmnProcessId": "products-process",
  8. "version": 2,
  9. "processDefinitionKey": 2251799813685251,
  10. "resourceName": "products-process.bpmn"
  11. }
  12. }
  13. }
  14. ]
  15. }
  1. {
  2. "key": 2251799813685253,
  3. "deployments": [
  4. {
  5. "Metadata": {
  6. "Decision": {
  7. "dmnDecisionId": "products-approval",
  8. "dmnDecisionName": "Products approval",
  9. "version": 1,
  10. "decisionKey": 2251799813685252,
  11. "dmnDecisionRequirementsId": "Definitions_0c98xne",
  12. "decisionRequirementsKey": 2251799813685251
  13. }
  14. }
  15. },
  16. {
  17. "Metadata": {
  18. "DecisionRequirements": {
  19. "dmnDecisionRequirementsId": "Definitions_0c98xne",
  20. "dmnDecisionRequirementsName": "DRD",
  21. "version": 1,
  22. "decisionRequirementsKey": 2251799813685251,
  23. "resourceName": "products-approval.dmn"
  24. }
  25. }
  26. }
  27. ]
  28. }

The response values are:

  • key - the unique key identifying the deployment
  • deployments - a list of deployed resources, e.g. processes
    • metadata - deployment metadata, each deployment has only one metadata
      • process- metadata of a deployed process
        • bpmnProcessId - the bpmn process ID, as parsed during deployment; together with the version forms a unique identifier for a specific process definition
        • version - the assigned process version
        • processDefinitionKey - the assigned key, which acts as a unique identifier for this process
        • resourceName - the resource name from which this process was parsed
      • decision - metadata of a deployed decision
        • dmnDecisionId - the dmn decision ID, as parsed during deployment; together with the versions forms a unique identifier for a specific decision
        • dmnDecisionName - the dmn name of the decision, as parsed during deployment
        • version - the assigned decision version
        • decisionKey - the assigned decision key, which acts as a unique identifier for this decision
        • dmnDecisionRequirementsId - the dmn ID of the decision requirements graph that this decision is part of, as parsed during deployment
        • decisionRequirementsKey - the assigned key of the decision requirements graph that this decision is part of
      • decisionRequirements - metadata of a deployed decision requirements
        • dmnDecisionRequirementsId - the dmn decision requirements ID, as parsed during deployment; together with the versions forms a unique identifier for a specific decision
        • dmnDecisionRequirementsName - the dmn name of the decision requirements, as parsed during deployment
        • version - the assigned decision requirements version
        • decisionRequirementsKey - the assigned decision requirements key, which acts as a unique identifier for this decision requirements
        • resourceName - the resource name from which this decision requirements was parsed

create-instance

The create-instance operation creates and starts an instance of the specified process. The process definition to use to create the instance can be specified either using its unique key (as returned by the deploy-process operation), or using the BPMN process ID and a version.

Note that only processes with none start events can be started through this command.

Typically, process creation and execution are decoupled. This means that the command creates a new process instance and immediately responds with the process instance id. The execution of the process occurs after the response is sent. However, there are use cases that need to collect the results of a process when its execution is complete. By defining the withResult property, the command allows to “synchronously” execute processes and receive the results via a set of variables. The response is sent when the process execution is complete.

For more information please visit the official documentation.

To perform a create-instance operation, invoke the Zeebe command binding with a POST method, and the following JSON body:

  1. {
  2. "data": {
  3. "bpmnProcessId": "products-process",
  4. "variables": {
  5. "productId": "some-product-id",
  6. "productName": "some-product-name",
  7. "productKey": "some-product-key"
  8. }
  9. },
  10. "operation": "create-instance"
  11. }
  1. {
  2. "data": {
  3. "processDefinitionKey": 2251799813685895,
  4. "variables": {
  5. "productId": "some-product-id",
  6. "productName": "some-product-name",
  7. "productKey": "some-product-key"
  8. }
  9. },
  10. "operation": "create-instance"
  11. }
  1. {
  2. "data": {
  3. "bpmnProcessId": "products-process",
  4. "variables": {
  5. "productId": "some-product-id",
  6. "productName": "some-product-name",
  7. "productKey": "some-product-key"
  8. },
  9. "withResult": true,
  10. "requestTimeout": "30s",
  11. "fetchVariables": ["productId"]
  12. },
  13. "operation": "create-instance"
  14. }

The data parameters are:

  • bpmnProcessId - the BPMN process ID of the process definition to instantiate
  • processDefinitionKey - the unique key identifying the process definition to instantiate
  • version - (optional, default: latest version) the version of the process to instantiate
  • variables - (optional) JSON document that will instantiate the variables for the root variable scope of the process instance; it must be a JSON object, as variables will be mapped in a key-value fashion. e.g. { “a”: 1, “b”: 2 } will create two variables, named “a” and “b” respectively, with their associated values. [{ “a”: 1, “b”: 2 }] would not be a valid argument, as the root of the JSON document is an array and not an object
  • withResult - (optional, default: false) if set to true, the process will be instantiated and executed synchronously
  • requestTimeout - (optional, only used if withResult=true) timeout the request will be closed if the process is not completed before the requestTimeout. If requestTimeout = 0, uses the generic requestTimeout configured in the gateway.
  • fetchVariables - (optional, only used if withResult=true) list of names of variables to be included in variables property of the response. If empty, all visible variables in the root scope will be returned.
Response

The binding returns a JSON with the following response:

  1. {
  2. "processDefinitionKey": 2251799813685895,
  3. "bpmnProcessId": "products-process",
  4. "version": 3,
  5. "processInstanceKey": 2251799813687851,
  6. "variables": "{\"productId\":\"some-product-id\"}"
  7. }

The response values are:

  • processDefinitionKey - the key of the process definition which was used to create the process instance
  • bpmnProcessId - the BPMN process ID of the process definition which was used to create the process instance
  • version - the version of the process definition which was used to create the process instance
  • processInstanceKey - the unique identifier of the created process instance
  • variables - (optional, only if withResult=true was used in the request) JSON document consists of visible variables in the root scope; returned as a serialized JSON document

cancel-instance

The cancel-instance operation cancels a running process instance.

To perform a cancel-instance operation, invoke the Zeebe command binding with a POST method, and the following JSON body:

  1. {
  2. "data": {
  3. "processInstanceKey": 2251799813687851
  4. },
  5. "operation": "cancel-instance"
  6. }

The data parameters are:

  • processInstanceKey - the process instance key
Response

The binding does not return a response body.

set-variables

The set-variables operation creates or updates variables for an element instance (e.g. process instance, flow element instance).

To perform a set-variables operation, invoke the Zeebe command binding with a POST method, and the following JSON body:

  1. {
  2. "data": {
  3. "elementInstanceKey": 2251799813687880,
  4. "variables": {
  5. "productId": "some-product-id",
  6. "productName": "some-product-name",
  7. "productKey": "some-product-key"
  8. }
  9. },
  10. "operation": "set-variables"
  11. }

The data parameters are:

  • elementInstanceKey - the unique identifier of a particular element; can be the process instance key (as obtained during instance creation), or a given element, such as a service task (see elementInstanceKey on the job message)
  • local - (optional, default: false) if true, the variables will be merged strictly into the local scope (as indicated by elementInstanceKey); this means the variables is not propagated to upper scopes. for example, let’s say we have two scopes, ‘1’ and ‘2’, with each having effective variables as: 1 => { "foo" : 2 }, and 2 => { "bar" : 1 }. if we send an update request with elementInstanceKey = 2, variables { "foo" : 5 }, and local is true, then scope 1 will be unchanged, and scope 2 will now be { "bar" : 1, "foo" 5 }. if local was false, however, then scope 1 would be { "foo": 5 }, and scope 2 would be { "bar" : 1 }
  • variables - a JSON serialized document describing variables as key value pairs; the root of the document must be an object
Response

The binding returns a JSON with the following response:

  1. {
  2. "key": 2251799813687896
  3. }

The response values are:

  • key - the unique key of the set variables command

resolve-incident

The resolve-incident operation resolves an incident.

To perform a resolve-incident operation, invoke the Zeebe command binding with a POST method, and the following JSON body:

  1. {
  2. "data": {
  3. "incidentKey": 2251799813686123
  4. },
  5. "operation": "resolve-incident"
  6. }

The data parameters are:

  • incidentKey - the unique ID of the incident to resolve
Response

The binding does not return a response body.

publish-message

The publish-message operation publishes a single message. Messages are published to specific partitions computed from their correlation keys.

To perform a publish-message operation, invoke the Zeebe command binding with a POST method, and the following JSON body:

  1. {
  2. "data": {
  3. "messageName": "product-message",
  4. "correlationKey": "2",
  5. "timeToLive": "1m",
  6. "variables": {
  7. "productId": "some-product-id",
  8. "productName": "some-product-name",
  9. "productKey": "some-product-key"
  10. },
  11. },
  12. "operation": "publish-message"
  13. }

The data parameters are:

  • messageName - the name of the message
  • correlationKey - (optional) the correlation key of the message
  • timeToLive - (optional) how long the message should be buffered on the broker
  • messageId - (optional) the unique ID of the message; can be omitted. only useful to ensure only one message with the given ID will ever be published (during its lifetime)
  • variables - (optional) the message variables as a JSON document; to be valid, the root of the document must be an object, e.g. { “a”: “foo” }. [ “foo” ] would not be valid
Response

The binding returns a JSON with the following response:

  1. {
  2. "key": 2251799813688225
  3. }

The response values are:

  • key - the unique ID of the message that was published

activate-jobs

The activate-jobs operation iterates through all known partitions round-robin and activates up to the requested maximum and streams them back to the client as they are activated.

To perform a activate-jobs operation, invoke the Zeebe command binding with a POST method, and the following JSON body:

  1. {
  2. "data": {
  3. "jobType": "fetch-products",
  4. "maxJobsToActivate": 5,
  5. "timeout": "5m",
  6. "workerName": "products-worker",
  7. "fetchVariables": [
  8. "productId",
  9. "productName",
  10. "productKey"
  11. ],
  12. "requestTimeout": "30s"
  13. },
  14. "operation": "activate-jobs"
  15. }

The data parameters are:

  • jobType - the job type, as defined in the BPMN process (e.g. <zeebe:taskDefinition type="fetch-products" />)
  • maxJobsToActivate - the maximum jobs to activate by this request
  • timeout - (optional, default: 5 minutes) a job returned after this call will not be activated by another call until the timeout has been reached
  • workerName - (optional, default: default) the name of the worker activating the jobs, mostly used for logging purposes
  • fetchVariables - (optional) a list of variables to fetch as the job variables; if empty, all visible variables at the time of activation for the scope of the job will be returned
  • requestTimeout - (optional) the request will be completed when at least one job is activated or after the requestTimeout. If the requestTimeout = 0, a default timeout is used. If the requestTimeout < 0, long polling is disabled and the request is completed immediately, even when no job is activated.
Response

The binding returns a JSON with the following response:

  1. [
  2. {
  3. "key": 2251799813685267,
  4. "type": "fetch-products",
  5. "processInstanceKey": 2251799813685260,
  6. "bpmnProcessId": "products",
  7. "processDefinitionVersion": 1,
  8. "processDefinitionKey": 2251799813685249,
  9. "elementId": "Activity_test",
  10. "elementInstanceKey": 2251799813685266,
  11. "customHeaders": "{\"process-header-1\":\"1\",\"process-header-2\":\"2\"}",
  12. "worker": "test",
  13. "retries": 1,
  14. "deadline": 1694091934039,
  15. "variables":"{\"productId\":\"some-product-id\"}"
  16. }
  17. ]

The response values are:

  • key - the key, a unique identifier for the job
  • type - the type of the job (should match what was requested)
  • processInstanceKey - the job’s process instance key
  • bpmnProcessId - the bpmn process ID of the job process definition
  • processDefinitionVersion - the version of the job process definition
  • processDefinitionKey - the key of the job process definition
  • elementId - the associated task element ID
  • elementInstanceKey - the unique key identifying the associated task, unique within the scope of the process instance
  • customHeaders - a set of custom headers defined during modelling; returned as a serialized JSON document
  • worker - the name of the worker which activated this job
  • retries - the amount of retries left to this job (should always be positive)
  • deadline - when the job can be activated again, sent as a UNIX epoch timestamp
  • variables - computed at activation time, consisting of all visible variables to the task scope; returned as a serialized JSON document

complete-job

The complete-job operation completes a job with the given payload, which allows completing the associated service task.

To perform a complete-job operation, invoke the Zeebe command binding with a POST method, and the following JSON body:

  1. {
  2. "data": {
  3. "jobKey": 2251799813686172,
  4. "variables": {
  5. "productId": "some-product-id",
  6. "productName": "some-product-name",
  7. "productKey": "some-product-key"
  8. }
  9. },
  10. "operation": "complete-job"
  11. }

The data parameters are:

  • jobKey - the unique job identifier, as obtained from the activate jobs response
  • variables - (optional) a JSON document representing the variables in the current task scope
Response

The binding does not return a response body.

fail-job

The fail-job operation marks the job as failed; if the retries argument is positive, then the job will be immediately activatable again, and a worker could try again to process it. If it is zero or negative however, an incident will be raised, tagged with the given errorMessage, and the job will not be activatable until the incident is resolved.

To perform a fail-job operation, invoke the Zeebe command binding with a POST method, and the following JSON body:

  1. {
  2. "data": {
  3. "jobKey": 2251799813685739,
  4. "retries": 5,
  5. "errorMessage": "some error occurred",
  6. "retryBackOff": "30s",
  7. "variables": {
  8. "productId": "some-product-id",
  9. "productName": "some-product-name",
  10. "productKey": "some-product-key"
  11. }
  12. },
  13. "operation": "fail-job"
  14. }

The data parameters are:

  • jobKey - the unique job identifier, as obtained when activating the job
  • retries - the amount of retries the job should have left
  • errorMessage - (optional) a message describing why the job failed this is particularly useful if a job runs out of retries and an incident is raised, as it this message can help explain why an incident was raised
  • retryBackOff - (optional) the back-off timeout for the next retry
  • variables - (optional) JSON document that will instantiate the variables at the local scope of the job’s associated task; it must be a JSON object, as variables will be mapped in a key-value fashion. e.g. { “a”: 1, “b”: 2 } will create two variables, named “a” and “b” respectively, with their associated values. [{ “a”: 1, “b”: 2 }] would not be a valid argument, as the root of the JSON document is an array and not an object.
Response

The binding does not return a response body.

update-job-retries

The update-job-retries operation updates the number of retries a job has left. This is mostly useful for jobs that have run out of retries, should the underlying problem be solved.

To perform a update-job-retries operation, invoke the Zeebe command binding with a POST method, and the following JSON body:

  1. {
  2. "data": {
  3. "jobKey": 2251799813686172,
  4. "retries": 10
  5. },
  6. "operation": "update-job-retries"
  7. }

The data parameters are:

  • jobKey - the unique job identifier, as obtained through the activate-jobs operation
  • retries - the new amount of retries for the job; must be positive
Response

The binding does not return a response body.

throw-error

The throw-error operation throw an error to indicate that a business error is occurred while processing the job. The error is identified by an error code and is handled by an error catch event in the process with the same error code.

To perform a throw-error operation, invoke the Zeebe command binding with a POST method, and the following JSON body:

  1. {
  2. "data": {
  3. "jobKey": 2251799813686172,
  4. "errorCode": "product-fetch-error",
  5. "errorMessage": "The product could not be fetched"
  6. },
  7. "operation": "throw-error"
  8. }

The data parameters are:

  • jobKey - the unique job identifier, as obtained when activating the job
  • errorCode - the error code that will be matched with an error catch event
  • errorMessage - (optional) an error message that provides additional context
Response

The binding does not return a response body.

Last modified October 12, 2023: Update config.toml (#3826) (0ffc2e7)