public class ExternalTaskServiceImpl extends ServiceImpl implements ExternalTaskService
commandExecutor| Constructor and Description | 
|---|
| ExternalTaskServiceImpl() | 
| Modifier and Type | Method and Description | 
|---|---|
| void | complete(String externalTaskId,
        String workerId)Completes an external task on behalf of a worker. | 
| void | complete(String externalTaskId,
        String workerId,
        Map<String,Object> variables)Completes an external task on behalf of a worker and submits variables
 to the process instance before continuing execution. | 
| ExternalTaskQuery | createExternalTaskQuery()
   Queries for tasks that the currently authenticated user has at least one
   of the following permissions for:
   
      Permissions.READonResources.PROCESS_INSTANCEPermissions.READ_INSTANCEonResources.PROCESS_DEFINITION | 
| ExternalTaskQueryBuilder | fetchAndLock(int maxTasks,
            String workerId)Calls method fetchAndLock(maxTasks, workerId, usePriority), where usePriority is false. | 
| ExternalTaskQueryBuilder | fetchAndLock(int maxTasks,
            String workerId,
            boolean usePriority)Defines fetching of external tasks by using a fluent builder. | 
| String | getExternalTaskErrorDetails(String externalTaskId)Returns the full error details that occurred while running external task
 with the given id. | 
| void | handleBpmnError(String externalTaskId,
               String workerId,
               String errorCode)Signals that an business error appears, which should be handled by the process engine. | 
| void | handleFailure(String externalTaskId,
             String workerId,
             String errorMessage,
             int retries,
             long retryDuration)Signals that an external task could not be successfully executed. | 
| void | handleFailure(String externalTaskId,
             String workerId,
             String errorMessage,
             String errorDetails,
             int retries,
             long retryDuration)Signals that an external task could not be successfully executed. | 
| void | setPriority(String externalTaskId,
           long priority)Sets the priority for an external task. | 
| void | setRetries(String externalTaskId,
          int retries)Sets the retries for an external task. | 
| void | unlock(String externalTaskId)Unlocks an external task instance. | 
getCommandExecutor, setCommandExecutorpublic ExternalTaskQueryBuilder fetchAndLock(int maxTasks, String workerId)
ExternalTaskServicefetchAndLock in interface ExternalTaskServicemaxTasks - the maximum number of tasks to returnworkerId - the id of the worker to lock the tasks forExternalTaskService#fetchAndLock(int, java.lang.String, boolean)}.public ExternalTaskQueryBuilder fetchAndLock(int maxTasks, String workerId, boolean usePriority)
ExternalTaskServiceDefines 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.Is the priority enabled the tasks with the highest priority are fetched.
Returned tasks are locked for the given worker until
 now + lockDuration expires.
 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 maxTasks tasks. 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 maxTasks tasks, 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:
fetchAndLock in interface ExternalTaskServicemaxTasks - the maximum number of tasks to returnworkerId - the id of the worker to lock the tasks forusePriority - the flag to enable the priority fetching mechanismpublic void complete(String externalTaskId, String workerId)
ExternalTaskServiceCompletes an external task on behalf of a worker. The given task must be assigned to the worker.
complete in interface ExternalTaskServiceexternalTaskId - the id of the external to completeworkerId - the id of the worker that completes the taskpublic void complete(String externalTaskId, String workerId, Map<String,Object> variables)
ExternalTaskServiceCompletes 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.
complete in interface ExternalTaskServiceexternalTaskId - the id of the external to completeworkerId - the id of the worker that completes the taskvariables - a map of variables to set on the execution (non-local)
   the external task is assigned topublic void handleFailure(String externalTaskId, String workerId, String errorMessage, int retries, long retryDuration)
ExternalTaskServiceSignals 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 + retryTimeout again.
If retries is 0, an incident with the given error message is created. The incident gets resolved,
 once the number of retries is increased again.
handleFailure in interface ExternalTaskServiceexternalTaskId - the id of the external task to report a failure forworkerId - the id of the worker that reports the failureerrorMessage - short error message related to this failure. This message can be retrieved via
   ExternalTask.getErrorMessage() and is used as the incident message in case retries is 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.retryDuration - the timeout before the task can be fetched again. Must be >= 0.public void handleFailure(String externalTaskId, String workerId, String errorMessage, String errorDetails, int retries, long retryDuration)
ExternalTaskServiceSignals 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 + retryTimeout again.
If retries is 0, an incident with the given error message is created. The incident gets resolved,
 once the number of retries is increased again.
handleFailure in interface ExternalTaskServiceexternalTaskId - the id of the external task to report a failure forworkerId - the id of the worker that reports the failureerrorMessage - short error message related to this failure. This message can be retrieved via
   ExternalTask.getErrorMessage() and is used as the incident message in case retries is null.
   May be null.errorDetails - full error message related to this failure. This message can be retrieved via
   ExternalTaskService.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.retryDuration - the timeout before the task can be fetched again. Must be >= 0.public void handleBpmnError(String externalTaskId, String workerId, String errorCode)
ExternalTaskServiceSignals 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.
handleBpmnError in interface ExternalTaskServiceexternalTaskId - the id of the external task to report a bpmn errorworkerId - the id of the worker that reports the bpmn errorerrorCode - the error code of the corresponding bmpn errorpublic void unlock(String externalTaskId)
ExternalTaskServiceunlock in interface ExternalTaskServiceexternalTaskId - the id of the task to unlockpublic void setRetries(String externalTaskId, int retries)
ExternalTaskServicenull
 message is created. If the old value is 0 and the new value is greater than 0, an existing incident
 is resolved.setRetries in interface ExternalTaskServiceexternalTaskId - the id of the task to set thepublic void setPriority(String externalTaskId, long priority)
ExternalTaskServicesetPriority in interface ExternalTaskServiceexternalTaskId - the id of the task to set thepriority - the new priority of the taskpublic ExternalTaskQuery createExternalTaskQuery()
ExternalTaskServiceQueries for tasks that the currently authenticated user has at least one of the following permissions for:
createExternalTaskQuery in interface ExternalTaskServiceExternalTaskQuery that can be used to dynamically
 query for external tasks.public String getExternalTaskErrorDetails(String externalTaskId)
ExternalTaskServicegetExternalTaskErrorDetails in interface ExternalTaskServiceexternalTaskId - id of the external task, cannot be null.Copyright © 2018. All rights reserved.