Interface ExternalTaskService
- All Known Implementing Classes:
- ExternalTaskServiceImpl
ExternalTask instances. External tasks
 represent work items that are processed externally and independently of the process
 engine.- Author:
- Thorben Lindhauer, Christopher Zell
- 
Method SummaryModifier and TypeMethodDescriptionvoidCompletes an external task on behalf of a worker.voidCompletes an external task on behalf of a worker and submits variables to the process instance before continuing execution.voidcomplete(String externalTaskId, String workerId, Map<String, Object> variables, Map<String, Object> localVariables) Completes an external task on behalf of a worker and submits variables to the process instance before continuing execution.Queries for tasks that the currently authenticated user has at least one of the following permissions for:Permissions.READonResources.PROCESS_INSTANCEPermissions.READ_INSTANCEonResources.PROCESS_DEFINITIONvoidextendLock(String externalTaskId, String workerId, long newLockDuration) Extends a lock of an external task on behalf of a worker.fetchAndLock(int maxTasks, String workerId) Calls method fetchAndLock(maxTasks, workerId, usePriority), where usePriority is false.fetchAndLock(int maxTasks, String workerId, boolean usePriority) Defines fetching of external tasks by using a fluent builder.getExternalTaskErrorDetails(String externalTaskId) Returns the full error details that occurred while running external task with the given id.Returns a list of distinct topic names of all currently existing external tasks.getTopicNames(boolean withLockedTasks, boolean withUnlockedTasks, boolean withRetriesLeft) Returns a list of distinct topic names of all currently existing external tasks restricted by the parameters.voidhandleBpmnError(String externalTaskId, String workerId, String errorCode) Signals that an business error appears, which should be handled by the process engine.voidhandleBpmnError(String externalTaskId, String workerId, String errorCode, String errorMessage) Signals that an business error appears, which should be handled by the process engine.voidhandleBpmnError(String externalTaskId, String workerId, String errorCode, String errorMessage, Map<String, Object> variables) Signals that an business error appears, which should be handled by the process engine.voidhandleFailure(String externalTaskId, String workerId, String errorMessage, int retries, long retryTimeout) Signals that an external task could not be successfully executed.voidhandleFailure(String externalTaskId, String workerId, String errorMessage, String errorDetails, int retries, long retryTimeout) Signals that an external task could not be successfully executed.voidhandleFailure(String externalTaskId, String workerId, String errorMessage, String errorDetails, int retries, long retryDuration, Map<String, Object> variables, Map<String, Object> localVariables) Signals that an external task could not be successfully executed.voidLock an external task on behalf of a worker.voidsetPriority(String externalTaskId, long priority) Sets the priority for an external task.voidsetRetries(String externalTaskId, int retries) Sets the retries for an external task.voidsetRetries(List<String> externalTaskIds, int retries) Sets the retries for external tasks.setRetriesAsync(List<String> externalTaskIds, ExternalTaskQuery externalTaskQuery, int retries) Sets the retries for external tasks asynchronously as batch.voidUnlocks an external task instance.Sets the retries for external tasks using a fluent builder.
- 
Method Details- 
fetchAndLockCalls method fetchAndLock(maxTasks, workerId, usePriority), where usePriority is false.- Parameters:
- maxTasks- the maximum number of tasks to return
- workerId- the id of the worker to lock the tasks for
- Returns:
- a builder to define and execute an external task fetching operation
 
- 
fetchAndLockDefines fetching of external tasks by using a fluent builder. The following parameters must be specified: A worker id, a maximum number of tasks to fetch and a flag that indicates whether priority should be regarded or not. The builder allows to specify multiple topics to fetch tasks for and individual lock durations. For every topic, variables can be fetched in addition. If priority is enabled, the tasks with the highest priority are fetched. Returned tasks are locked for the given worker until now + lockDurationexpires. Locked tasks cannot be fetched or completed by other workers. When the lock time has expired, a task may be fetched and locked by other workers.Returns at most maxTaskstasks. The tasks are arbitrarily distributed among the specified topics. Example: Fetching 10 tasks of topics "a"/"b"/"c" may return 3/3/4 tasks, or 10/0/0 tasks, etc.May return less than maxTaskstasks, if there exist not enough unlocked tasks matching the provided topics or if parallel fetching by other workers results in locking failures.Returns only tasks that the currently authenticated user has at least one permission out of all of the following groups for: - Parameters:
- maxTasks- the maximum number of tasks to return
- workerId- the id of the worker to lock the tasks for
- usePriority- the flag to enable the priority fetching mechanism
- Returns:
- a builder to define and execute an external task fetching operation
 
- 
lockLock an external task on behalf of a worker. Note: Attempting to lock an already locked external task with the same workerIdwill succeed and a new lock duration will be set, starting from the current moment.- Parameters:
- externalTaskId- the id of the external task to lock
- workerId- the id of the worker to lock the task for
- lockDuration- the duration in milliseconds for which task should be locked
- Throws:
- NotFoundException- if no external task with the given id exists
- BadUserRequestException- if the task was already locked by a different worker
- AuthorizationException- thrown if the current user does not possess any of the following permissions:
 
- 
completeCompletes an external task on behalf of a worker. The given task must be assigned to the worker. - Parameters:
- externalTaskId- the id of the external task to complete
- workerId- the id of the worker that completes the task
- Throws:
- NotFoundException- if no external task with the given id exists
- BadUserRequestException- if the task is assigned to a different worker
- AuthorizationException- thrown if the current user does not possess any of the following permissions:
 
- 
completeCompletes an external task on behalf of a worker and submits variables to the process instance before continuing execution. The given task must be assigned to the worker. - Parameters:
- externalTaskId- the id of the external task to complete
- workerId- the id of the worker that completes the task
- variables- a map of variables to set on the execution (non-local) the external task is assigned to
- Throws:
- NotFoundException- if no external task with the given id exists
- BadUserRequestException- if the task is assigned to a different worker
- AuthorizationException- thrown if the current user does not possess any of the following permissions:
 
- 
completevoid complete(String externalTaskId, String workerId, Map<String, Object> variables, Map<String, Object> localVariables) Completes an external task on behalf of a worker and submits variables to the process instance before continuing execution. The given task must be assigned to the worker. - Parameters:
- externalTaskId- the id of the external task to complete
- workerId- the id of the worker that completes the task
- variables- a map of variables to set on the execution the external task is assigned to
- localVariables- a map of variables to set on the execution locally
- Throws:
- NotFoundException- if no external task with the given id exists
- BadUserRequestException- if the task is assigned to a different worker
- AuthorizationException- thrown if the current user does not possess any of the following permissions:
 
- 
extendLockExtends a lock of an external task on behalf of a worker. The given task must be assigned to the worker. - Parameters:
- externalTaskId- the id of the external task
- workerId- the id of the worker that extends the lock of the task
- Throws:
- NotFoundException- if no external task with the given id exists
- BadUserRequestException- if the task is assigned to a different worker
- AuthorizationException- thrown if the current user does not possess any of the following permissions:
 
- 
handleFailurevoid handleFailure(String externalTaskId, String workerId, String errorMessage, int retries, long retryTimeout) Signals that an external task could not be successfully executed. The task must be assigned to the given worker. The number of retries left can be specified. In addition, a timeout can be provided, such that the task cannot be fetched before now + retryTimeoutagain.If retriesis 0, an incident with the given error message is created. The incident gets resolved, once the number of retries is increased again.Exceptions raised in evaluating expressions of error event definitions attached to the task will be ignored by this method and the event definitions considered as not-matching. - Parameters:
- externalTaskId- the id of the external task to report a failure for
- workerId- the id of the worker that reports the failure
- errorMessage- short error message related to this failure. This message can be retrieved via- ExternalTask.getErrorMessage()and is used as the incident message in case- retriesis- null. May be- null.
- retries- the number of retries left. External tasks with 0 retries cannot be fetched anymore unless the number of retries is increased via API. Must be >= 0.
- retryTimeout- the timeout before the task can be fetched again. Must be >= 0.
- Throws:
- NotFoundException- if no external task with the given id exists
- BadUserRequestException- if the task is assigned to a different worker
- AuthorizationException- thrown if the current user does not possess any of the following permissions:
 
- 
handleFailurevoid handleFailure(String externalTaskId, String workerId, String errorMessage, String errorDetails, int retries, long retryTimeout) Signals that an external task could not be successfully executed. The task must be assigned to the given worker. The number of retries left can be specified. In addition, a timeout can be provided, such that the task cannot be fetched before now + retryTimeoutagain.If retriesis 0, an incident with the given error message is created. The incident gets resolved, once the number of retries is increased again.Exceptions raised in evaluating expressions of error event definitions attached to the task will be ignored by this method and the event definitions considered as not-matching. - Parameters:
- externalTaskId- the id of the external task to report a failure for
- workerId- the id of the worker that reports the failure
- errorMessage- short error message related to this failure. This message can be retrieved via- ExternalTask.getErrorMessage()and is used as the incident message in case- retriesis- null. May be- null.
- errorDetails- full error message related to this failure. This message can be retrieved via- getExternalTaskErrorDetails(String)()}
- retries- the number of retries left. External tasks with 0 retries cannot be fetched anymore unless the number of retries is increased via API. Must be >= 0.
- retryTimeout- the timeout before the task can be fetched again. Must be >= 0.
- Throws:
- NotFoundException- if no external task with the given id exists
- BadUserRequestException- if the task is assigned to a different worker
- AuthorizationException- thrown if the current user does not possess any of the following permissions:
 
- 
handleFailurevoid handleFailure(String externalTaskId, String workerId, String errorMessage, String errorDetails, int retries, long retryDuration, Map<String, Object> variables, Map<String, Object> localVariables) Signals that an external task could not be successfully executed. The task must be assigned to the given worker. The number of retries left can be specified. In addition, a timeout can be provided, such that the task cannot be fetched before now + retryTimeoutagain.If retriesis 0, an incident with the given error message is created. The incident gets resolved, once the number of retries is increased again.Exceptions raised in evaluating expressions of error event definitions attached to the task will be ignored by this method and the event definitions considered as not-matching. Variables passed with thevariablesorlocalVariablesparameter will be set before any output mapping is performed.- Parameters:
- externalTaskId- the id of the external task to report a failure for
- workerId- the id of the worker that reports the failure
- errorMessage- short error message related to this failure. This message can be retrieved via- ExternalTask.getErrorMessage()and is used as the incident message in case- retriesis- null. May be- null.
- errorDetails- full error message related to this failure. This message can be retrieved via- getExternalTaskErrorDetails(String)()}
- retries- the number of retries left. External tasks with 0 retries cannot be fetched anymore unless the number of retries is increased via API. Must be >= 0.
- retryTimeout- the timeout before the task can be fetched again. Must be >= 0.
- variables- a map of variables to set on the execution the external task is assigned to
- localVariables- a map of variables to set on the execution locally
- Throws:
- NotFoundException- if no external task with the given id exists
- BadUserRequestException- if the task is assigned to a different worker
- AuthorizationException- thrown if the current user does not possess any of the following permissions:
 
- 
handleBpmnErrorSignals that an business error appears, which should be handled by the process engine. The task must be assigned to the given worker. The error will be propagated to the next error handler. Is no existing error handler for the given bpmn error the activity instance of the external task ends. - Parameters:
- externalTaskId- the id of the external task to report a bpmn error
- workerId- the id of the worker that reports the bpmn error
- errorCode- the error code of the corresponding bmpn error
- Throws:
- NotFoundException- if no external task with the given id exists
- BadUserRequestException- if the task is assigned to a different worker
- AuthorizationException- thrown if the current user does not possess any of the following permissions:
- Since:
- 7.5
 
- 
handleBpmnErrorSignals that an business error appears, which should be handled by the process engine. The task must be assigned to the given worker. The error will be propagated to the next error handler. Is no existing error handler for the given bpmn error the activity instance of the external task ends. - Parameters:
- externalTaskId- the id of the external task to report a bpmn error
- workerId- the id of the worker that reports the bpmn error
- errorCode- the error code of the corresponding bmpn error
- errorMessage- the error message of the corresponding bmpn error
- Throws:
- NotFoundException- if no external task with the given id exists
- BadUserRequestException- if the task is assigned to a different worker
- AuthorizationException- thrown if the current user does not possess any of the following permissions:
- Since:
- 7.10
 
- 
handleBpmnErrorvoid handleBpmnError(String externalTaskId, String workerId, String errorCode, String errorMessage, Map<String, Object> variables) Signals that an business error appears, which should be handled by the process engine. The task must be assigned to the given worker. The error will be propagated to the next error handler. Is no existing error handler for the given bpmn error the activity instance of the external task ends. - Parameters:
- externalTaskId- the id of the external task to report a bpmn error
- workerId- the id of the worker that reports the bpmn error
- errorCode- the error code of the corresponding bmpn error
- errorMessage- the error message of the corresponding bmpn error
- variables- the variables to pass to the execution
- Throws:
- NotFoundException- if no external task with the given id exists
- BadUserRequestException- if the task is assigned to a different worker
- AuthorizationException- thrown if the current user does not possess any of the following permissions:
- Since:
- 7.10
 
- 
unlockUnlocks an external task instance.- Parameters:
- externalTaskId- the id of the task to unlock
- Throws:
- NotFoundException- if no external task with the given id exists
- AuthorizationException- thrown if the current user does not possess any of the following permissions:
 
- 
setRetriesSets the retries for an external task. If the new value is 0, a new incident with anullmessage is created. If the old value is 0 and the new value is greater than 0, an existing incident is resolved.- Parameters:
- externalTaskId- the id of the task to set the
- retries-
- Throws:
- NotFoundException- if no external task with the given id exists
- AuthorizationException- thrown if the current user does not possess any of the following permissions:
 
- 
setRetriesSets the retries for external tasks. If the new value is 0, a new incident with anullmessage is created. If the old value is 0 and the new value is greater than 0, an existing incident is resolved.- Parameters:
- externalTaskIds- the ids of the tasks to set the
- retries-
- Throws:
- NotFoundException- if no external task with one of the given id exists
- BadUserRequestException- if the ids are null or the number of retries is negative
- AuthorizationException- thrown if the current user does not possess any of the following permissions:
 
- 
setRetriesAsyncBatch setRetriesAsync(List<String> externalTaskIds, ExternalTaskQuery externalTaskQuery, int retries) Sets the retries for external tasks asynchronously as batch. The returned batch can be used to track the progress. If the new value is 0, a new incident with anullmessage is created. If the old value is 0 and the new value is greater than 0, an existing incident is resolved.- Parameters:
- externalTaskIds- the ids of the tasks to set the
- retries-
- externalTaskQuery- a query which selects the external tasks to set the retries for.
- Returns:
- the batch
- Throws:
- NotFoundException- if no external task with one of the given id exists
- BadUserRequestException- if the ids are null or the number of retries is negative
- AuthorizationException- If the user has no- Permissions.CREATEor- BatchPermissions.CREATE_BATCH_SET_EXTERNAL_TASK_RETRIESpermission on- Resources.BATCH.
 
- 
updateRetriesUpdateExternalTaskRetriesSelectBuilder updateRetries()Sets the retries for external tasks using a fluent builder. Specify the instances by calling one of the following methods, like externalTaskIds. To set the retries callUpdateExternalTaskRetriesBuilder.set(int)orUpdateExternalTaskRetriesBuilder.setAsync(int).- Since:
- 7.8
 
- 
setPrioritySets the priority for an external task.- Parameters:
- externalTaskId- the id of the task to set the
- priority- the new priority of the task
- Throws:
- NotFoundException- if no external task with the given id exists
- AuthorizationException- thrown if the current user does not possess any of the following permissions:
 
- 
createExternalTaskQueryExternalTaskQuery createExternalTaskQuery()Queries for tasks that the currently authenticated user has at least one of the following permissions for: - Returns:
- a new ExternalTaskQuerythat can be used to dynamically query for external tasks.
 
- 
getTopicNamesReturns a list of distinct topic names of all currently existing external tasks. Returns an empty list if no topics are found.
- 
getTopicNamesList<String> getTopicNames(boolean withLockedTasks, boolean withUnlockedTasks, boolean withRetriesLeft) Returns a list of distinct topic names of all currently existing external tasks restricted by the parameters. Returns an empty list if no matching tasks are found. Parameters are conjunctive, i.e. only tasks are returned that match all parameters with valuetrue. Parameters with valuefalseare effectively ignored. For example, this means that an empty list is returned if bothwithLockedTasksandwithUnlockedTasksare true.- Parameters:
- withLockedTasks- return only topic names of unlocked tasks
- withUnlockedTasks- return only topic names of locked tasks
- withRetriesLeft- return only topic names of tasks with retries remaining
 
- 
getExternalTaskErrorDetailsReturns the full error details that occurred while running external task with the given id. Returns null when the external task has no error details.- Parameters:
- externalTaskId- id of the external task, cannot be null.
- Throws:
- ProcessEngineException- When no external task exists with the given id.
- AuthorizationException- If the user has no- Permissions.READpermission on- Resources.PROCESS_INSTANCEor no- Permissions.READ_INSTANCEpermission on- Resources.PROCESS_DEFINITION.
- Since:
- 7.6
 
 
-