Class ExternalTaskEntity
java.lang.Object
org.camunda.bpm.engine.impl.persistence.entity.ExternalTaskEntity
- All Implemented Interfaces:
- ExternalTask,- DbEntity,- HasDbReferences,- HasDbRevision
public class ExternalTaskEntity
extends Object
implements ExternalTask, DbEntity, HasDbRevision, HasDbReferences
- Author:
- Thorben Lindhauer, Askar Akhmerov
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprotected Stringprotected Stringprotected Stringprotected Dateprotected ByteArrayEntityprotected Stringprotected Stringprotected ExecutionEntityprotected Stringprotected Stringprotected Stringprotected Dateprotected static final EnginePersistenceLoggerstatic final intNote:String.length()counts Unicode supplementary characters twice, so for a String consisting only of those, the limit is effectively MAX_EXCEPTION_MESSAGE_LENGTH / 2protected longprotected Stringprotected Stringprotected Stringprotected Stringprotected Integerprotected intprotected intprotected Stringprotected Stringprotected String
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionbooleanvoidvoidstatic ExternalTaskEntitycreateAndInsert(ExecutionEntity execution, String topic, long priority) protected voidprotected IncidentContextvoiddelete()protected voiddeleteFromExecutionAndRuntimeTable(boolean incidentResolved) protected voidprotected voidprotected voidensureExecutionInitialized(boolean validateExistence) protected voidensureVariablesSet(ExecutionEntity execution, Map<String, Object> variables, Map<String, Object> localVariables) protected booleanerrorEventDefinitionMatches(CamundaErrorEventDefinition camundaErrorEventDefinition, boolean continueOnException) protected booleanevaluateThrowBpmnError(ExecutionEntity execution, boolean continueOnException) voidextendLock(long newLockExpirationTime) voidfailed(String errorMessage, String errorDetails, int retries, long retryDuration, Map<String, Object> variables, Map<String, Object> localVariables) process failed state, make sure that binary entity is created for the errorMessage, shortError message does not exceed limit, handle properly retry counts and incidentsReturns the business key of the process instance the external task belongs toprotected ByteArrayEntityMethod implementation relies on the command context object, therefore should be invoked from the commands onlygetExecution(boolean validateExistence) Returns a map containing all custom extension properties of the external task.getId()Returns a representation of the object, as would be stored in the database.longReturns the priority of the external task.Scope: IN-MEMORY referencesScope: IN-MEMORY referencesintintintvoidinsert()booleanvoidprotected voidprotected voidprotected voidprotected voidprotected voidremoveIncidents(boolean incidentResolved) voidsetActivityId(String activityId) voidsetActivityInstanceId(String activityInstanceId) voidsetBusinessKey(String businessKey) voidsetCreateTime(Date createTime) protected voidsetErrorDetails(String exception) voidsetErrorMessage(String errorMessage) voidsetExecution(ExecutionEntity execution) voidsetExecutionId(String executionId) voidsetExtensionProperties(Map<String, String> extensionProperties) voidvoidsetLastFailureLogId(String lastFailureLogId) voidsetLockExpirationTime(Date lockExpirationTime) voidsetPriority(long priority) voidsetProcessDefinitionId(String processDefinitionId) voidsetProcessDefinitionKey(String processDefinitionKey) voidsetProcessDefinitionVersionTag(String processDefinitionVersionTag) voidsetProcessInstanceId(String processInstanceId) voidsetRetries(Integer retries) voidsetRetriesAndManageIncidents(int retries) voidsetRevision(int revision) voidsetSuspensionState(int suspensionState) voidsetTenantId(String tenantId) voidsetTopicName(String topic) voidsetWorkerId(String workerId) toString()voidunlock()Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface org.camunda.bpm.engine.impl.db.HasDbReferencesgetDependentEntities
- 
Field Details- 
LOG
- 
MAX_EXCEPTION_MESSAGE_LENGTHpublic static final int MAX_EXCEPTION_MESSAGE_LENGTHNote:String.length()counts Unicode supplementary characters twice, so for a String consisting only of those, the limit is effectively MAX_EXCEPTION_MESSAGE_LENGTH / 2- See Also:
 
- 
id
- 
revisionprotected int revision
- 
topicName
- 
workerId
- 
lockExpirationTime
- 
createTime
- 
retries
- 
errorMessage
- 
errorDetailsByteArray
- 
errorDetailsByteArrayId
- 
suspensionStateprotected int suspensionState
- 
executionId
- 
processInstanceId
- 
processDefinitionId
- 
processDefinitionKey
- 
processDefinitionVersionTag
- 
activityId
- 
activityInstanceId
- 
tenantId
- 
priorityprotected long priority
- 
extensionProperties
- 
execution
- 
businessKey
- 
lastFailureLogId
 
- 
- 
Constructor Details- 
ExternalTaskEntitypublic ExternalTaskEntity()
 
- 
- 
Method Details- 
getId- Specified by:
- getIdin interface- DbEntity
- Specified by:
- getIdin interface- ExternalTask
- Returns:
- the id of the task
 
- 
setId
- 
getTopicName- Specified by:
- getTopicNamein interface- ExternalTask
- Returns:
- the name of the topic the task belongs to
 
- 
setTopicName
- 
getWorkerId- Specified by:
- getWorkerIdin interface- ExternalTask
- Returns:
- the id of the worker that has locked the task
 
- 
setWorkerId
- 
getLockExpirationTime- Specified by:
- getLockExpirationTimein interface- ExternalTask
- Returns:
- the absolute time at which the lock expires
 
- 
setLockExpirationTime
- 
getCreateTime- Specified by:
- getCreateTimein interface- ExternalTask
- Returns:
- the absolute time at which the task was created
 
- 
setCreateTime
- 
getExecutionId- Specified by:
- getExecutionIdin interface- ExternalTask
- Returns:
- the id of the execution that the task is assigned to
 
- 
setExecutionId
- 
getProcessDefinitionKey- Specified by:
- getProcessDefinitionKeyin interface- ExternalTask
- Returns:
- the key of the process definition the tasks activity belongs to
 
- 
setProcessDefinitionKey
- 
getProcessDefinitionVersionTag- Specified by:
- getProcessDefinitionVersionTagin interface- ExternalTask
- Returns:
- the version tag of the process definition the tasks activity belongs to
 
- 
setProcessDefinitionVersionTag
- 
getActivityId- Specified by:
- getActivityIdin interface- ExternalTask
- Returns:
- the id of the activity for which the task is created
 
- 
setActivityId
- 
getActivityInstanceId- Specified by:
- getActivityInstanceIdin interface- ExternalTask
- Returns:
- the id of the activity instance in which context the task exists
 
- 
setActivityInstanceId
- 
getRevisionpublic int getRevision()- Specified by:
- getRevisionin interface- HasDbRevision
 
- 
setRevisionpublic void setRevision(int revision) - Specified by:
- setRevisionin interface- HasDbRevision
 
- 
getRevisionNextpublic int getRevisionNext()- Specified by:
- getRevisionNextin interface- HasDbRevision
 
- 
getSuspensionStatepublic int getSuspensionState()
- 
setSuspensionStatepublic void setSuspensionState(int suspensionState) 
- 
isSuspendedpublic boolean isSuspended()- Specified by:
- isSuspendedin interface- ExternalTask
- Returns:
- true if the external task is suspended; a suspended external task cannot be completed, thereby preventing process continuation
 
- 
getProcessInstanceId- Specified by:
- getProcessInstanceIdin interface- ExternalTask
- Returns:
- the id of the process instance the task exists in
 
- 
setProcessInstanceId
- 
getProcessDefinitionId- Specified by:
- getProcessDefinitionIdin interface- ExternalTask
- Returns:
- the id of the process definition the tasks activity belongs to
 
- 
setProcessDefinitionId
- 
getTenantId- Specified by:
- getTenantIdin interface- ExternalTask
- Returns:
- the id of the tenant the task belongs to. Can be nullif the task belongs to no single tenant.
 
- 
setTenantId
- 
getRetries- Specified by:
- getRetriesin interface- ExternalTask
- Returns:
- the number of retries left. The number of retries is provided by
   a task client, therefore the initial value is null.
 
- 
setRetries
- 
getErrorMessage- Specified by:
- getErrorMessagein interface- ExternalTask
- Returns:
- short error message submitted with the latest reported failure executing this task;
   nullif no failure was reported previously or if no error message was submitted
- See Also:
 
- 
areRetriesLeftpublic boolean areRetriesLeft()
- 
getPrioritypublic long getPriority()Description copied from interface:ExternalTaskReturns the priority of the external task.- Specified by:
- getPriorityin interface- ExternalTask
- Returns:
- the priority of the external task
 
- 
setPrioritypublic void setPriority(long priority) 
- 
getBusinessKeyDescription copied from interface:ExternalTaskReturns the business key of the process instance the external task belongs to- Specified by:
- getBusinessKeyin interface- ExternalTask
- Returns:
- the business key
 
- 
setBusinessKey
- 
getExtensionPropertiesDescription copied from interface:ExternalTaskReturns a map containing all custom extension properties of the external task.- Specified by:
- getExtensionPropertiesin interface- ExternalTask
- Returns:
- the properties, never null
 
- 
setExtensionProperties
- 
getPersistentStateDescription copied from interface:DbEntityReturns a representation of the object, as would be stored in the database. Used when deciding if updates have occurred to the object or not since it was last loaded.- Specified by:
- getPersistentStatein interface- DbEntity
 
- 
insertpublic void insert()
- 
getErrorDetailsMethod implementation relies on the command context object, therefore should be invoked from the commands only- Returns:
- error details persisted in byte array table
 
- 
setErrorMessage
- 
setErrorDetails
- 
getErrorDetailsByteArrayId
- 
getErrorByteArray
- 
ensureErrorByteArrayInitializedprotected void ensureErrorByteArrayInitialized()
- 
deletepublic void delete()
- 
deleteFromExecutionAndRuntimeTableprotected void deleteFromExecutionAndRuntimeTable(boolean incidentResolved) 
- 
removeIncidentsprotected void removeIncidents(boolean incidentResolved) 
- 
complete
- 
failedpublic void failed(String errorMessage, String errorDetails, int retries, long retryDuration, Map<String, Object> variables, Map<String, Object> localVariables) process failed state, make sure that binary entity is created for the errorMessage, shortError message does not exceed limit, handle properly retry counts and incidents- Parameters:
- errorMessage- - short error message text
- errorDetails- - full error details
- retries- - updated value of retries left
- retryDuration- - used for lockExpirationTime calculation
 
- 
bpmnError
- 
setRetriesAndManageIncidentspublic void setRetriesAndManageIncidents(int retries) 
- 
createIncidentprotected void createIncident()
- 
createIncidentContext
- 
lock
- 
getExecution
- 
getExecution
- 
setExecution
- 
ensureExecutionInitializedprotected void ensureExecutionInitialized(boolean validateExistence) 
- 
ensureActiveprotected void ensureActive()
- 
ensureVariablesSet
- 
evaluateThrowBpmnError
- 
errorEventDefinitionMatchesprotected boolean errorEventDefinitionMatches(CamundaErrorEventDefinition camundaErrorEventDefinition, boolean continueOnException) 
- 
toString
- 
unlockpublic void unlock()
- 
createAndInsertpublic static ExternalTaskEntity createAndInsert(ExecutionEntity execution, String topic, long priority) 
- 
produceHistoricExternalTaskCreatedEventprotected void produceHistoricExternalTaskCreatedEvent()
- 
produceHistoricExternalTaskFailedEventprotected void produceHistoricExternalTaskFailedEvent()
- 
produceHistoricExternalTaskSuccessfulEventprotected void produceHistoricExternalTaskSuccessfulEvent()
- 
produceHistoricExternalTaskDeletedEventprotected void produceHistoricExternalTaskDeletedEvent()
- 
extendLockpublic void extendLock(long newLockExpirationTime) 
- 
getReferencedEntityIdsDescription copied from interface:HasDbReferencesScope: IN-MEMORY references - Specified by:
- getReferencedEntityIdsin interface- HasDbReferences
- Returns:
- the ids of the entities that this entity references. Should only return ids for entities of the same type
 
- 
getReferencedEntitiesIdAndClassDescription copied from interface:HasDbReferencesScope: IN-MEMORY references - Specified by:
- getReferencedEntitiesIdAndClassin interface- HasDbReferences
- Returns:
- a map of the ids and the entities' classes that this entity references. It's used when trying to determine if there was an Optimistic Locking occurrence on an INSERT or UPDATE of an object of this type.
 
- 
getLastFailureLogId
- 
setLastFailureLogId
 
-