All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.camunda.bpm.engine.TaskService Maven / Gradle / Ivy

/*
 * Copyright Camunda Services GmbH and/or licensed to Camunda Services GmbH
 * under one or more contributor license agreements. See the NOTICE file
 * distributed with this work for additional information regarding copyright
 * ownership. Camunda licenses this file to you under the Apache License,
 * Version 2.0; you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package org.camunda.bpm.engine;

import java.io.InputStream;
import java.util.Collection;
import java.util.List;
import java.util.Map;

import org.camunda.bpm.engine.authorization.Permissions;
import org.camunda.bpm.engine.authorization.ProcessDefinitionPermissions;
import org.camunda.bpm.engine.authorization.Resources;
import org.camunda.bpm.engine.authorization.TaskPermissions;
import org.camunda.bpm.engine.exception.NotFoundException;
import org.camunda.bpm.engine.history.UserOperationLogEntry;
import org.camunda.bpm.engine.history.UserOperationLogQuery;
import org.camunda.bpm.engine.task.Attachment;
import org.camunda.bpm.engine.task.Comment;
import org.camunda.bpm.engine.task.DelegationState;
import org.camunda.bpm.engine.task.Event;
import org.camunda.bpm.engine.task.IdentityLink;
import org.camunda.bpm.engine.task.IdentityLinkType;
import org.camunda.bpm.engine.task.NativeTaskQuery;
import org.camunda.bpm.engine.task.Task;
import org.camunda.bpm.engine.task.TaskQuery;
import org.camunda.bpm.engine.task.TaskReport;
import org.camunda.bpm.engine.variable.VariableMap;
import org.camunda.bpm.engine.variable.value.SerializableValue;
import org.camunda.bpm.engine.variable.value.TypedValue;

/** Service which provides access to {@link Task} and form related operations.
 *
 * @author Tom Baeyens
 * @author Joram Barrez
 * @author Thorben Lindhauer
 */
public interface TaskService {

  /**
   * Creates a new task that is not related to any process instance.
   *
   * The returned task is transient and must be saved with {@link #saveTask(Task)} 'manually'.
   *
   * @throws AuthorizationException
   *          if the user has no {@link Permissions#CREATE} permission on {@link Resources#TASK}.
   */
  Task newTask();

  /** create a new task with a user defined task id */
  Task newTask(String taskId);

  /**
   * Saves the given task to the persistent data store. If the task is already
   * present in the persistent store, it is updated.
   * After a new task has been saved, the task instance passed into this method
   * is updated with the id of the newly created task.
   *
   * @param task the task, cannot be null.
   *
   * @throws AuthorizationException
   *          If the task is already present and the user has no {@link Permissions#UPDATE} permission
   *          on {@link Resources#TASK} or no {@link Permissions#UPDATE_TASK} permission on
   *          {@link Resources#PROCESS_DEFINITION}.
   *          Or if the task is not present and the user has no {@link Permissions#CREATE} permission
   *          on {@link Resources#TASK}.
   */
  void saveTask(Task task);

  /**
   * Deletes the given task, not deleting historic information that is related to this task.
   *
   * @param taskId The id of the task that will be deleted, cannot be null. If no task
   * exists with the given taskId, the operation is ignored.
   *
   * @throws ProcessEngineException
   *          when an error occurs while deleting the task or in case the task is part
   *          of a running process or case instance.
   * @throws AuthorizationException
   *          If the user has no {@link Permissions#DELETE} permission on {@link Resources#TASK}.
   */
  void deleteTask(String taskId);

  /**
   * Deletes all tasks of the given collection, not deleting historic information that is related
   * to these tasks.
   *
   * @param taskIds The id's of the tasks that will be deleted, cannot be null. All
   * id's in the list that don't have an existing task will be ignored.
   *
   * @throws ProcessEngineException
   *          when an error occurs while deleting the tasks or in case one of the tasks
   *          is part of a running process or case instance.
   * @throws AuthorizationException
   *          If the user has no {@link Permissions#DELETE} permission on {@link Resources#TASK}.
   */
  void deleteTasks(Collection taskIds);

  /**
   * Deletes the given task.
   *
   * @param taskId The id of the task that will be deleted, cannot be null. If no task
   * exists with the given taskId, the operation is ignored.
   *
   * @param cascade If cascade is true, also the historic information related to this task is deleted.
   *
   * @throws ProcessEngineException
   *          when an error occurs while deleting the task or in case the task is part
   *          of a running process or case instance.
   * @throws AuthorizationException
   *          If the user has no {@link Permissions#DELETE} permission on {@link Resources#TASK}.
   */
  void deleteTask(String taskId, boolean cascade);

  /**
   * Deletes all tasks of the given collection.
   *
   * @param taskIds The id's of the tasks that will be deleted, cannot be null. All
   * id's in the list that don't have an existing task will be ignored.
   * @param cascade If cascade is true, also the historic information related to this task is deleted.
   *
   * @throws ProcessEngineException
   *          when an error occurs while deleting the tasks or in case one of the tasks
   *          is part of a running process or case instance.
   * @throws AuthorizationException
   *          If the user has no {@link Permissions#DELETE} permission on {@link Resources#TASK}.
   */
  void deleteTasks(Collection taskIds, boolean cascade);

  /**
   * Deletes the given task, not deleting historic information that is related to this task.
   *
   * @param taskId The id of the task that will be deleted, cannot be null. If no task
   * exists with the given taskId, the operation is ignored.
   * @param deleteReason reason the task is deleted. Is recorded in history, if enabled.
   *
   * @throws ProcessEngineException
   *          when an error occurs while deleting the task or in case the task is part
   *          of a running process or case instance.
   * @throws AuthorizationException
   *          If the user has no {@link Permissions#DELETE} permission on {@link Resources#TASK}.
   */
  void deleteTask(String taskId, String deleteReason);

  /**
   * Deletes all tasks of the given collection, not deleting historic information that is related to these tasks.
   *
   * @param taskIds The id's of the tasks that will be deleted, cannot be null. All
   * id's in the list that don't have an existing task will be ignored.
   * @param deleteReason reason the task is deleted. Is recorded in history, if enabled.
   *
   * @throws ProcessEngineException
   *          when an error occurs while deleting the tasks or in case one of the tasks
   *          is part of a running process or case instance.
   * @throws AuthorizationException
   *          If the user has no {@link Permissions#DELETE} permission on {@link Resources#TASK}.
   */
  void deleteTasks(Collection taskIds, String deleteReason);

  /**
   * Claim responsibility for a task:
   * the given user is made {@link Task#getAssignee() assignee} for the task.
   * The difference with {@link #setAssignee(String, String)} is that here
   * a check is done if the task already has a user assigned to it.
   * No check is done whether the user is known by the identity component.
   *
   * @param taskId task to claim, cannot be null.
   * @param userId user that claims the task. When userId is null the task is unclaimed,
   * assigned to no one.
   *
   * @throws ProcessEngineException
   *          when the task doesn't exist or when the task is already claimed by another user.
   * @throws AuthorizationException
   *          If the user has no {@link Permissions#UPDATE} permission on {@link Resources#TASK}
   *          or no {@link Permissions#UPDATE_TASK} permission on {@link Resources#PROCESS_DEFINITION}
   *          (if the task is part of a running process instance).
   */
  void claim(String taskId, String userId);

  /**
   * Marks a task as done and continues process execution.
   *
   * This method is typically called by a task list user interface
   * after a task form has been submitted by the
   * {@link Task#getAssignee() assignee}.
   *
   * @param taskId the id of the task to complete, cannot be null.
   *
   * @throws ProcessEngineException
   *          when no task exists with the given id or when this task is {@link DelegationState#PENDING} delegation.
   * @throws AuthorizationException
   *          If the user has no {@link Permissions#UPDATE} permission on {@link Resources#TASK}
   *          or no {@link Permissions#UPDATE_TASK} permission on {@link Resources#PROCESS_DEFINITION}
   *          (if the task is part of a running process instance).
   */
  void complete(String taskId);

  /**
   * Delegates the task to another user.
   *
   * This means that the {@link Task#getAssignee() assignee} is set
   * and the {@link Task#getDelegationState() delegation state} is set to
   * {@link DelegationState#PENDING}.
   * If no owner is set on the task, the owner is set to the current
   * {@link Task#getAssignee() assignee} of the task.
   * The new assignee must use {@link TaskService#resolveTask(String)}
   * to report back to the owner.
   * Only the owner can {@link TaskService#complete(String) complete} the task.
   *
   * @param taskId The id of the task that will be delegated.
   * @param userId The id of the user that will be set as assignee.
   *
   * @throws ProcessEngineException
   *          when no task exists with the given id.
   * @throws AuthorizationException
   *          If the user has no {@link Permissions#UPDATE} permission on {@link Resources#TASK}
   *          or no {@link Permissions#UPDATE_TASK} permission on {@link Resources#PROCESS_DEFINITION}
   *          (if the task is part of a running process instance).
   */
  void delegateTask(String taskId, String userId);

  /**
   * Marks that the {@link Task#getAssignee() assignee} is done with the task
   * {@link TaskService#delegateTask(String, String) delegated}
   * to her and that it can be sent back to the {@link Task#getOwner() owner}.
   * Can only be called when this task is {@link DelegationState#PENDING} delegation.
   * After this method returns, the {@link Task#getDelegationState() delegation state}
   * is set to {@link DelegationState#RESOLVED} and the task can be
   * {@link TaskService#complete(String) completed}.
   *
   * @param taskId the id of the task to resolve, cannot be null.
   *
   * @throws ProcessEngineException
   *          when no task exists with the given id.
   * @throws AuthorizationException
   *          If the user has no {@link Permissions#UPDATE} permission on {@link Resources#TASK}
   *          or no {@link Permissions#UPDATE_TASK} permission on {@link Resources#PROCESS_DEFINITION}
   *          (if the task is part of a running process instance).
   */
  void resolveTask(String taskId);

  /**
   * Marks that the {@link Task#getAssignee() assignee} is done with the task
   * {@link TaskService#delegateTask(String, String) delegated}
   * to her and that it can be sent back to the {@link Task#getOwner() owner}
   * with the provided variables.
   * Can only be called when this task is {@link DelegationState#PENDING} delegation.
   * After this method returns, the {@link Task#getDelegationState() delegation state}
   * is set to {@link DelegationState#RESOLVED} and the task can be
   * {@link TaskService#complete(String) completed}.
   *
   * @param taskId
   * @param variables
   *
   * @throws ProcessEngineException
   *          when no task exists with the given id.
   * @throws AuthorizationException
   *          If the user has no {@link Permissions#UPDATE} permission on {@link Resources#TASK}
   *          or no {@link Permissions#UPDATE_TASK} permission on {@link Resources#PROCESS_DEFINITION}
   *          (if the task is part of a running process instance).
   */
  void resolveTask(String taskId, Map variables);

  /**
   * Marks a task as done and continues process execution.
   *
   * This method is typically called by a task list user interface
   * after a task form has been submitted by the
   * {@link Task#getAssignee() assignee}
   * and the required task parameters have been provided.
   *
   * @param taskId the id of the task to complete, cannot be null.
   * @param variables task parameters. May be null or empty.
   *
   * @throws ProcessEngineException
   *          when no task exists with the given id.
   * @throws AuthorizationException
   *          If the user has no {@link Permissions#UPDATE} permission on {@link Resources#TASK}
   *          or no {@link Permissions#UPDATE_TASK} permission on {@link Resources#PROCESS_DEFINITION}
   *          (if the task is part of a running process instance).
   */
  void complete(String taskId, Map variables);

  /**
   * Marks a task as done and continues process execution.
   *
   * This method is typically called by a task list user interface
   * after a task form has been submitted by the
   * {@link Task#getAssignee() assignee}
   * and the required task parameters have been provided.
   *
   * @param taskId the id of the task to complete, cannot be null.
   * @param variables task parameters. May be null or empty.
   * @param deserializeValues if false, returned {@link SerializableValue}s
   *   will not be deserialized (unless they are passed into this method as a
   *   deserialized value or if the BPMN process triggers deserialization)
   *
   * @return All task variables with their current value
   *
   * @throws ProcessEngineException
   *          when no task exists with the given id.
   * @throws AuthorizationException
   *          If the user has no {@link Permissions#UPDATE} permission on {@link Resources#TASK}
   *          or no {@link Permissions#UPDATE_TASK} permission on {@link Resources#PROCESS_DEFINITION}
   *          (if the task is part of a running process instance).
   */
  VariableMap completeWithVariablesInReturn(String taskId, Map variables, boolean deserializeValues);

  /**
   * Changes the assignee of the given task to the given userId.
   * No check is done whether the user is known by the identity component.
   *
   * @param taskId id of the task, cannot be null.
   * @param userId id of the user to use as assignee.
   *
   * @throws ProcessEngineException
   *          when the task or user doesn't exist.
   * @throws AuthorizationException
   *          If the user has no {@link Permissions#UPDATE} permission on {@link Resources#TASK}
   *          or no {@link Permissions#UPDATE_TASK} permission on {@link Resources#PROCESS_DEFINITION}
   *          (if the task is part of a running process instance).
   */
  void setAssignee(String taskId, String userId);

  /**
   * Transfers ownership of this task to another user.
   * No check is done whether the user is known by the identity component.
   *
   * @param taskId id of the task, cannot be null.
   * @param userId of the person that is receiving ownership.
   *
   * @throws ProcessEngineException
   *          when the task or user doesn't exist.
   * @throws AuthorizationException
   *          If the user has no {@link Permissions#UPDATE} permission on {@link Resources#TASK}
   *          or no {@link Permissions#UPDATE_TASK} permission on {@link Resources#PROCESS_DEFINITION}
   *          (if the task is part of a running process instance).
   */
  void setOwner(String taskId, String userId);

  /**
   * Retrieves the {@link IdentityLink}s associated with the given task.
   * Such an {@link IdentityLink} informs how a certain identity (eg. group or user)
   * is associated with a certain task (eg. as candidate, assignee, etc.)
   *
   * @throws ProcessEngineException
   *          when the task doesn't exist.
   * @throws AuthorizationException
   *          If the user has no {@link Permissions#READ} permission on {@link Resources#TASK}
   *          or no {@link Permissions#READ_TASK} permission on {@link Resources#PROCESS_DEFINITION}
   *          (if the task is part of a running process instance).
   */
  List getIdentityLinksForTask(String taskId);

  /**
   * Convenience shorthand for {@link #addUserIdentityLink(String, String, String)}; with type {@link IdentityLinkType#CANDIDATE}
   *
   * @param taskId id of the task, cannot be null.
   * @param userId id of the user to use as candidate, cannot be null.
   *
   * @throws ProcessEngineException
   *          when the task or user doesn't exist.
   * @throws AuthorizationException
   *          If the user has no {@link Permissions#UPDATE} permission on {@link Resources#TASK}
   *          or no {@link Permissions#UPDATE_TASK} permission on {@link Resources#PROCESS_DEFINITION}
   *          (if the task is part of a running process instance).
   */
  void addCandidateUser(String taskId, String userId);

  /**
   * Convenience shorthand for {@link #addGroupIdentityLink(String, String, String)}; with type {@link IdentityLinkType#CANDIDATE}
   *
   * @param taskId id of the task, cannot be null.
   * @param groupId id of the group to use as candidate, cannot be null.
   *
   * @throws ProcessEngineException
   *          when the task or group doesn't exist.
   * @throws AuthorizationException
   *          If the user has no {@link Permissions#UPDATE} permission on {@link Resources#TASK}
   *          or no {@link Permissions#UPDATE_TASK} permission on {@link Resources#PROCESS_DEFINITION}
   *          (if the task is part of a running process instance).
   */
  void addCandidateGroup(String taskId, String groupId);

  /**
   * Involves a user with a task. The type of identity link is defined by the
   * given identityLinkType.
   *
   * @param taskId id of the task, cannot be null.
   * @param userId id of the user involve, cannot be null.
   * @param identityLinkType type of identityLink, cannot be null (@see {@link IdentityLinkType}).
   *
   * @throws ProcessEngineException
   *          when the task or user doesn't exist.
   * @throws AuthorizationException
   *          If the user has no {@link Permissions#UPDATE} permission on {@link Resources#TASK}
   *          or no {@link Permissions#UPDATE_TASK} permission on {@link Resources#PROCESS_DEFINITION}
   *          (if the task is part of a running process instance).
   */
  void addUserIdentityLink(String taskId, String userId, String identityLinkType);

  /**
   * Involves a group with a task. The type of identityLink is defined by the
   * given identityLink.
   *
   * @param taskId id of the task, cannot be null.
   * @param groupId id of the group to involve, cannot be null.
   * @param identityLinkType type of identity, cannot be null (@see {@link IdentityLinkType}).
   *
   * @throws ProcessEngineException
   *          when the task or group doesn't exist.
   * @throws AuthorizationException
   *          If the user has no {@link Permissions#UPDATE} permission on {@link Resources#TASK}
   *          or no {@link Permissions#UPDATE_TASK} permission on {@link Resources#PROCESS_DEFINITION}
   *          (if the task is part of a running process instance).
   */
  void addGroupIdentityLink(String taskId, String groupId, String identityLinkType);

  /**
   * Convenience shorthand for {@link #deleteUserIdentityLink(String, String, String)}; with type {@link IdentityLinkType#CANDIDATE}
   *
   * @param taskId id of the task, cannot be null.
   * @param userId id of the user to use as candidate, cannot be null.
   *
   * @throws ProcessEngineException
   *          when the task or user doesn't exist.
   * @throws AuthorizationException
   *          If the user has no {@link Permissions#UPDATE} permission on {@link Resources#TASK}
   *          or no {@link Permissions#UPDATE_TASK} permission on {@link Resources#PROCESS_DEFINITION}
   *          (if the task is part of a running process instance).
   */
  void deleteCandidateUser(String taskId, String userId);

  /**
   * Convenience shorthand for {@link #deleteGroupIdentityLink(String, String, String)}; with type {@link IdentityLinkType#CANDIDATE}
   *
   * @param taskId id of the task, cannot be null.
   * @param groupId id of the group to use as candidate, cannot be null.
   *
   * @throws ProcessEngineException
   *          when the task or group doesn't exist.
   * @throws AuthorizationException
   *          If the user has no {@link Permissions#UPDATE} permission on {@link Resources#TASK}
   *          or no {@link Permissions#UPDATE_TASK} permission on {@link Resources#PROCESS_DEFINITION}
   *          (if the task is part of a running process instance).
   */
  void deleteCandidateGroup(String taskId, String groupId);

  /**
   * Removes the association between a user and a task for the given identityLinkType.
   *
   * @param taskId id of the task, cannot be null.
   * @param userId id of the user involve, cannot be null.
   * @param identityLinkType type of identityLink, cannot be null (@see {@link IdentityLinkType}).
   *
   * @throws ProcessEngineException
   *          when the task or user doesn't exist.
   * @throws AuthorizationException
   *          If the user has no {@link Permissions#UPDATE} permission on {@link Resources#TASK}
   *          or no {@link Permissions#UPDATE_TASK} permission on {@link Resources#PROCESS_DEFINITION}
   *          (if the task is part of a running process instance).
   */
  void deleteUserIdentityLink(String taskId, String userId, String identityLinkType);

  /**
   * Removes the association between a group and a task for the given identityLinkType.
   *
   * @param taskId id of the task, cannot be null.
   * @param groupId id of the group to involve, cannot be null.
   * @param identityLinkType type of identity, cannot be null (@see {@link IdentityLinkType}).
   *
   * @throws ProcessEngineException
   *          when the task or group doesn't exist.
   * @throws AuthorizationException
   *          If the user has no {@link Permissions#UPDATE} permission on {@link Resources#TASK}
   *          or no {@link Permissions#UPDATE_TASK} permission on {@link Resources#PROCESS_DEFINITION}
   *          (if the task is part of a running process instance).
   */
  void deleteGroupIdentityLink(String taskId, String groupId, String identityLinkType);

  /**
   * Changes the priority of the task.
   *
   * Authorization: actual owner / business admin
   *
   * @param taskId id of the task, cannot be null.
   * @param priority the new priority for the task.
   *
   * @throws ProcessEngineException
   *          when the task doesn't exist.
   * @throws AuthorizationException
   *          If the user has no {@link Permissions#UPDATE} permission on {@link Resources#TASK}
   *          or no {@link Permissions#UPDATE_TASK} permission on {@link Resources#PROCESS_DEFINITION}
   *          (if the task is part of a running process instance).
   */
  void setPriority(String taskId, int priority);

  /**
   * Returns a new {@link TaskQuery} that can be used to dynamically query tasks.
   */
  TaskQuery createTaskQuery();

  /**
   * Returns a new
   */
  NativeTaskQuery createNativeTaskQuery();

  /**
   * Set variable on a task. If the variable is not already existing, it will be created in the
   * most outer scope.  This means the process instance in case this task is related to an
   * execution.
   *
   * @throws ProcessEngineException
   *          when the task doesn't exist.
   * @throws AuthorizationException
   *           If the user has none of the following:
   *           
  • {@link TaskPermissions#UPDATE_VARIABLE} permission on {@link Resources#TASK}
  • *
  • {@link Permissions#UPDATE} permission on {@link Resources#TASK}
  • *
  • or if the task is part of a running process instance:
  • *
      *
    • {@link ProcessDefinitionPermissions#UPDATE_TASK_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
    • *
    • {@link Permissions#UPDATE_TASK} permission on {@link Resources#PROCESS_DEFINITION}
    • *
    */ void setVariable(String taskId, String variableName, Object value); /** * Set variables on a task. If the variable is not already existing, it will be created in the * most outer scope. This means the process instance in case this task is related to an * execution. * * @throws ProcessEngineException * when the task doesn't exist. * @throws AuthorizationException * If the user has none of the following: *
  • {@link TaskPermissions#UPDATE_VARIABLE} permission on {@link Resources#TASK}
  • *
  • {@link Permissions#UPDATE} permission on {@link Resources#TASK}
  • *
  • or if the task is part of a running process instance:
  • *
      *
    • {@link ProcessDefinitionPermissions#UPDATE_TASK_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
    • *
    • {@link Permissions#UPDATE_TASK} permission on {@link Resources#PROCESS_DEFINITION}
    • *
    */ void setVariables(String taskId, Map variables); /** * Set variable on a task. If the variable is not already existing, it will be created in the * task. * * @throws ProcessEngineException * when the task doesn't exist. * @throws AuthorizationException * If the user has none of the following: *
  • {@link TaskPermissions#UPDATE_VARIABLE} permission on {@link Resources#TASK}
  • *
  • {@link Permissions#UPDATE} permission on {@link Resources#TASK}
  • *
  • or if the task is part of a running process instance:
  • *
      *
    • {@link ProcessDefinitionPermissions#UPDATE_TASK_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
    • *
    • {@link Permissions#UPDATE_TASK} permission on {@link Resources#PROCESS_DEFINITION}
    • *
    */ void setVariableLocal(String taskId, String variableName, Object value); /** * Set variables on a task. If the variable is not already existing, it will be created in the * task. * * @throws ProcessEngineException * when the task doesn't exist. * @throws AuthorizationException * If the user has none of the following: *
  • {@link TaskPermissions#UPDATE_VARIABLE} permission on {@link Resources#TASK}
  • *
  • {@link Permissions#UPDATE} permission on {@link Resources#TASK}
  • *
  • or if the task is part of a running process instance:
  • *
      *
    • {@link ProcessDefinitionPermissions#UPDATE_TASK_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
    • *
    • {@link Permissions#UPDATE_TASK} permission on {@link Resources#PROCESS_DEFINITION}
    • *
    */ void setVariablesLocal(String taskId, Map variables); /** * Get a variables and search in the task scope and if available also the execution scopes. * * @throws ProcessEngineException * when the task doesn't exist. * @throws AuthorizationException *

    In case of standalone tasks: *

  • if the user has no {@link Permissions#READ} permission on {@link Resources#TASK} or
  • *
  • if {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} configuration is enabled and * the user has no {@link TaskPermissions#READ_VARIABLE} permission on {@link Resources#TASK}
  • *

    In case the task is part of a running process instance: *

  • if the user has no {@link Permissions#READ} permission on {@link Resources#TASK} and * no {@link Permissions#READ_TASK} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • in case {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} configuration is enabled and * the user has no {@link TaskPermissions#READ_VARIABLE} permission on {@link Resources#TASK} and * no {@link ProcessDefinitionPermissions#READ_TASK_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
  • */ Object getVariable(String taskId, String variableName); /** * Get a variables and search in the task scope and if available also the execution scopes. * * @param taskId the id of the task * @param variableName the name of the variable to fetch * * @return the TypedValue for the variable or 'null' in case no such variable exists. * * @throws ClassCastException * in case the value is not of the requested type * @throws ProcessEngineException * when the task doesn't exist. * @throws AuthorizationException *

    In case of standalone tasks: *

  • if the user has no {@link Permissions#READ} permission on {@link Resources#TASK} or
  • *
  • if {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} configuration is enabled and * the user has no {@link TaskPermissions#READ_VARIABLE} permission on {@link Resources#TASK}
  • *

    In case the task is part of a running process instance: *

  • if the user has no {@link Permissions#READ} permission on {@link Resources#TASK} and * no {@link Permissions#READ_TASK} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • in case {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} configuration is enabled and * the user has no {@link TaskPermissions#READ_VARIABLE} permission on {@link Resources#TASK} and * no {@link ProcessDefinitionPermissions#READ_TASK_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
  • * * @since 7.2 */ T getVariableTyped(String taskId, String variableName); /** * Get a variables and search in the task scope and if available also the execution scopes. * * @param taskId the id of the task * @param variableName the name of the variable to fetch * @param deserializeValue if false a, {@link SerializableValue} will not be deserialized. * * @return the TypedValue for the variable or 'null' in case no such variable exists. * * @throws ClassCastException * in case the value is not of the requested type * @throws ProcessEngineException * when the task doesn't exist. * @throws AuthorizationException *

    In case of standalone tasks: *

  • if the user has no {@link Permissions#READ} permission on {@link Resources#TASK} or
  • *
  • if {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} configuration is enabled and * the user has no {@link TaskPermissions#READ_VARIABLE} permission on {@link Resources#TASK}
  • *

    In case the task is part of a running process instance: *

  • if the user has no {@link Permissions#READ} permission on {@link Resources#TASK} and * no {@link Permissions#READ_TASK} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • in case {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} configuration is enabled and * the user has no {@link TaskPermissions#READ_VARIABLE} permission on {@link Resources#TASK} and * no {@link ProcessDefinitionPermissions#READ_TASK_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
  • * * @since 7.2 */ T getVariableTyped(String taskId, String variableName, boolean deserializeValue); /** * Get a variables and only search in the task scope. * * @throws ProcessEngineException * when the task doesn't exist. * @throws AuthorizationException *

    In case of standalone tasks: *

  • if the user has no {@link Permissions#READ} permission on {@link Resources#TASK} or
  • *
  • if {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} configuration is enabled and * the user has no {@link TaskPermissions#READ_VARIABLE} permission on {@link Resources#TASK}
  • *

    In case the task is part of a running process instance: *

  • if the user has no {@link Permissions#READ} permission on {@link Resources#TASK} and * no {@link Permissions#READ_TASK} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • in case {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} configuration is enabled and * the user has no {@link TaskPermissions#READ_VARIABLE} permission on {@link Resources#TASK} and * no {@link ProcessDefinitionPermissions#READ_TASK_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
  • */ Object getVariableLocal(String taskId, String variableName); /** * Get a variables and only search in the task scope. * * @param taskId the id of the task * @param variableName the name of the variable to fetch * * @return the TypedValue for the variable or 'null' in case no such variable exists. * * @throws ClassCastException * in case the value is not of the requested type * @throws ProcessEngineException * when the task doesn't exist. * @throws AuthorizationException *

    In case of standalone tasks: *

  • if the user has no {@link Permissions#READ} permission on {@link Resources#TASK} or
  • *
  • if {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} configuration is enabled and * the user has no {@link TaskPermissions#READ_VARIABLE} permission on {@link Resources#TASK}
  • *

    In case the task is part of a running process instance: *

  • if the user has no {@link Permissions#READ} permission on {@link Resources#TASK} and * no {@link Permissions#READ_TASK} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • in case {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} configuration is enabled and * the user has no {@link TaskPermissions#READ_VARIABLE} permission on {@link Resources#TASK} and * no {@link ProcessDefinitionPermissions#READ_TASK_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
  • * * @since 7.2 */ T getVariableLocalTyped(String taskId, String variableName); /** * Get a variables and only search in the task scope. * * @param taskId the id of the task * @param variableName the name of the variable to fetch * @param deserializeValue if false a, {@link SerializableValue} will not be deserialized. * * @return the TypedValue for the variable or 'null' in case no such variable exists. * * @throws ClassCastException * in case the value is not of the requested type * @throws ProcessEngineException * when the task doesn't exist. * @throws AuthorizationException *

    In case of standalone tasks: *

  • if the user has no {@link Permissions#READ} permission on {@link Resources#TASK} or
  • *
  • if {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} configuration is enabled and * the user has no {@link TaskPermissions#READ_VARIABLE} permission on {@link Resources#TASK}
  • *

    In case the task is part of a running process instance: *

  • if the user has no {@link Permissions#READ} permission on {@link Resources#TASK} and * no {@link Permissions#READ_TASK} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • in case {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} configuration is enabled and * the user has no {@link TaskPermissions#READ_VARIABLE} permission on {@link Resources#TASK} and * no {@link ProcessDefinitionPermissions#READ_TASK_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
  • * * @since 7.2 */ T getVariableLocalTyped(String taskId, String variableName, boolean deserializeValue); /** * Get all variables and search in the task scope and if available also the execution scopes. * If you have many variables and you only need a few, consider using {@link #getVariables(String, Collection)} * for better performance. * * @throws ProcessEngineException * when the task doesn't exist. * @throws AuthorizationException *

    In case of standalone tasks: *

  • if the user has no {@link Permissions#READ} permission on {@link Resources#TASK} or
  • *
  • if {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} configuration is enabled and * the user has no {@link TaskPermissions#READ_VARIABLE} permission on {@link Resources#TASK}
  • *

    In case the task is part of a running process instance: *

  • if the user has no {@link Permissions#READ} permission on {@link Resources#TASK} and * no {@link Permissions#READ_TASK} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • in case {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} configuration is enabled and * the user has no {@link TaskPermissions#READ_VARIABLE} permission on {@link Resources#TASK} and * no {@link ProcessDefinitionPermissions#READ_TASK_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
  • */ Map getVariables(String taskId); /** * Get all variables and search in the task scope and if available also the execution scopes. * If you have many variables and you only need a few, consider using {@link #getVariables(String, Collection)} * for better performance. * * @param taskId the id of the task * * @throws ProcessEngineException * when the task doesn't exist. * @throws AuthorizationException *

    In case of standalone tasks: *

  • if the user has no {@link Permissions#READ} permission on {@link Resources#TASK} or
  • *
  • if {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} configuration is enabled and * the user has no {@link TaskPermissions#READ_VARIABLE} permission on {@link Resources#TASK}
  • *

    In case the task is part of a running process instance: *

  • if the user has no {@link Permissions#READ} permission on {@link Resources#TASK} and * no {@link Permissions#READ_TASK} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • in case {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} configuration is enabled and * the user has no {@link TaskPermissions#READ_VARIABLE} permission on {@link Resources#TASK} and * no {@link ProcessDefinitionPermissions#READ_TASK_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
  • * @since 7.2 */ VariableMap getVariablesTyped(String taskId); /** * Get all variables and search in the task scope and if available also the execution scopes. * If you have many variables and you only need a few, consider using {@link #getVariables(String, Collection)} * for better performance. * * @param taskId the id of the task * @param deserializeValues if false, {@link SerializableValue SerializableValues} will not be deserialized. * * @throws ProcessEngineException * when the task doesn't exist. * @throws AuthorizationException *

    In case of standalone tasks: *

  • if the user has no {@link Permissions#READ} permission on {@link Resources#TASK} or
  • *
  • if {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} configuration is enabled and * the user has no {@link TaskPermissions#READ_VARIABLE} permission on {@link Resources#TASK}
  • *

    In case the task is part of a running process instance: *

  • if the user has no {@link Permissions#READ} permission on {@link Resources#TASK} and * no {@link Permissions#READ_TASK} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • in case {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} configuration is enabled and * the user has no {@link TaskPermissions#READ_VARIABLE} permission on {@link Resources#TASK} and * no {@link ProcessDefinitionPermissions#READ_TASK_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
  • * * @since 7.2 */ VariableMap getVariablesTyped(String taskId, boolean deserializeValues); /** * Get all variables and search only in the task scope. * If you have many task local variables and you only need a few, consider using {@link #getVariablesLocal(String, Collection)} * for better performance. * * @throws ProcessEngineException * when the task doesn't exist. * @throws AuthorizationException *

    In case of standalone tasks: *

  • if the user has no {@link Permissions#READ} permission on {@link Resources#TASK} or
  • *
  • if {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} configuration is enabled and * the user has no {@link TaskPermissions#READ_VARIABLE} permission on {@link Resources#TASK}
  • *

    In case the task is part of a running process instance: *

  • if the user has no {@link Permissions#READ} permission on {@link Resources#TASK} and * no {@link Permissions#READ_TASK} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • in case {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} configuration is enabled and * the user has no {@link TaskPermissions#READ_VARIABLE} permission on {@link Resources#TASK} and * no {@link ProcessDefinitionPermissions#READ_TASK_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
  • */ Map getVariablesLocal(String taskId); /** * Get all variables and search only in the task scope. * If you have many task local variables and you only need a few, consider using {@link #getVariablesLocal(String, Collection)} * for better performance. * * @param taskId the id of the task * @param deserializeValues if false, {@link SerializableValue SerializableValues} will not be deserialized. * * @throws ProcessEngineException * when the task doesn't exist. * @throws AuthorizationException *

    In case of standalone tasks: *

  • if the user has no {@link Permissions#READ} permission on {@link Resources#TASK} or
  • *
  • if {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} configuration is enabled and * the user has no {@link TaskPermissions#READ_VARIABLE} permission on {@link Resources#TASK}
  • *

    In case the task is part of a running process instance: *

  • if the user has no {@link Permissions#READ} permission on {@link Resources#TASK} and * no {@link Permissions#READ_TASK} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • in case {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} configuration is enabled and * the user has no {@link TaskPermissions#READ_VARIABLE} permission on {@link Resources#TASK} and * no {@link ProcessDefinitionPermissions#READ_TASK_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
  • * * @since 7.2 */ VariableMap getVariablesLocalTyped(String taskId); /** * Get all variables and search only in the task scope. * If you have many task local variables and you only need a few, consider using {@link #getVariablesLocal(String, Collection)} * for better performance. * * @param taskId the id of the task * @param deserializeValues if false, {@link SerializableValue SerializableValues} will not be deserialized. * * @throws ProcessEngineException * when the task doesn't exist. * @throws AuthorizationException *

    In case of standalone tasks: *

  • if the user has no {@link Permissions#READ} permission on {@link Resources#TASK} or
  • *
  • if {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} configuration is enabled and * the user has no {@link TaskPermissions#READ_VARIABLE} permission on {@link Resources#TASK}
  • *

    In case the task is part of a running process instance: *

  • if the user has no {@link Permissions#READ} permission on {@link Resources#TASK} and * no {@link Permissions#READ_TASK} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • in case {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} configuration is enabled and * the user has no {@link TaskPermissions#READ_VARIABLE} permission on {@link Resources#TASK} and * no {@link ProcessDefinitionPermissions#READ_TASK_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
  • * * @since 7.2 */ VariableMap getVariablesLocalTyped(String taskId, boolean deserializeValues); /** * Get values for all given variableNames * * @throws ProcessEngineException * when the task doesn't exist. * @throws AuthorizationException *

    In case of standalone tasks: *

  • if the user has no {@link Permissions#READ} permission on {@link Resources#TASK} or
  • *
  • if {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} configuration is enabled and * the user has no {@link TaskPermissions#READ_VARIABLE} permission on {@link Resources#TASK}
  • *

    In case the task is part of a running process instance: *

  • if the user has no {@link Permissions#READ} permission on {@link Resources#TASK} and * no {@link Permissions#READ_TASK} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • in case {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} configuration is enabled and * the user has no {@link TaskPermissions#READ_VARIABLE} permission on {@link Resources#TASK} and * no {@link ProcessDefinitionPermissions#READ_TASK_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
  • * */ Map getVariables(String taskId, Collection variableNames); /** * Get values for all given variableName * * @param taskId the id of the task * @param variableNames only fetch variables whose names are in the collection. * @param deserializeValues if false, {@link SerializableValue SerializableValues} will not be deserialized. * * @throws ProcessEngineException * when the task doesn't exist. * @throws AuthorizationException *

    In case of standalone tasks: *

  • if the user has no {@link Permissions#READ} permission on {@link Resources#TASK} or
  • *
  • if {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} configuration is enabled and * the user has no {@link TaskPermissions#READ_VARIABLE} permission on {@link Resources#TASK}
  • *

    In case the task is part of a running process instance: *

  • if the user has no {@link Permissions#READ} permission on {@link Resources#TASK} and * no {@link Permissions#READ_TASK} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • in case {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} configuration is enabled and * the user has no {@link TaskPermissions#READ_VARIABLE} permission on {@link Resources#TASK} and * no {@link ProcessDefinitionPermissions#READ_TASK_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
  • * * @since 7.2 * */ VariableMap getVariablesTyped(String taskId, Collection variableNames, boolean deserializeValues); /** * Get a variable on a task * * @throws ProcessEngineException * when the task doesn't exist. * @throws AuthorizationException *

    In case of standalone tasks: *

  • if the user has no {@link Permissions#READ} permission on {@link Resources#TASK} or
  • *
  • if {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} configuration is enabled and * the user has no {@link TaskPermissions#READ_VARIABLE} permission on {@link Resources#TASK}
  • *

    In case the task is part of a running process instance: *

  • if the user has no {@link Permissions#READ} permission on {@link Resources#TASK} and * no {@link Permissions#READ_TASK} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • in case {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} configuration is enabled and * the user has no {@link TaskPermissions#READ_VARIABLE} permission on {@link Resources#TASK} and * no {@link ProcessDefinitionPermissions#READ_TASK_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
  • * */ Map getVariablesLocal(String taskId, Collection variableNames); /** * Get values for all given variableName. Only search in the local task scope. * * @param taskId the id of the task * @param variableNames only fetch variables whose names are in the collection. * @param deserializeValues if false, {@link SerializableValue SerializableValues} will not be deserialized. * * @throws ProcessEngineException * when the task doesn't exist. * @throws AuthorizationException *

    In case of standalone tasks: *

  • if the user has no {@link Permissions#READ} permission on {@link Resources#TASK} or
  • *
  • if {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} configuration is enabled and * the user has no {@link TaskPermissions#READ_VARIABLE} permission on {@link Resources#TASK}
  • *

    In case the task is part of a running process instance: *

  • if the user has no {@link Permissions#READ} permission on {@link Resources#TASK} and * no {@link Permissions#READ_TASK} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • in case {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} configuration is enabled and * the user has no {@link TaskPermissions#READ_VARIABLE} permission on {@link Resources#TASK} and * no {@link ProcessDefinitionPermissions#READ_TASK_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
  • * * @since 7.2 */ VariableMap getVariablesLocalTyped(String taskId, Collection variableNames, boolean deserializeValues); /** * Removes the variable from the task. * When the variable does not exist, nothing happens. * * @throws ProcessEngineException * when the task doesn't exist. * @throws AuthorizationException * If the user has none of the following: *
  • {@link TaskPermissions#UPDATE_VARIABLE} permission on {@link Resources#TASK}
  • *
  • {@link Permissions#UPDATE} permission on {@link Resources#TASK}
  • *
  • or if the task is part of a running process instance:
  • *
      *
    • {@link ProcessDefinitionPermissions#UPDATE_TASK_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
    • *
    • {@link Permissions#UPDATE_TASK} permission on {@link Resources#PROCESS_DEFINITION}
    • *
    */ void removeVariable(String taskId, String variableName); /** * Removes the variable from the task (not considering parent scopes). * When the variable does not exist, nothing happens. * * @throws ProcessEngineException * when the task doesn't exist. * @throws AuthorizationException * If the user has none of the following: *
  • {@link TaskPermissions#UPDATE_VARIABLE} permission on {@link Resources#TASK}
  • *
  • {@link Permissions#UPDATE} permission on {@link Resources#TASK}
  • *
  • or if the task is part of a running process instance:
  • *
      *
    • {@link ProcessDefinitionPermissions#UPDATE_TASK_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
    • *
    • {@link Permissions#UPDATE_TASK} permission on {@link Resources#PROCESS_DEFINITION}
    • *
    */ void removeVariableLocal(String taskId, String variableName); /** * Removes all variables in the given collection from the task. * Non existing variable names are simply ignored. * * @throws ProcessEngineException * when the task doesn't exist. * @throws AuthorizationException * If the user has none of the following: *
  • {@link TaskPermissions#UPDATE_VARIABLE} permission on {@link Resources#TASK}
  • *
  • {@link Permissions#UPDATE} permission on {@link Resources#TASK}
  • *
  • or if the task is part of a running process instance:
  • *
      *
    • {@link ProcessDefinitionPermissions#UPDATE_TASK_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
    • *
    • {@link Permissions#UPDATE_TASK} permission on {@link Resources#PROCESS_DEFINITION}
    • *
    */ void removeVariables(String taskId, Collection variableNames); /** * Removes all variables in the given collection from the task (not considering parent scopes). * Non existing variable names are simply ignored. * * @throws ProcessEngineException * when the task doesn't exist. * @throws AuthorizationException * If the user has none of the following: *
  • {@link TaskPermissions#UPDATE_VARIABLE} permission on {@link Resources#TASK}
  • *
  • {@link Permissions#UPDATE} permission on {@link Resources#TASK}
  • *
  • or if the task is part of a running process instance:
  • *
      *
    • {@link ProcessDefinitionPermissions#UPDATE_TASK_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
    • *
    • {@link Permissions#UPDATE_TASK} permission on {@link Resources#PROCESS_DEFINITION}
    • *
    */ void removeVariablesLocal(String taskId, Collection variableNames); /** * Add a comment to a task and/or process instance. * * @deprecated Use {@link #createComment(String, String, String)} instead */ @Deprecated void addComment(String taskId, String processInstanceId, String message); /** Creates a comment to a task and/or process instance and returns the comment. */ Comment createComment(String taskId, String processInstanceId, String message); /** The comments related to the given task. */ List getTaskComments(String taskId); /** Retrieve a particular task comment */ Comment getTaskComment(String taskId, String commentId); /** *

    The all events related to the given task.

    * *

    As of Camunda Platform 7.4 task events are only written in context of a logged in * user. This behavior can be toggled in the process engine configuration using the * property legacyUserOperationLog (default false). To restore the engine's * previous behavior, set the flag to true.

    * * @deprecated This method has been deprecated as of Camunda Platform 7.1. It has been replaced with * the operation log. See {@link UserOperationLogEntry} and {@link UserOperationLogQuery}. * * @see HistoryService#createUserOperationLogQuery() */ @Deprecated List getTaskEvents(String taskId); /** The comments related to the given process instance. */ List getProcessInstanceComments(String processInstanceId); /** * Add a new attachment to a task and/or a process instance and use an input stream to provide the content * please use method in runtime service to operate on process instance. * * Either taskId or processInstanceId has to be provided * * @param taskId - task that should have an attachment * @param processInstanceId - id of a process to use if task id is null * @param attachmentType - name of the attachment, can be null * @param attachmentName - name of the attachment, can be null * @param attachmentDescription - full text description, can be null * @param content - byte array with content of attachment * */ Attachment createAttachment(String attachmentType, String taskId, String processInstanceId, String attachmentName, String attachmentDescription, InputStream content); /** * Add a new attachment to a task and/or a process instance and use an url as the content * please use method in runtime service to operate on process instance * * Either taskId or processInstanceId has to be provided * * @param taskId - task that should have an attachment * @param processInstanceId - id of a process to use if task id is null * @param attachmentType - name of the attachment, can be null * @param attachmentName - name of the attachment, can be null * @param attachmentDescription - full text description, can be null * @param url - url of the attachment, can be null * */ Attachment createAttachment(String attachmentType, String taskId, String processInstanceId, String attachmentName, String attachmentDescription, String url); /** Update the name and decription of an attachment */ void saveAttachment(Attachment attachment); /** Retrieve a particular attachment */ Attachment getAttachment(String attachmentId); /** Retrieve a particular attachment to the given task id and attachment id*/ Attachment getTaskAttachment(String taskId, String attachmentId); /** Retrieve stream content of a particular attachment */ InputStream getAttachmentContent(String attachmentId); /** Retrieve stream content of a particular attachment to the given task id and attachment id*/ InputStream getTaskAttachmentContent(String taskId, String attachmentId); /** The list of attachments associated to a task */ List getTaskAttachments(String taskId); /** The list of attachments associated to a process instance */ List getProcessInstanceAttachments(String processInstanceId); /** Delete an attachment */ void deleteAttachment(String attachmentId); /** Delete an attachment to the given task id and attachment id */ void deleteTaskAttachment(String taskId, String attachmentId); /** The list of subtasks for this parent task */ List getSubTasks(String parentTaskId); /** Instantiate a task report */ TaskReport createTaskReport(); /** * Signals that a business error appears, which should be handled by the process engine. * * @param taskId the id of an existing active task * @param errorCode the error code of the corresponding bmpn error * * @throws NotFoundException if no task with the given id exists * @throws BadUserRequestException if task id or error code were null or empty * @throws SuspendedEntityInteractionException if the task is suspended * @throws AuthorizationException if the user has none of the following permissions: *
  • {@link Permissions#TASK_WORK} permission on {@link Resources#TASK} or * {@link Resources#PROCESS_DEFINITION} resource
  • *
  • {@link Permissions#UPDATE} permission on {@link Resources#TASK} resource
  • *
  • {@link Permissions#UPDATE_TASK} permission on {@link Resources#PROCESS_DEFINITION} resource
  • */ void handleBpmnError(String taskId, String errorCode); /** * @see #handleBpmnError(String, String) * * @param taskId the id of an existing active task * @param errorCode the error code of the corresponding bmpn error * @param errorMessage the error message of the corresponding bmpn error */ void handleBpmnError(String taskId, String errorCode, String errorMessage); /** * @see #handleBpmnError(String, String) * * @param taskId the id of an existing active task * @param errorCode the error code of the corresponding bmpn error * @param errorMessage the error message of the corresponding bmpn error * @param variables the variables to pass to the execution */ void handleBpmnError(String taskId, String errorCode, String errorMessage, Map variables); /** * Signals that an escalation appears, which should be handled by the process engine. * * @param taskId the id of an existing active task * @param escalationCode the escalation code of the corresponding escalation * @param variables the variables to pass to the execution * * @throws NotFoundException if no task with the given id exists * @throws BadUserRequestException if task id or escalation code were null or empty * @throws SuspendedEntityInteractionException if the task is suspended * @throws AuthorizationException if the user has none of the following permissions: *
  • {@link Permissions#TASK_WORK} permission on {@link Resources#TASK} or * {@link Resources#PROCESS_DEFINITION} resource
  • *
  • {@link Permissions#UPDATE} permission on {@link Resources#TASK} resource
  • *
  • {@link Permissions#UPDATE_TASK} permission on {@link Resources#PROCESS_DEFINITION} resource
  • */ void handleEscalation(String taskId, String escalationCode); /** * Signals that an escalation appears, which should be handled by the process engine. * * @param taskId the id of an existing active task * @param escalationCode the escalation code of the corresponding escalation * @param variables the variables to pass to the execution * * @throws NotFoundException if no task with the given id exists * @throws BadUserRequestException if task id or escalation code were null or empty * @throws SuspendedEntityInteractionException if the task is suspended * @throws AuthorizationException if the user has none of the following permissions: *
  • {@link Permissions#TASK_WORK} permission on {@link Resources#TASK} or * {@link Resources#PROCESS_DEFINITION} resource
  • *
  • {@link Permissions#UPDATE} permission on {@link Resources#TASK} resource
  • *
  • {@link Permissions#UPDATE_TASK} permission on {@link Resources#PROCESS_DEFINITION} resource
  • */ void handleEscalation(String taskId, String escalationCode, Map variables); }




    © 2015 - 2025 Weber Informatics LLC | Privacy Policy