Class ProcessTaskDelegate
java.lang.Object
com.aquima.interactions.process.wrapper.ProcessTaskDelegate
- All Implemented Interfaces:
IProcessTask
- Direct Known Subclasses:
ReadonlyProcessTask
Utility class to allow for easy wrapping of a process engine implementation.
This an internal class.
- Since:
- 7.1
- Author:
- Jon van Leuven
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoid
abort
(IUserData userData, IProcessCaseUpdates updates) This method may be invoked to indicate the process step has been aborted.void
assign
(IUserData userData, IAssigneeInfo assigneeInfo, boolean isUserSet) This method may be used to assign the task.void
This method may be used to explicitly cancel the task.void
complete
(IUserData userData, IProcessCaseUpdates updates, String taskExit) This method may be invoked to indicate the process step has been successfully completed.IRole[]
This method returns the required roles to start this task.This method returns the AssigneeInfo of whom the task is assigned to.getCustomFieldValue
(String name) This method returns the value of a custom fieldThis method returns an optional description of the task.Returns theIMultilingualText
display name for the task.this method returns the date at which the task should be completed.Gets the name of the user that executed this task.long
getId()
This method returns the unique ID of this task.getName()
This method returns the name of the task as present in the task definition.This method returns the optional node ID this task belongs to.This method returns the priority of a task.long
This method returns the ID of the process the task is defined for.This method returns the date at which the task may start.This method returns the current status of the task.this method returns the date at which the task will expireboolean
void
setStartDate
(DateTimeValue startDate) This method may be used to change the start date of the task.void
setTimeoutDate
(IUserData userData, DateTimeValue dueDate) This method may be used to change the timeout date of the task.void
This method will attempt to mark the process step as started for the current user.void
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
Methods inherited from interface com.aquima.interactions.process.IProcessTask
evaluateAfterComplete, unassign
-
Constructor Details
-
ProcessTaskDelegate
-
-
Method Details
-
abort
Description copied from interface:IProcessTask
This method may be invoked to indicate the process step has been aborted. The abort method may be manually invoked, but can also be invoked by a session that has been closed. This method is also known as "cancel task" in the documentation.- Specified by:
abort
in interfaceIProcessTask
- Parameters:
userData
- User that aborts the execution of the task.updates
- Object containing updates that should be applied to the case data.- Throws:
AppException
- This exception is thrown when the task could not be aborted.
-
assign
public void assign(IUserData userData, IAssigneeInfo assigneeInfo, boolean isUserSet) throws ProcessDataAccessException Description copied from interface:IProcessTask
This method may be used to assign the task.- Specified by:
assign
in interfaceIProcessTask
- Parameters:
userData
- Object containing information about the current user.assigneeInfo
- The AssigneeInfo of who the task should be assigned to.- Throws:
ProcessDataAccessException
-
cancel
Description copied from interface:IProcessTask
This method may be used to explicitly cancel the task. Canceling a task may only be done for tasks that are not part of a process definition. Canceling the task will remove the task, and should not be confused with the abort task method.- Specified by:
cancel
in interfaceIProcessTask
- Parameters:
userData
- User that aborts the execution of the task.- Throws:
AppException
- This exception is thrown when the task could not be canceled.
-
complete
public void complete(IUserData userData, IProcessCaseUpdates updates, String taskExit) throws AppException Description copied from interface:IProcessTask
This method may be invoked to indicate the process step has been successfully completed. The complete operation will unlock the case again, and merge the updates from the process step with the case data. This method is also known as "close task" in the documentation.- Specified by:
complete
in interfaceIProcessTask
- Parameters:
userData
- User that marks the task as completed.updates
- Object containing updates that should be applied to the case data.taskExit
- The exit state of the completed task, may be null.- Throws:
AppException
- This exception is thrown when the current task could not be marked as completed.
-
getAssigneeInfo
Description copied from interface:IProcessTask
This method returns the AssigneeInfo of whom the task is assigned to.- Specified by:
getAssigneeInfo
in interfaceIProcessTask
- Returns:
- the AssigneeInfo of whom the task is assigned to.
-
getProcessId
public long getProcessId()Description copied from interface:IProcessTask
This method returns the ID of the process the task is defined for.- Specified by:
getProcessId
in interfaceIProcessTask
- Returns:
- The ID of the case the task is defined for.
-
getDescription
Description copied from interface:IProcessTask
This method returns an optional description of the task.- Specified by:
getDescription
in interfaceIProcessTask
- Returns:
- Description of the task
-
getTimeoutDate
Description copied from interface:IProcessTask
this method returns the date at which the task will expire- Specified by:
getTimeoutDate
in interfaceIProcessTask
- Returns:
- The date at which the task will expire
-
getId
public long getId()Description copied from interface:IProcessTask
This method returns the unique ID of this task.- Specified by:
getId
in interfaceIProcessTask
- Returns:
- the unique ID of this process step.
-
getName
Description copied from interface:IProcessTask
This method returns the name of the task as present in the task definition.- Specified by:
getName
in interfaceIProcessTask
- Returns:
- The name of the task.
-
getNodeId
Description copied from interface:IProcessTask
This method returns the optional node ID this task belongs to.- Specified by:
getNodeId
in interfaceIProcessTask
- Returns:
- the node ID of this task.
-
evaluateRequiredRoles
Description copied from interface:IProcessTask
This method returns the required roles to start this task.- Specified by:
evaluateRequiredRoles
in interfaceIProcessTask
- Returns:
- The required roles.
-
getPriority
Description copied from interface:IProcessTask
This method returns the priority of a task.- Specified by:
getPriority
in interfaceIProcessTask
- Returns:
- The priority
-
getCustomFieldValue
Description copied from interface:IProcessTask
This method returns the value of a custom field- Specified by:
getCustomFieldValue
in interfaceIProcessTask
- Parameters:
name
- the custom field name- Returns:
- null if the field does not exist or has no value for this task
-
getStartDate
Description copied from interface:IProcessTask
This method returns the date at which the task may start.- Specified by:
getStartDate
in interfaceIProcessTask
- Returns:
- The date at which the task may start.
-
getStatus
Description copied from interface:IProcessTask
This method returns the current status of the task.- Specified by:
getStatus
in interfaceIProcessTask
- Returns:
- the current status of the task.
-
setTimeoutDate
public void setTimeoutDate(IUserData userData, DateTimeValue dueDate) throws ProcessDataAccessException Description copied from interface:IProcessTask
This method may be used to change the timeout date of the task. Adjusting the timeout date of the task may cause the task to be aborted.- Specified by:
setTimeoutDate
in interfaceIProcessTask
- Parameters:
userData
- Object containing information about the current user.dueDate
- The new timeout date for the task.- Throws:
ProcessDataAccessException
-
setStartDate
Description copied from interface:IProcessTask
This method may be used to change the start date of the task.- Specified by:
setStartDate
in interfaceIProcessTask
- Parameters:
startDate
- The new timeout date for the task.- Throws:
ProcessDataAccessException
-
getDueDate
Description copied from interface:IProcessTask
this method returns the date at which the task should be completed.- Specified by:
getDueDate
in interfaceIProcessTask
- Returns:
- The date at which the task should be completed.
-
start
Description copied from interface:IProcessTask
This method will attempt to mark the process step as started for the current user. The start operation may fail if another process has updated the case, or started another task, in the time between acquiring the task and starting it. When the start method has completed without an exception, the case will be locked by the current user, and the either the complete or abort method should be invoked to release it.- Specified by:
start
in interfaceIProcessTask
- Parameters:
userData
- User that will start the task.- Throws:
AppException
- This exception is thrown when the current task could not be started.
-
unassign
- Throws:
ProcessDataAccessException
-
getExecutedBy
Description copied from interface:IProcessTask
Gets the name of the user that executed this task.- Specified by:
getExecutedBy
in interfaceIProcessTask
- Returns:
- Username
-
isUserSet
public boolean isUserSet()- Specified by:
isUserSet
in interfaceIProcessTask
- Returns:
- whether the assignee of the task is set manually by an user or by routing algorithm
-
getDisplayName
Description copied from interface:IProcessTask
Returns theIMultilingualText
display name for the task.- Specified by:
getDisplayName
in interfaceIProcessTask
- Returns:
- display name for the task
-