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

org.camunda.bpm.engine.RuntimeService 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.util.Collection;
import java.util.List;
import java.util.Map;

import org.camunda.bpm.engine.authorization.BatchPermissions;
import org.camunda.bpm.engine.authorization.Permissions;
import org.camunda.bpm.engine.authorization.ProcessDefinitionPermissions;
import org.camunda.bpm.engine.authorization.ProcessInstancePermissions;
import org.camunda.bpm.engine.authorization.Resources;
import org.camunda.bpm.engine.batch.Batch;
import org.camunda.bpm.engine.delegate.ExecutionListener;
import org.camunda.bpm.engine.exception.NullValueException;
import org.camunda.bpm.engine.exception.NotFoundException;
import org.camunda.bpm.engine.exception.NotValidException;
import org.camunda.bpm.engine.history.HistoricProcessInstanceQuery;
import org.camunda.bpm.engine.migration.MigrationPlan;
import org.camunda.bpm.engine.migration.MigrationPlanBuilder;
import org.camunda.bpm.engine.migration.MigrationPlanExecutionBuilder;
import org.camunda.bpm.engine.repository.Deployment;
import org.camunda.bpm.engine.repository.ProcessDefinition;
import org.camunda.bpm.engine.runtime.ActivityInstance;
import org.camunda.bpm.engine.runtime.ConditionEvaluationBuilder;
import org.camunda.bpm.engine.runtime.EventSubscriptionQuery;
import org.camunda.bpm.engine.runtime.Execution;
import org.camunda.bpm.engine.runtime.ExecutionQuery;
import org.camunda.bpm.engine.runtime.Incident;
import org.camunda.bpm.engine.runtime.IncidentQuery;
import org.camunda.bpm.engine.runtime.MessageCorrelationAsyncBuilder;
import org.camunda.bpm.engine.runtime.MessageCorrelationBuilder;
import org.camunda.bpm.engine.runtime.ModificationBuilder;
import org.camunda.bpm.engine.runtime.NativeExecutionQuery;
import org.camunda.bpm.engine.runtime.NativeProcessInstanceQuery;
import org.camunda.bpm.engine.runtime.ProcessInstance;
import org.camunda.bpm.engine.runtime.ProcessInstanceModificationBuilder;
import org.camunda.bpm.engine.runtime.ProcessInstanceQuery;
import org.camunda.bpm.engine.runtime.ProcessInstantiationBuilder;
import org.camunda.bpm.engine.runtime.RestartProcessInstanceBuilder;
import org.camunda.bpm.engine.runtime.SignalEventReceivedBuilder;
import org.camunda.bpm.engine.runtime.UpdateProcessInstanceSuspensionStateBuilder;
import org.camunda.bpm.engine.runtime.UpdateProcessInstanceSuspensionStateSelectBuilder;
import org.camunda.bpm.engine.runtime.VariableInstanceQuery;
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 Deployment}s,
 * {@link ProcessDefinition}s and {@link ProcessInstance}s.
 *
 * @author Tom Baeyens
 * @author Joram Barrez
 * @author Daniel Meyer
 */
public interface RuntimeService {

  /**
   * Starts a new process instance in the latest version of the process definition with the given key.
   *
   * @param processDefinitionKey key of process definition, cannot be null.
   *
   * @throws ProcessEngineException
   *          when no process definition is deployed with the given key.
   * @throws AuthorizationException
   *          if the user has no {@link Permissions#CREATE} permission on {@link Resources#PROCESS_INSTANCE}
   *          and no {@link Permissions#CREATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}.
   */
  ProcessInstance startProcessInstanceByKey(String processDefinitionKey);

  /**
   * Starts a new process instance in the latest version of the process
   * definition with the given key.
   *
   * A business key can be provided to associate the process instance with a
   * certain identifier that has a clear business meaning. For example in an
   * order process, the business key could be an order id. This business key can
   * then be used to easily look up that process instance , see
   * {@link ProcessInstanceQuery#processInstanceBusinessKey(String)}. Providing such a business
   * key is definitely a best practice.
   *
   * Note that a business key MUST be unique for the given process definition WHEN you have added
   * a database constraint for it.
   * In this case, only Process instance from different process definition are allowed to have the
   * same business key and the combination of processdefinitionKey-businessKey must be unique.
   *
   * @param processDefinitionKey
   *          key of process definition, cannot be null.
   * @param businessKey
   *          a key that uniquely identifies the process instance in the context
   *          of the given process definition.
   *
   * @throws ProcessEngineException
   *          when no process definition is deployed with the given key.
   * @throws AuthorizationException
   *          if the user has no {@link Permissions#CREATE} permission on {@link Resources#PROCESS_INSTANCE}
   *          and no {@link Permissions#CREATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}.
   */
  ProcessInstance startProcessInstanceByKey(String processDefinitionKey, String businessKey);

  /**
   * Starts a new process instance in the latest version of the process
   * definition with the given key.
   *
   * A business key can be provided to associate the process instance with a
   * certain identifier that has a clear business meaning. For example in an
   * order process, the business key could be an order id. This business key can
   * then be used to easily look up that process instance , see
   * {@link ProcessInstanceQuery#processInstanceBusinessKey(String)}. Providing such a business
   * key is definitely a best practice.
   *
   * Note that a business key MUST be unique for the given process definition WHEN you have added
   * a database constraint for it.
   * In this case, only Process instance from different process definition are allowed to have the
   * same business key and the combination of processdefinitionKey-businessKey must be unique.
   *
   * @param processDefinitionKey
   *          key of process definition, cannot be null.
   * @param businessKey
   *          a key that uniquely identifies the process instance in the context
   *          of the given process definition.
   * @param caseInstanceId
   *          an id of a case instance to associate the process instance with
   *          a case instance.
   *
   * @throws ProcessEngineException
   *          when no process definition is deployed with the given key.
   * @throws AuthorizationException
   *          if the user has no {@link Permissions#CREATE} permission on {@link Resources#PROCESS_INSTANCE}
   *          and no {@link Permissions#CREATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}.
   */
  ProcessInstance startProcessInstanceByKey(String processDefinitionKey, String businessKey, String caseInstanceId);

  /** Starts a new process instance in the latest version of the process definition with the given key
   *
   * @param processDefinitionKey key of process definition, cannot be null.
   * @param variables the variables to pass, can be null.
   *
   * @throws ProcessEngineException
   *          when no process definition is deployed with the given key.
   * @throws AuthorizationException
   *          if the user has no {@link Permissions#CREATE} permission on {@link Resources#PROCESS_INSTANCE}
   *          and no {@link Permissions#CREATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}.
   */
  ProcessInstance startProcessInstanceByKey(String processDefinitionKey, Map variables);

  /**
   * Starts a new process instance in the latest version of the process definition with the given key.
   *
   * A business key can be provided to associate the process instance with a
   * certain identifier that has a clear business meaning. For example in an
   * order process, the business key could be an order id. This business key can
   * then be used to easily look up that process instance , see
   * {@link ProcessInstanceQuery#processInstanceBusinessKey(String)}. Providing such a business
   * key is definitely a best practice.
   *
   * Note that a business key MUST be unique for the given process definition WHEN you have added a
   * database constraint for it.
   * In this case, only Process instance from different process definition are allowed to have the
   * same business key and the combination of processdefinitionKey-businessKey must be unique.
   *
   * The combination of processdefinitionKey-businessKey must be unique.
   *
   * @param processDefinitionKey key of process definition, cannot be null.
   * @param variables the variables to pass, can be null.
   * @param businessKey a key that uniquely identifies the process instance in the context of the
   *                    given process definition.
   *
   * @throws ProcessEngineException
   *          when no process definition is deployed with the given key.
   * @throws AuthorizationException
   *          if the user has no {@link Permissions#CREATE} permission on {@link Resources#PROCESS_INSTANCE}
   *          and no {@link Permissions#CREATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}.
   */
  ProcessInstance startProcessInstanceByKey(String processDefinitionKey, String businessKey, Map variables);

  /**
   * Starts a new process instance in the latest version of the process definition with the given key.
   *
   * A business key can be provided to associate the process instance with a
   * certain identifier that has a clear business meaning. For example in an
   * order process, the business key could be an order id. This business key can
   * then be used to easily look up that process instance , see
   * {@link ProcessInstanceQuery#processInstanceBusinessKey(String)}. Providing such a business
   * key is definitely a best practice.
   *
   * Note that a business key MUST be unique for the given process definition WHEN you have added a
   * database constraint for it.
   * In this case, only Process instance from different process definition are allowed to have the
   * same business key and the combination of processdefinitionKey-businessKey must be unique.
   *
   * The combination of processdefinitionKey-businessKey must be unique.
   * @param processDefinitionKey key of process definition, cannot be null.
   * @param variables the variables to pass, can be null.
   * @param businessKey a key that uniquely identifies the process instance in the context of the
   *                    given process definition.
   * @param caseInstanceId
   *          an id of a case instance to associate the process instance with
   *          a case instance.
   *
   * @throws ProcessEngineException
   *          when no process definition is deployed with the given key.
   * @throws AuthorizationException
   *          if the user has no {@link Permissions#CREATE} permission on {@link Resources#PROCESS_INSTANCE}
   *          and no {@link Permissions#CREATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}.
   */
  ProcessInstance startProcessInstanceByKey(String processDefinitionKey, String businessKey, String caseInstanceId, Map variables);

  /** Starts a new process instance in the exactly specified version of the process definition with the given id.
   *
   * @param processDefinitionId the id of the process definition, cannot be null.
   *
   * @throws ProcessEngineException
   *          when no process definition is deployed with the given key.
   * @throws AuthorizationException
   *          if the user has no {@link Permissions#CREATE} permission on {@link Resources#PROCESS_INSTANCE}
   *          and no {@link Permissions#CREATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}.
   */
  ProcessInstance startProcessInstanceById(String processDefinitionId);

  /**
   * Starts a new process instance in the exactly specified version of the process definition with the given id.
   *
   * A business key can be provided to associate the process instance with a
   * certain identifier that has a clear business meaning. For example in an
   * order process, the business key could be an order id. This business key can
   * then be used to easily look up that process instance , see
   * {@link ProcessInstanceQuery#processInstanceBusinessKey(String)}. Providing such a business
   * key is definitely a best practice.
   *
   * Note that a business key MUST be unique for the given process definition WHEN you have added
   * a database constraint for it.
   * In this case, only Process instance from different process definition are allowed to have the
   * same business key and the combination of processdefinitionKey-businessKey must be unique.
   *
   * @param processDefinitionId the id of the process definition, cannot be null.
   * @param businessKey a key that uniquely identifies the process instance in the context of the
   *                    given process definition.
   *
   * @throws ProcessEngineException
   *          when no process definition is deployed with the given key.
   * @throws AuthorizationException
   *          if the user has no {@link Permissions#CREATE} permission on {@link Resources#PROCESS_INSTANCE}
   *          and no {@link Permissions#CREATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}.
   */
  ProcessInstance startProcessInstanceById(String processDefinitionId, String businessKey);

  /**
   * Starts a new process instance in the exactly specified version of the process definition with the given id.
   *
   * A business key can be provided to associate the process instance with a
   * certain identifier that has a clear business meaning. For example in an
   * order process, the business key could be an order id. This business key can
   * then be used to easily look up that process instance , see
   * {@link ProcessInstanceQuery#processInstanceBusinessKey(String)}. Providing such a business
   * key is definitely a best practice.
   *
   * Note that a business key MUST be unique for the given process definition WHEN you have added
   * a database constraint for it.
   * In this case, only Process instance from different process definition are allowed to have the
   * same business key and the combination of processdefinitionKey-businessKey must be unique.
   *
   * @param processDefinitionId the id of the process definition, cannot be null.
   * @param businessKey a key that uniquely identifies the process instance in the context of the
   *                    given process definition.
   * @param caseInstanceId
   *          an id of a case instance to associate the process instance with
   *          a case instance.
   *
   * @throws ProcessEngineException
   *          when no process definition is deployed with the given key.
   * @throws AuthorizationException
   *          if the user has no {@link Permissions#CREATE} permission on {@link Resources#PROCESS_INSTANCE}
   *          and no {@link Permissions#CREATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}.
   */
  ProcessInstance startProcessInstanceById(String processDefinitionId, String businessKey, String caseInstanceId);

  /** Starts a new process instance in the exactly specified version of the process definition with the given id.
   *
   * @param processDefinitionId the id of the process definition, cannot be null.
   * @param variables variables to be passed, can be null
   *
   * @throws ProcessEngineException
   *          when no process definition is deployed with the given key.
   * @throws AuthorizationException
   *          if the user has no {@link Permissions#CREATE} permission on {@link Resources#PROCESS_INSTANCE}
   *          and no {@link Permissions#CREATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}.
   */
  ProcessInstance startProcessInstanceById(String processDefinitionId, Map variables);

  /**
   * Starts a new process instance in the exactly specified version of the process definition with the given id.
   *
   * A business key can be provided to associate the process instance with a
   * certain identifier that has a clear business meaning. For example in an
   * order process, the business key could be an order id. This business key can
   * then be used to easily look up that process instance , see
   * {@link ProcessInstanceQuery#processInstanceBusinessKey(String)}. Providing such a business
   * key is definitely a best practice.
   *
   * Note that a business key MUST be unique for the given process definition WHEN you have added
   * a database constraint for it.
   * In this case, only Process instance from different process definition are allowed to have the
   * same business key and the combination of processdefinitionKey-businessKey must be unique.
   *
   * @param processDefinitionId the id of the process definition, cannot be null.
   * @param businessKey a key that uniquely identifies the process instance in the context of the
   *                    given process definition.
   * @param variables variables to be passed, can be null
   *
   * @throws ProcessEngineException
   *          when no process definition is deployed with the given key.
   * @throws AuthorizationException
   *          if the user has no {@link Permissions#CREATE} permission on {@link Resources#PROCESS_INSTANCE}
   *          and no {@link Permissions#CREATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}.
   */
  ProcessInstance startProcessInstanceById(String processDefinitionId, String businessKey, Map variables);

  /**
   * Starts a new process instance in the exactly specified version of the process definition with the given id.
   *
   * A business key can be provided to associate the process instance with a
   * certain identifier that has a clear business meaning. For example in an
   * order process, the business key could be an order id. This business key can
   * then be used to easily look up that process instance , see
   * {@link ProcessInstanceQuery#processInstanceBusinessKey(String)}. Providing such a business
   * key is definitely a best practice.
   *
   * Note that a business key MUST be unique for the given process definition WHEN you have added
   * a database constraint for it.
   * In this case, only Process instance from different process definition are allowed to have the
   * same business key and the combination of processdefinitionKey-businessKey must be unique.
   *
   * @param processDefinitionId the id of the process definition, cannot be null.
   * @param businessKey a key that uniquely identifies the process instance in the context of the
   *                    given process definition.
   * @param caseInstanceId
   *          an id of a case instance to associate the process instance with
   *          a case instance.
   * @param variables variables to be passed, can be null
   *
   * @throws ProcessEngineException
   *          when no process definition is deployed with the given key.
   * @throws AuthorizationException
   *          if the user has no {@link Permissions#CREATE} permission on {@link Resources#PROCESS_INSTANCE}
   *          and no {@link Permissions#CREATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}.
   */
  ProcessInstance startProcessInstanceById(String processDefinitionId, String businessKey, String caseInstanceId, Map variables);

  /**
   * 

Signals the process engine that a message is received and starts a new * {@link ProcessInstance}.

* *

Calling this method can have two different outcomes: *

    *
  • If the message name is associated with a message start event, a new * process instance is started.
  • *
  • If no subscription to a message with the given name exists, {@link ProcessEngineException} * is thrown
  • *
*

* * @param messageName * the 'name' of the message as specified as an attribute on the * bpmn20 {@code } element. * @return the {@link ProcessInstance} object representing the started process instance * * @throws ProcessEngineException * if no subscription to a message with the given name exists * @throws AuthorizationException * if the user has no {@link Permissions#CREATE} permission on {@link Resources#PROCESS_INSTANCE} * and no {@link Permissions#CREATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}. * * @since 5.9 */ ProcessInstance startProcessInstanceByMessage(String messageName); /** *

Signals the process engine that a message is received and starts a new * {@link ProcessInstance}.

* * See {@link #startProcessInstanceByMessage(String, Map)}. This method allows * specifying a business key. * * @param messageName * the 'name' of the message as specified as an attribute on the * bpmn20 {@code } element. * @param businessKey * the business key which is added to the started process instance * * @throws ProcessEngineException * if no subscription to a message with the given name exists * @throws AuthorizationException * if the user has no {@link Permissions#CREATE} permission on {@link Resources#PROCESS_INSTANCE} * and no {@link Permissions#CREATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}. * * @since 5.10 */ ProcessInstance startProcessInstanceByMessage(String messageName, String businessKey); /** *

Signals the process engine that a message is received and starts a new * {@link ProcessInstance}.

* * See {@link #startProcessInstanceByMessage(String)}. In addition, this method allows * specifying a the payload of the message as a map of process variables. * * @param messageName * the 'name' of the message as specified as an attribute on the * bpmn20 {@code } element. * @param processVariables * the 'payload' of the message. The variables are added as processes * variables to the started process instance. * * @return the {@link ProcessInstance} object representing the started process instance * * @throws ProcessEngineException * if no subscription to a message with the given name exists * @throws AuthorizationException * if the user has no {@link Permissions#CREATE} permission on {@link Resources#PROCESS_INSTANCE} * and no {@link Permissions#CREATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}. * * @since 5.9 */ ProcessInstance startProcessInstanceByMessage(String messageName, Map processVariables); /** *

Signals the process engine that a message is received and starts a new * {@link ProcessInstance}.

* * See {@link #startProcessInstanceByMessage(String, Map)}. In addition, this method allows * specifying a business key. * * @param messageName * the 'name' of the message as specified as an attribute on the * bpmn20 {@code } element. * @param businessKey * the business key which is added to the started process instance * @param processVariables * the 'payload' of the message. The variables are added as processes * variables to the started process instance. * * @return the {@link ProcessInstance} object representing the started process instance * * @throws ProcessEngineException * if no subscription to a message with the given name exists * @throws AuthorizationException * if the user has no {@link Permissions#CREATE} permission on {@link Resources#PROCESS_INSTANCE} * and no {@link Permissions#CREATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}. * * @since 5.9 */ ProcessInstance startProcessInstanceByMessage(String messageName, String businessKey, Map processVariables); /** *

Signals the process engine that a message is received and starts a new * {@link ProcessInstance}.

* * See {@link #startProcessInstanceByMessage(String)}. In addition, this method allows * specifying the exactly version of the process definition with the given id. * * @param messageName * the 'name' of the message as specified as an attribute on the * bpmn20 {@code } element, cannot be null. * @param processDefinitionId * the id of the process definition, cannot be null. * * @return the {@link ProcessInstance} object representing the started process instance * * @throws ProcessEngineException * if no subscription to a message with the given name exists for the * specified version of process definition. * @throws AuthorizationException * if the user has no {@link Permissions#CREATE} permission on {@link Resources#PROCESS_INSTANCE} * and no {@link Permissions#CREATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}. * * @since 7.3 */ ProcessInstance startProcessInstanceByMessageAndProcessDefinitionId(String messageName, String processDefinitionId); /** *

Signals the process engine that a message is received and starts a new * {@link ProcessInstance}.

* * See {@link #startProcessInstanceByMessage(String, String)}. In addition, this method allows * specifying the exactly version of the process definition with the given id. * * @param messageName * the 'name' of the message as specified as an attribute on the * bpmn20 {@code } element, cannot be null. * @param processDefinitionId * the id of the process definition, cannot be null. * @param businessKey * the business key which is added to the started process instance * * @return the {@link ProcessInstance} object representing the started process instance * * @throws ProcessEngineException * if no subscription to a message with the given name exists for the * specified version of process definition. * @throws AuthorizationException * if the user has no {@link Permissions#CREATE} permission on {@link Resources#PROCESS_INSTANCE} * and no {@link Permissions#CREATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}. * * @since 7.3 */ ProcessInstance startProcessInstanceByMessageAndProcessDefinitionId(String messageName, String processDefinitionId, String businessKey); /** *

Signals the process engine that a message is received and starts a new * {@link ProcessInstance}.

* * See {@link #startProcessInstanceByMessage(String, Map)}. In addition, this method allows * specifying the exactly version of the process definition with the given id. * * @param messageName * the 'name' of the message as specified as an attribute on the * bpmn20 {@code } element, cannot be null. * @param processDefinitionId * the id of the process definition, cannot be null. * @param processVariables * the 'payload' of the message. The variables are added as processes * variables to the started process instance. * * @return the {@link ProcessInstance} object representing the started process instance * * @throws ProcessEngineException * if no subscription to a message with the given name exists for the * specified version of process definition. * * @throws AuthorizationException * if the user has no {@link Permissions#CREATE} permission on {@link Resources#PROCESS_INSTANCE} * and no {@link Permissions#CREATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}. * * @since 7.3 */ ProcessInstance startProcessInstanceByMessageAndProcessDefinitionId(String messageName, String processDefinitionId, Map processVariables); /** *

Signals the process engine that a message is received and starts a new * {@link ProcessInstance}.

* * See {@link #startProcessInstanceByMessage(String, String, Map)}. In addition, this method allows * specifying the exactly version of the process definition with the given id. * * @param messageName * the 'name' of the message as specified as an attribute on the * bpmn20 {@code } element, cannot be null. * @param processDefinitionId * the id of the process definition, cannot be null. * @param businessKey * the business key which is added to the started process instance * @param processVariables * the 'payload' of the message. The variables are added as processes * variables to the started process instance. * * @return the {@link ProcessInstance} object representing the started process instance * * @throws ProcessEngineException * if no subscription to a message with the given name exists for the * specified version of process definition. * @throws AuthorizationException * if the user has no {@link Permissions#CREATE} permission on {@link Resources#PROCESS_INSTANCE} * and no {@link Permissions#CREATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}. * * @since 7.3 */ ProcessInstance startProcessInstanceByMessageAndProcessDefinitionId(String messageName, String processDefinitionId, String businessKey, Map processVariables); /** * Delete an existing runtime process instance. * * Deletion propagates upward as far as necessary. * * @param processInstanceId id of process instance to delete, cannot be null. * @param deleteReason reason for deleting, which will be stored in the history. Can be null. * * @throws BadUserRequestException * when the processInstanceId is null. * @throws NotFoundException * when no process instance is found with the given processInstanceId. * @throws AuthorizationException * if the user has no {@link Permissions#DELETE} permission on {@link Resources#PROCESS_INSTANCE} * or no {@link Permissions#DELETE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}. */ void deleteProcessInstance(String processInstanceId, String deleteReason); /** * Delete an existing runtime process instances asynchronously using Batch operation. * * Deletion propagates upward as far as necessary. * * @param processInstanceIds id's of process instances to delete, cannot be null if processInstanceQuery is null. * @param processInstanceQuery query that will be used to fetch affected process instances. * Cannot be null if processInstanceIds are null. * @param deleteReason reason for deleting, which will be stored in the history. Can be null. * * @throws BadUserRequestException * when no process instance is found with the given id or id is null. * @throws AuthorizationException * If the user has no {@link Permissions#CREATE} or * {@link BatchPermissions#CREATE_BATCH_DELETE_RUNNING_PROCESS_INSTANCES} permission on {@link Resources#BATCH}. */ Batch deleteProcessInstancesAsync(List processInstanceIds, ProcessInstanceQuery processInstanceQuery, String deleteReason); /** * Delete an existing runtime process instances asynchronously using Batch operation. * * Deletion propagates upward as far as necessary. * * @param processInstanceIds id's of process instances to delete, cannot be null if processInstanceQuery is null. * @param processInstanceQuery query that will be used to fetch affected process instances. * Cannot be null if processInstanceIds are null. * @param deleteReason reason for deleting, which will be stored in the history. Can be null. * @param skipCustomListeners skips custom execution listeners when removing instances * @throws BadUserRequestException * when no process instance is found with the given id or id is null. * @throws AuthorizationException * If the user has no {@link Permissions#CREATE} or * {@link BatchPermissions#CREATE_BATCH_DELETE_RUNNING_PROCESS_INSTANCES} permission on {@link Resources#BATCH}. */ Batch deleteProcessInstancesAsync(List processInstanceIds, ProcessInstanceQuery processInstanceQuery, String deleteReason, boolean skipCustomListeners); /** * Delete an existing runtime process instances asynchronously using Batch operation. * * Deletion propagates upward as far as necessary. * * @param processInstanceIds id's of process instances to delete, cannot be null if processInstanceQuery is null. * @param processInstanceQuery query that will be used to fetch affected process instances. * Cannot be null if processInstanceIds are null. * @param deleteReason reason for deleting, which will be stored in the history. Can be null. * @param skipCustomListeners skips custom execution listeners when removing instances * @param skipSubprocesses skips subprocesses when removing instances * * @throws BadUserRequestException * when no process instance is found with the given id or id is null. * @throws AuthorizationException * If the user has no {@link Permissions#CREATE} or * {@link BatchPermissions#CREATE_BATCH_DELETE_RUNNING_PROCESS_INSTANCES} permission on {@link Resources#BATCH}. */ Batch deleteProcessInstancesAsync(List processInstanceIds, ProcessInstanceQuery processInstanceQuery, String deleteReason, boolean skipCustomListeners, boolean skipSubprocesses); /** * Delete an existing runtime process instances asynchronously using Batch operation. * * Deletion propagates upward as far as necessary. * * @param processInstanceIds id's of process instances to delete. * @param processInstanceQuery query that will be used to fetch affected process instances. * @param historicProcessInstanceQuery query that will be used to fetch affected * process instances based on history data. * @param deleteReason reason for deleting, which will be stored in the history. Can be null. * @param skipCustomListeners skips custom execution listeners when removing instances * @param skipSubprocesses skips subprocesses when removing instances * * @throws BadUserRequestException * when no process instance is found with the given queries or ids. * @throws AuthorizationException * If the user has no {@link Permissions#CREATE} or * {@link BatchPermissions#CREATE_BATCH_DELETE_RUNNING_PROCESS_INSTANCES} permission on {@link Resources#BATCH}. */ Batch deleteProcessInstancesAsync(List processInstanceIds, ProcessInstanceQuery processInstanceQuery, HistoricProcessInstanceQuery historicProcessInstanceQuery, String deleteReason, boolean skipCustomListeners, boolean skipSubprocesses); /** * Delete an existing runtime process instances asynchronously using Batch operation. * * Deletion propagates upward as far as necessary. * * @param processInstanceQuery query that will be used to fetch affected process instances. * Cannot be null. * @param deleteReason reason for deleting, which will be stored in the history. Can be null. * * @throws BadUserRequestException * when no process instance is found with the given id or id is null. * @throws AuthorizationException * If the user has no {@link Permissions#CREATE} or * {@link BatchPermissions#CREATE_BATCH_DELETE_RUNNING_PROCESS_INSTANCES} permission on {@link Resources#BATCH}. */ Batch deleteProcessInstancesAsync(ProcessInstanceQuery processInstanceQuery, String deleteReason); /** * Delete an existing runtime process instances asynchronously using Batch operation. * * Deletion propagates upward as far as necessary. * * If both process instances list and query are provided, process instances containing in both sets * will be deleted. * * @param processInstanceIds id's of process instances to delete, cannot be null. * @param deleteReason reason for deleting, which will be stored in the history. Can be null. * * @throws BadUserRequestException * when no process instance is found with the given id or id is null. * @throws AuthorizationException * If the user has no {@link Permissions#CREATE} or * {@link BatchPermissions#CREATE_BATCH_DELETE_RUNNING_PROCESS_INSTANCES} permission on {@link Resources#BATCH}. */ Batch deleteProcessInstancesAsync(List processInstanceIds, String deleteReason); /** * Delete an existing runtime process instance. * * Deletion propagates upward as far as necessary. * * @param processInstanceId id of process instance to delete, cannot be null. * @param deleteReason reason for deleting, which will be stored in the history. Can be null. * @param skipCustomListeners if true, only the built-in {@link ExecutionListener}s * are notified with the {@link ExecutionListener#EVENTNAME_END} event. * * @throws BadUserRequestException * when the processInstanceId is null. * @throws NotFoundException * when no process instance is found with the given processInstanceId. * @throws AuthorizationException * if the user has no {@link Permissions#DELETE} permission on {@link Resources#PROCESS_INSTANCE} * or no {@link Permissions#DELETE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}. */ void deleteProcessInstance(String processInstanceId, String deleteReason, boolean skipCustomListeners); /** * Delete an existing runtime process instance. * * Deletion propagates upward as far as necessary. * * @param processInstanceId id of process instance to delete, cannot be null. * @param deleteReason reason for deleting, which will be stored in the history. Can be null. * @param skipCustomListeners if true, only the built-in {@link ExecutionListener}s * are notified with the {@link ExecutionListener#EVENTNAME_END} event. * @param externallyTerminated indicator if deletion triggered from external context, for instance * REST API call * * * @throws BadUserRequestException * when the processInstanceId is null. * @throws NotFoundException * when no process instance is found with the given processInstanceId. * @throws AuthorizationException * if the user has no {@link Permissions#DELETE} permission on {@link Resources#PROCESS_INSTANCE} * or no {@link Permissions#DELETE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}. */ void deleteProcessInstance(String processInstanceId, String deleteReason, boolean skipCustomListeners, boolean externallyTerminated); /** * Delete existing runtime process instances. * * Deletion propagates upward as far as necessary. * * @param processInstanceIds ids of process instance to delete, cannot be null. * @param deleteReason reason for deleting, which will be stored in the history. Can be null. * @param skipCustomListeners if true, only the built-in {@link ExecutionListener}s * are notified with the {@link ExecutionListener#EVENTNAME_END} event. * @param externallyTerminated indicator if deletion triggered from external context, for instance * REST API call * * * @throws BadUserRequestException * when a processInstanceId is null. * @throws NotFoundException * when no process instance is found with a given processInstanceId. * @throws AuthorizationException * if the user has no {@link Permissions#DELETE} permission on {@link Resources#PROCESS_INSTANCE} * or no {@link Permissions#DELETE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}. */ void deleteProcessInstances(List processInstanceIds, String deleteReason, boolean skipCustomListeners, boolean externallyTerminated); /** * Delete existing runtime process instances. * * Deletion propagates upward as far as necessary. * * @param processInstanceIds ids of process instance to delete, cannot be null. * @param deleteReason reason for deleting, which will be stored in the history. Can be null. * @param skipCustomListeners if true, only the built-in {@link ExecutionListener}s * are notified with the {@link ExecutionListener#EVENTNAME_END} event. * @param externallyTerminated indicator if deletion triggered from external context, for instance * REST API call * @param skipSubprocesses specifies whether subprocesses should be deleted * * * @throws BadUserRequestException * when a processInstanceId is null. * @throws NotFoundException * when no process instance is found with a given processInstanceId. * @throws AuthorizationException * if the user has no {@link Permissions#DELETE} permission on {@link Resources#PROCESS_INSTANCE} * or no {@link Permissions#DELETE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}. */ void deleteProcessInstances(List processInstanceIds, String deleteReason, boolean skipCustomListeners, boolean externallyTerminated, boolean skipSubprocesses); /** * Delete existing runtime process instances. * * Deletion propagates upward as far as necessary. * * Does not fail if a process instance was not found. * * @param processInstanceIds ids of process instance to delete, cannot be null. * @param deleteReason reason for deleting, which will be stored in the history. Can be null. * @param skipCustomListeners if true, only the built-in {@link ExecutionListener}s * are notified with the {@link ExecutionListener#EVENTNAME_END} event. * @param externallyTerminated indicator if deletion triggered from external context, for instance * REST API call * @param skipSubprocesses specifies whether subprocesses should be deleted * * * @throws BadUserRequestException * when a processInstanceId is null. * @throws AuthorizationException * if the user has no {@link Permissions#DELETE} permission on {@link Resources#PROCESS_INSTANCE} * or no {@link Permissions#DELETE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}. */ void deleteProcessInstancesIfExists(List processInstanceIds, String deleteReason, boolean skipCustomListeners, boolean externallyTerminated, boolean skipSubprocesses); /** * Delete an existing runtime process instance. * * Deletion propagates upward as far as necessary. * * @param processInstanceId id of process instance to delete, cannot be null. * @param deleteReason reason for deleting, which will be stored in the history. Can be null. * @param skipCustomListeners if true, only the built-in {@link ExecutionListener}s * are notified with the {@link ExecutionListener#EVENTNAME_END} event. * @param externallyTerminated indicator if deletion triggered from external context, for instance * REST API call * @param skipIoMappings specifies whether input/output mappings for tasks should be invoked * * * @throws BadUserRequestException * when the processInstanceId is null. * @throws NotFoundException * when no process instance is found with the given processInstanceId. * @throws AuthorizationException * if the user has no {@link Permissions#DELETE} permission on {@link Resources#PROCESS_INSTANCE} * or no {@link Permissions#DELETE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}. */ void deleteProcessInstance(String processInstanceId, String deleteReason, boolean skipCustomListeners, boolean externallyTerminated, boolean skipIoMappings); /** * Delete an existing runtime process instance. * * Deletion propagates upward as far as necessary. * * @param processInstanceId id of process instance to delete, cannot be null. * @param deleteReason reason for deleting, which will be stored in the history. Can be null. * @param skipCustomListeners if true, only the built-in {@link ExecutionListener}s * are notified with the {@link ExecutionListener#EVENTNAME_END} event. * @param externallyTerminated indicator if deletion triggered from external context, for instance * REST API call * @param skipIoMappings specifies whether input/output mappings for tasks should be invoked * @param skipSubprocesses specifies whether subprocesses should be deleted * * * @throws BadUserRequestException * when the processInstanceId is null. * @throws NotFoundException * when no process instance is found with the given processInstanceId. * @throws AuthorizationException * if the user has no {@link Permissions#DELETE} permission on {@link Resources#PROCESS_INSTANCE} * or no {@link Permissions#DELETE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}. */ void deleteProcessInstance(String processInstanceId, String deleteReason, boolean skipCustomListeners, boolean externallyTerminated, boolean skipIoMappings, boolean skipSubprocesses); /** * Delete an existing runtime process instance. * * Deletion propagates upward as far as necessary. * * Does not fail if a process instance was not found. * * @param processInstanceId id of process instance to delete, cannot be null. * @param deleteReason reason for deleting, which will be stored in the history. Can be null. * @param skipCustomListeners if true, only the built-in {@link ExecutionListener}s * are notified with the {@link ExecutionListener#EVENTNAME_END} event. * @param externallyTerminated indicator if deletion triggered from external context, for instance * REST API call * @param skipIoMappings specifies whether input/output mappings for tasks should be invoked * @param skipSubprocesses specifies whether subprocesses should be deleted * * * @throws BadUserRequestException * when processInstanceId is null. * @throws AuthorizationException * if the user has no {@link Permissions#DELETE} permission on {@link Resources#PROCESS_INSTANCE} * or no {@link Permissions#DELETE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}. */ void deleteProcessInstanceIfExists(String processInstanceId, String deleteReason, boolean skipCustomListeners, boolean externallyTerminated, boolean skipIoMappings, boolean skipSubprocesses); /** * Finds the activity ids for all executions that are waiting in activities. * This is a list because a single activity can be active multiple times. * * Deletion propagates upward as far as necessary. * * @param executionId id of the process instance or the execution, cannot be null. * * @throws ProcessEngineException * when no execution exists with the given executionId. * @throws AuthorizationException * if the user has no {@link Permissions#READ} permission on {@link Resources#PROCESS_INSTANCE} * or no {@link Permissions#READ_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}. */ List getActiveActivityIds(String executionId); /** *

Allows retrieving the activity instance tree for a given process instance. * The activity instance tree is aligned with the concept of scope in the BPMN specification. * Activities that are "on the same level of subprocess" (ie. part of the same scope, contained * in the same subprocess) will have their activity instances at the same level in the tree.

* *

Examples:

*

    *
  • Process with two parallel user tasks after parallel Gateway: in the activity instance tree you * will see two activity instances below the root instance, one for each user task.
  • *
  • Process with two parallel Multi Instance user tasks after parallel Gateway: in the activity instance * tree, all instances of both user tasks will be listed below the root activity instance. Reason: all * activity instances are at the same level of subprocess.
  • *
  • Usertask inside embedded subprocess: the activity instance three will have 3 levels: the root instance * representing the process instance itself, below it an activity instance representing the instance of the embedded * subprocess, and below this one, the activity instance representing the usertask.
  • *

* *

Identity & Uniqueness:

*

Each activity instance is assigned a unique Id. The id is persistent, if you invoke this method multiple times, * the same activity instance ids will be returned for the same activity instances. (However, there might be * different executions assigned, see below)

* *

Relation to Executions

*

The {@link Execution} concept in the process engine is not completely aligned with the activity * instance concept because the execution tree is in general not aligned with the activity / scope concept in * BPMN. In general, there is a n-1 relationship between Executions and ActivityInstances, ie. at a given * point in time, an activity instance can be linked to multiple executions. In addition, it is not guaranteed * that the same execution that started a given activity instance will also end it. The process engine performs * several internal optimizations concerning the compacting of the execution tree which might lead to executions * being reordered and pruned. This can lead to situations where a given execution starts an activity instance * but another execution ends it. Another special case is the process instance: if the process instance is executing * a non-scope activity (for example a user task) below the process definition scope, it will be referenced * by both the root activity instance and the user task activity instance. * *

If you need to interpret the state of a process instance in terms of a BPMN process model, it is usually easier to * use the activity instance tree as opposed to the execution tree.

* * @param processInstanceId the id of the process instance for which the activity instance tree should be constructed. * * @return the activity instance tree for a given process instance or null if no such process instance exists. * * @throws ProcessEngineException * if processInstanceId is 'null' or an internal error occurs. * @throws AuthorizationException * if the user has no {@link Permissions#READ} permission on {@link Resources#PROCESS_INSTANCE} * or no {@link Permissions#READ_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}. * * @since 7.0 */ ActivityInstance getActivityInstance(String processInstanceId); /** * Sends an external trigger to an activity instance that is waiting inside the given execution. * * Note that you need to provide the exact execution that is waiting for the signal * if the process instance contains multiple executions. * * @param executionId id of process instance or execution to signal, cannot be null. * * @throws BadUserRequestException * when no execution is found for the given executionId or id is null. * @throws SuspendedEntityInteractionException * when the execution is suspended. * @throws AuthorizationException * if the user has no {@link Permissions#UPDATE} permission on {@link Resources#PROCESS_INSTANCE} * or no {@link Permissions#UPDATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}. */ void signal(String executionId); /** * Sends an external trigger to an activity instance that is waiting inside the given execution. * * Note that you need to provide the exact execution that is waiting for the signal * if the process instance contains multiple executions. * * @param executionId id of process instance or execution to signal, cannot be null. * @param signalName name of the signal (can be null) * @param signalData additional data of the signal (can be null) * @param processVariables a map of process variables (can be null) * * @throws ProcessEngineException * when no execution is found for the given executionId. * @throws AuthorizationException * if the user has no {@link Permissions#UPDATE} permission on {@link Resources#PROCESS_INSTANCE} * or no {@link Permissions#UPDATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}. */ void signal(String executionId, String signalName, Object signalData, Map processVariables); /** * Sends an external trigger to an activity instance that is waiting inside the given execution. * * Note that you need to provide the exact execution that is waiting for the signal * if the process instance contains multiple executions. * * @param executionId id of process instance or execution to signal, cannot be null. * @param processVariables a map of process variables * * @throws BadUserRequestException * when no execution is found for the given executionId or id is null. * @throws SuspendedEntityInteractionException * when the execution is suspended. * @throws AuthorizationException * if the user has no {@link Permissions#UPDATE} permission on {@link Resources#PROCESS_INSTANCE} * or no {@link Permissions#UPDATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}. */ void signal(String executionId, Map processVariables); // Variables //////////////////////////////////////////////////////////////////// /** * All variables visible from the given execution scope (including parent scopes). * * @param executionId id of process instance or execution, cannot be null. * * @return the variables or an empty map if no such variables are found. * * @throws ProcessEngineException * when no execution is found for the given executionId. * @throws AuthorizationException *
  • if the user has no {@link Permissions#READ} permission on {@link Resources#PROCESS_INSTANCE} or * no {@link Permissions#READ_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • In case {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} config is enabled and * the user has no {@link ProcessDefinitionPermisions#READ_INSTANCE_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
  • */ Map getVariables(String executionId); /** * All variables visible from the given execution scope (including parent scopes). * * @param executionId id of process instance or execution, cannot be null. * * @return the variables or an empty map if no such variables are found. * * @throws ProcessEngineException * when no execution is found for the given executionId. * @throws AuthorizationException *
  • if the user has no {@link Permissions#READ} permission on {@link Resources#PROCESS_INSTANCE} or * no {@link Permissions#READ_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • In case {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} config is enabled and * the user has no {@link ProcessDefinitionPermisions#READ_INSTANCE_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
  • * * @since 7.2 * */ VariableMap getVariablesTyped(String executionId); /** * All variables visible from the given execution scope (including parent scopes). * * @param executionId id of process instance or execution, cannot be null. * @param deserializeValues if false, {@link SerializableValue}s will not be deserialized * * @return the variables or an empty map if no such variables are found. * * @throws ProcessEngineException * when no execution is found for the given executionId. * @throws AuthorizationException *
  • if the user has no {@link Permissions#READ} permission on {@link Resources#PROCESS_INSTANCE} or * no {@link Permissions#READ_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • In case {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} config is enabled and * the user has no {@link ProcessDefinitionPermisions#READ_INSTANCE_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
  • * * @since 7.2 * */ VariableMap getVariablesTyped(String executionId, boolean deserializeValues); /** * All variable values that are defined in the execution scope, without taking outer scopes into account. * If you have many task local variables and you only need a few, consider using {@link #getVariablesLocal(String, Collection)} * for better performance. * @param executionId id of execution, cannot be null. * * @return the variables or an empty map if no such variables are found. * * @throws ProcessEngineException * when no execution is found for the given executionId. * @throws AuthorizationException *
  • if the user has no {@link Permissions#READ} permission on {@link Resources#PROCESS_INSTANCE} or * no {@link Permissions#READ_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • In case {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} config is enabled and * the user has no {@link ProcessDefinitionPermisions#READ_INSTANCE_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
  • */ Map getVariablesLocal(String executionId); /** * All variable values that are defined in the execution scope, without taking outer scopes into account. * If you have many task local variables and you only need a few, consider using {@link #getVariablesLocal(String, Collection)} * for better performance. * * @param executionId id of execution, cannot be null. * * @return the variables or an empty map if no such variables are found. * * @throws ProcessEngineException * when no execution is found for the given executionId. * @throws AuthorizationException *
  • if the user has no {@link Permissions#READ} permission on {@link Resources#PROCESS_INSTANCE} or * no {@link Permissions#READ_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • In case {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} config is enabled and * the user has no {@link ProcessDefinitionPermisions#READ_INSTANCE_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
  • */ VariableMap getVariablesLocalTyped(String executionId); /** * All variable values that are defined in the execution scope, without taking outer scopes into account. * If you have many task local variables and you only need a few, consider using {@link #getVariablesLocal(String, Collection)} * for better performance. * * @param executionId id of execution, cannot be null. * @param deserializeObjectValues if false, {@link SerializableValue}s will not be deserialized * * @return the variables or an empty map if no such variables are found. * * @throws ProcessEngineException * when no execution is found for the given executionId. * @throws AuthorizationException *
  • if the user has no {@link Permissions#READ} permission on {@link Resources#PROCESS_INSTANCE} or * no {@link Permissions#READ_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • In case {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} config is enabled and * the user has no {@link ProcessDefinitionPermisions#READ_INSTANCE_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
  • * * @since 7.2 */ VariableMap getVariablesLocalTyped(String executionId, boolean deserializeValues); /** * The variable values for all given variableNames, takes all variables into account which are visible from the given execution scope (including parent scopes). * * @param executionId id of process instance or execution, cannot be null. * @param variableNames the collection of variable names that should be retrieved. * * @return the variables or an empty map if no such variables are found. * * @throws ProcessEngineException * when no execution is found for the given executionId. * @throws AuthorizationException *
  • if the user has no {@link Permissions#READ} permission on {@link Resources#PROCESS_INSTANCE} or * no {@link Permissions#READ_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • In case {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} config is enabled and * the user has no {@link ProcessDefinitionPermisions#READ_INSTANCE_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
  • */ Map getVariables(String executionId, Collection variableNames); /** * The variable values for all given variableNames, takes all variables into account which are visible from the given execution scope (including parent scopes). * @param executionId id of process instance or execution, cannot be null. * @param variableNames the collection of variable names that should be retrieved. * @param deserializeObjectValues if false, {@link SerializableValue}s will not be deserialized * * @return the variables or an empty map if no such variables are found. * * @throws ProcessEngineException * when no execution is found for the given executionId. * @throws AuthorizationException *
  • if the user has no {@link Permissions#READ} permission on {@link Resources#PROCESS_INSTANCE} or * no {@link Permissions#READ_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • In case {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} config is enabled and * the user has no {@link ProcessDefinitionPermisions#READ_INSTANCE_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
  • * * @since 7.2 * */ VariableMap getVariablesTyped(String executionId, Collection variableNames, boolean deserializeValues); /** * The variable values for the given variableNames only taking the given execution scope into account, not looking in outer scopes. * * @param executionId id of execution, cannot be null. * @param variableNames the collection of variable names that should be retrieved. * * @return the variables or an empty map if no such variables are found. * * @throws ProcessEngineException * when no execution is found for the given executionId. * @throws AuthorizationException *
  • if the user has no {@link Permissions#READ} permission on {@link Resources#PROCESS_INSTANCE} or * no {@link Permissions#READ_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • In case {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} config is enabled and * the user has no {@link ProcessDefinitionPermisions#READ_INSTANCE_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
  • */ Map getVariablesLocal(String executionId, Collection variableNames); /** * The variable values for the given variableNames only taking the given execution scope into account, not looking in outer scopes. * @param executionId id of execution, cannot be null. * @param variableNames the collection of variable names that should be retrieved. * @param deserializeObjectValues if false, {@link SerializableValue}s will not be deserialized * * @return the variables or an empty map if no such variables are found. * * @throws ProcessEngineException * when no execution is found for the given executionId. * @throws AuthorizationException *
  • if the user has no {@link Permissions#READ} permission on {@link Resources#PROCESS_INSTANCE} or * no {@link Permissions#READ_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • In case {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} config is enabled and * the user has no {@link ProcessDefinitionPermisions#READ_INSTANCE_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
  • * * @since 7.2 * */ VariableMap getVariablesLocalTyped(String executionId, Collection variableNames, boolean deserializeValues); /** * The variable value. Searching for the variable is done in all scopes that are visible to the given execution (including parent scopes). * Returns null when no variable value is found with the given name or when the value is set to null. * * @param executionId id of process instance or execution, cannot be null. * @param variableName name of variable, cannot be null. * * @return the variable value or null if the variable is undefined or the value of the variable is null. * * @throws ProcessEngineException * when no execution is found for the given executionId. * @throws AuthorizationException *
  • if the user has no {@link Permissions#READ} permission on {@link Resources#PROCESS_INSTANCE} or * no {@link Permissions#READ_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • In case {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} config is enabled and * the user has no {@link ProcessDefinitionPermisions#READ_INSTANCE_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
  • */ Object getVariable(String executionId, String variableName); /** * Returns a {@link TypedValue} for the variable. Searching for the variable is done in all scopes that are visible * to the given execution (including parent scopes). Returns null when no variable value is found with the given name. * * @param executionId id of process instance or execution, cannot be null. * @param variableName name of variable, cannot be null. * * @return the variable value or null if the variable is undefined. * * @throws ProcessEngineException * when no execution is found for the given executionId. * @throws AuthorizationException *
  • if the user has no {@link Permissions#READ} permission on {@link Resources#PROCESS_INSTANCE} or * no {@link Permissions#READ_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • In case {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} config is enabled and * the user has no {@link ProcessDefinitionPermisions#READ_INSTANCE_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
  • * * @since 7.2 * */ T getVariableTyped(String executionId, String variableName); /** * Returns a {@link TypedValue} for the variable. Searching for the variable is done in all scopes that are visible * to the given execution (including parent scopes). Returns null when no variable value is found with the given name. * * @param executionId id of process instance or execution, cannot be null. * @param variableName name of variable, cannot be null. * @param deserializeValue if false, a {@link SerializableValue} will not be deserialized * * @return the variable value or null if the variable is undefined. * * @throws ProcessEngineException * when no execution is found for the given executionId. * @throws AuthorizationException *
  • if the user has no {@link Permissions#READ} permission on {@link Resources#PROCESS_INSTANCE} or * no {@link Permissions#READ_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • In case {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} config is enabled and * the user has no {@link ProcessDefinitionPermisions#READ_INSTANCE_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
  • * * @since 7.2 * */ T getVariableTyped(String executionId, String variableName, boolean deserializeValue); /** * The variable value for an execution. Returns the value when the variable is set * for the execution (and not searching parent scopes). Returns null when no variable value is found with the given name or when the value is set to null. * * @param executionId id of process instance or execution, cannot be null. * @param variableName name of variable, cannot be null. * * @return the variable value or null if the variable is undefined or the value of the variable is null. * * @throws ProcessEngineException * when no execution is found for the given executionId. * @throws AuthorizationException *
  • if the user has no {@link Permissions#READ} permission on {@link Resources#PROCESS_INSTANCE} or * no {@link Permissions#READ_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • In case {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} config is enabled and * the user has no {@link ProcessDefinitionPermisions#READ_INSTANCE_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
  • */ Object getVariableLocal(String executionId, String variableName); /** * Returns a {@link TypedValue} for the variable. Returns the value when the variable is set * for the execution (and not searching parent scopes). Returns null when no variable value is found with the given name. * * @param executionId id of process instance or execution, cannot be null. * @param variableName name of variable, cannot be null. * * @return the variable value or null if the variable is undefined. * * @throws ProcessEngineException * when no execution is found for the given executionId. * @throws AuthorizationException *
  • if the user has no {@link Permissions#READ} permission on {@link Resources#PROCESS_INSTANCE} or * no {@link Permissions#READ_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • In case {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} config is enabled and * the user has no {@link ProcessDefinitionPermisions#READ_INSTANCE_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
  • * * @since 7.2 * */ T getVariableLocalTyped(String executionId, String variableName); /** * Returns a {@link TypedValue} for the variable. Searching for the variable is done in all scopes that are visible * to the given execution (and not searching parent scopes). Returns null when no variable value is found with the given name. * * @param executionId id of process instance or execution, cannot be null. * @param variableName name of variable, cannot be null. * @param deserializeValue if false, a {@link SerializableValue} will not be deserialized * * @return the variable value or null if the variable is undefined. * * @throws ProcessEngineException * when no execution is found for the given executionId. * @throws AuthorizationException *
  • if the user has no {@link Permissions#READ} permission on {@link Resources#PROCESS_INSTANCE} or * no {@link Permissions#READ_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • In case {@link ProcessEngineConfiguration#enforceSpecificVariablePermission this} config is enabled and * the user has no {@link ProcessDefinitionPermisions#READ_INSTANCE_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
  • * * @since 7.2 * */ T getVariableLocalTyped(String executionId, String variableName, boolean deserializeValue); /** * Update or create a variable for an execution. If the variable does not already exist * somewhere in the execution hierarchy (i.e. the specified execution or any ancestor), * it will be created in the process instance (which is the root execution). * * @param executionId id of process instance or execution to set variable in, cannot be null. * @param variableName name of variable to set, cannot be null. * @param value value to set. When null is passed, the variable is not removed, * only it's value will be set to null. * * @throws ProcessEngineException * when no execution is found for the given executionId. * @throws AuthorizationException * if the user has none of the following: *
  • {@link ProcessInstancePermissions#UPDATE_VARIABLE} permission on {@link Resources#PROCESS_INSTANCE}
  • *
  • {@link ProcessDefinitionPermissions#UPDATE_INSTANCE_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • {@link Permissions#UPDATE} permission on {@link Resources#PROCESS_INSTANCE}
  • *
  • {@link Permissions#UPDATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}
  • */ void setVariable(String executionId, String variableName, Object value); /** * Update or create a variable for an execution (not considering parent scopes). * If the variable does not already exist, it will be created in the given execution. * * @param executionId id of execution to set variable in, cannot be null. * @param variableName name of variable to set, cannot be null. * @param value value to set. When null is passed, the variable is not removed, * only it's value will be set to null. * * @throws ProcessEngineException * when no execution is found for the given executionId. * @throws AuthorizationException * if the user has none of the following: *
  • {@link ProcessInstancePermissions#UPDATE_VARIABLE} permission on {@link Resources#PROCESS_INSTANCE}
  • *
  • {@link ProcessDefinitionPermissions#UPDATE_INSTANCE_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • {@link Permissions#UPDATE} permission on {@link Resources#PROCESS_INSTANCE}
  • *
  • {@link Permissions#UPDATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}
  • */ void setVariableLocal(String executionId, String variableName, Object value); /** * Update or create given variables for an execution (including parent scopes). If the variables are not already existing, they will be created in the process instance * (which is the root execution). * * @param executionId id of the process instance or the execution, cannot be null. * @param variables map containing name (key) and value of variables, can be null. * * @throws ProcessEngineException * when no execution is found for the given executionId. * @throws AuthorizationException * if the user has none of the following: *
  • {@link ProcessInstancePermissions#UPDATE_VARIABLE} permission on {@link Resources#PROCESS_INSTANCE}
  • *
  • {@link ProcessDefinitionPermissions#UPDATE_INSTANCE_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • {@link Permissions#UPDATE} permission on {@link Resources#PROCESS_INSTANCE}
  • *
  • {@link Permissions#UPDATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}
  • */ void setVariables(String executionId, Map variables); /** * Update or create given variables for an execution (not considering parent scopes). If the variables are not already existing, it will be created in the given execution. * * @param executionId id of the execution, cannot be null. * @param variables map containing name (key) and value of variables, can be null. * * @throws ProcessEngineException * when no execution is found for the given executionId. * @throws AuthorizationException * if the user has none of the following: *
  • {@link ProcessInstancePermissions#UPDATE_VARIABLE} permission on {@link Resources#PROCESS_INSTANCE}
  • *
  • {@link ProcessDefinitionPermissions#UPDATE_INSTANCE_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • {@link Permissions#UPDATE} permission on {@link Resources#PROCESS_INSTANCE}
  • *
  • {@link Permissions#UPDATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}
  • */ void setVariablesLocal(String executionId, Map variables); /** * Update or create runtime process variables in the root scope of process instances. * * @param processInstanceIds related to the process instances the variables will be set on; cannot * be {@code null} when processInstanceQuery and * historicProcessInstanceQuery are {@code null}. * @param processInstanceQuery to select process instances; Cannot be {@code null} when * processInstanceIds and historicProcessInstanceQuery * are {@code null}. * @param historicProcessInstanceQuery to select process instances; Cannot be {@code null} when * processInstanceIds and processInstanceQuery * are {@code null}. * @param variables that will be set to the root scope of the process instances * * @throws NullValueException
      *
    • when {@code variables} is {@code null}
    • *
    • when {@code processInstanceIds}, {@code processInstanceQuery} and * {@code historicProcessInstanceQuery} are {@code null}
    • *
    * @throws BadUserRequestException
      *
    • when {@code variables} is empty
    • *
    • when no process instance ids were found
    • *
    • when a transient variable is set
    • *
    * @throws ProcessEngineException when the java serialization format is prohibited * @throws AuthorizationException when the user has no {@link BatchPermissions#CREATE} or * {@link BatchPermissions#CREATE_BATCH_SET_VARIABLES} permission on {@link Resources#BATCH}. * * @return the batch which sets the variables asynchronously. */ Batch setVariablesAsync(List processInstanceIds, ProcessInstanceQuery processInstanceQuery, HistoricProcessInstanceQuery historicProcessInstanceQuery, Map variables); /** * Update or create runtime process variables in the root scope of process instances. * * @param processInstanceIds related to the process instances the variables will be set on * @param variables that will be set to the root scope of the process instances * * @throws NullValueException
      *
    • when {@code variables} is {@code null}
    • *
    • when {@code processInstanceIds} is {@code null}
    • *
    * @throws BadUserRequestException
      *
    • when {@code variables} is empty
    • *
    • when no process instance ids were found
    • *
    • when a transient variable is set
    • *
    * @throws ProcessEngineException when the java serialization format is prohibited * @throws AuthorizationException when the user has no {@link BatchPermissions#CREATE} or * {@link BatchPermissions#CREATE_BATCH_SET_VARIABLES} permission on {@link Resources#BATCH}. * * @return the batch which sets the variables asynchronously. */ Batch setVariablesAsync(List processInstanceIds, Map variables); /** * Update or create runtime process variables in the root scope of process instances. * * @param processInstanceQuery to select process instances * @param variables that will be set to the root scope of the process instances * * @throws NullValueException
      *
    • when {@code variables} is {@code null}
    • *
    • when {@code processInstanceQuery} is {@code null}
    • *
    * @throws BadUserRequestException
      *
    • when {@code variables} is empty
    • *
    • when no process instance ids were found
    • *
    • when a transient variable is set
    • *
    * @throws ProcessEngineException when the java serialization format is prohibited * @throws AuthorizationException when the user has no {@link BatchPermissions#CREATE} or * {@link BatchPermissions#CREATE_BATCH_SET_VARIABLES} permission on {@link Resources#BATCH}. * * @return the batch which sets the variables asynchronously. */ Batch setVariablesAsync(ProcessInstanceQuery processInstanceQuery, Map variables); /** * Update or create runtime process variables in the root scope of process instances. * * @param historicProcessInstanceQuery to select process instances * @param variables that will be set to the root scope of the process instances * * @throws NullValueException
      *
    • when {@code variables} is {@code null}
    • *
    • when {@code historicProcessInstanceQuery} is {@code null}
    • *
    * @throws BadUserRequestException
      *
    • when {@code variables} is empty
    • *
    • when no process instance ids were found
    • *
    • when a transient variable is set
    • *
    * @throws ProcessEngineException when the java serialization format is prohibited * @throws AuthorizationException when the user has no {@link BatchPermissions#CREATE} or * {@link BatchPermissions#CREATE_BATCH_SET_VARIABLES} permission on {@link Resources#BATCH}. * * @return the batch which sets the variables asynchronously. */ Batch setVariablesAsync(HistoricProcessInstanceQuery historicProcessInstanceQuery, Map variables); /** * Removes a variable for an execution. * * @param executionId id of process instance or execution to remove variable in. * @param variableName name of variable to remove. * * @throws ProcessEngineException * when no execution is found for the given executionId. * @throws AuthorizationException * if the user has none of the following: *
  • {@link ProcessInstancePermissions#UPDATE_VARIABLE} permission on {@link Resources#PROCESS_INSTANCE}
  • *
  • {@link ProcessDefinitionPermissions#UPDATE_INSTANCE_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • {@link Permissions#UPDATE} permission on {@link Resources#PROCESS_INSTANCE}
  • *
  • {@link Permissions#UPDATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}
  • */ void removeVariable(String executionId, String variableName); /** * Removes a variable for an execution (not considering parent scopes). * * @param executionId id of execution to remove variable in. * @param variableName name of variable to remove. * * @throws ProcessEngineException * when no execution is found for the given executionId. * @throws AuthorizationException * if the user has none of the following: *
  • {@link ProcessInstancePermissions#UPDATE_VARIABLE} permission on {@link Resources#PROCESS_INSTANCE}
  • *
  • {@link ProcessDefinitionPermissions#UPDATE_INSTANCE_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • {@link Permissions#UPDATE} permission on {@link Resources#PROCESS_INSTANCE}
  • *
  • {@link Permissions#UPDATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}
  • */ void removeVariableLocal(String executionId, String variableName); /** * Removes variables for an execution. * * @param executionId id of process instance or execution to remove variable in. * @param variableNames collection containing name of variables to remove. * * @throws ProcessEngineException * when no execution is found for the given executionId. * @throws AuthorizationException * if the user has none of the following: *
  • {@link ProcessInstancePermissions#UPDATE_VARIABLE} permission on {@link Resources#PROCESS_INSTANCE}
  • *
  • {@link ProcessDefinitionPermissions#UPDATE_INSTANCE_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • {@link Permissions#UPDATE} permission on {@link Resources#PROCESS_INSTANCE}
  • *
  • {@link Permissions#UPDATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}
  • */ void removeVariables(String executionId, Collection variableNames); /** * Remove variables for an execution (not considering parent scopes). * * @param executionId id of execution to remove variable in. * @param variableNames collection containing name of variables to remove. * * @throws ProcessEngineException * when no execution is found for the given executionId. * @throws AuthorizationException * if the user has none of the following: *
  • {@link ProcessInstancePermissions#UPDATE_VARIABLE} permission on {@link Resources#PROCESS_INSTANCE}
  • *
  • {@link ProcessDefinitionPermissions#UPDATE_INSTANCE_VARIABLE} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • {@link Permissions#UPDATE} permission on {@link Resources#PROCESS_INSTANCE}
  • *
  • {@link Permissions#UPDATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}
  • */ void removeVariablesLocal(String executionId, Collection variableNames); // Queries //////////////////////////////////////////////////////// /** Creates a new {@link ExecutionQuery} instance, * that can be used to query the executions and process instances. */ ExecutionQuery createExecutionQuery(); /** * creates a new {@link NativeExecutionQuery} to query {@link Execution}s * by SQL directly */ NativeExecutionQuery createNativeExecutionQuery(); /** * Creates a new {@link ProcessInstanceQuery} instance, that can be used * to query process instances. */ ProcessInstanceQuery createProcessInstanceQuery(); /** * creates a new {@link NativeProcessInstanceQuery} to query {@link ProcessInstance}s * by SQL directly */ NativeProcessInstanceQuery createNativeProcessInstanceQuery(); /** * Creates a new {@link IncidentQuery} instance, that can be used * to query incidents. */ IncidentQuery createIncidentQuery(); /** * Creates a new {@link EventSubscriptionQuery} instance, that can be used to query * event subscriptions. */ EventSubscriptionQuery createEventSubscriptionQuery(); /** * Creates a new {@link VariableInstanceQuery} instance, that can be used to query * variable instances. */ VariableInstanceQuery createVariableInstanceQuery(); // Process instance state ////////////////////////////////////////// /** *

    Suspends the process instance with the given id. This means that the * execution is stopped, so the token state will not change. * However, actions that do not change token state, like setting/removing * variables, etc. will succeed.

    * *

    Tasks belonging to this process instance will also be suspended. This means * that any actions influencing the tasks' lifecycles will fail, such as *

      *
    • claiming
    • *
    • completing
    • *
    • delegation
    • *
    • changes in task assignees, owners, etc.
    • *
    * Actions that only change task properties will succeed, such as changing variables * or adding comments. *

    * *

    If a process instance is in state suspended, the engine will also not * execute jobs (timers, messages) associated with this instance.

    * *

    If you have a process instance hierarchy, suspending * one process instance from the hierarchy will not suspend other * process instances from that hierarchy.

    * *

    Note: for more complex suspend commands use {@link #updateProcessInstanceSuspensionState()}.

    * * @throws ProcessEngineException * if no such processInstance can be found. * @throws AuthorizationException * if the user has none of the following: *
  • {@link ProcessInstancePermissions#SUSPEND} permission on {@link Resources#PROCESS_INSTANCE}
  • *
  • {@link ProcessDefinitionPermissions#SUSPEND_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • {@link Permissions#UPDATE} permission on {@link Resources#PROCESS_INSTANCE}
  • *
  • {@link Permissions#UPDATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}
  • */ void suspendProcessInstanceById(String processInstanceId); /** *

    Suspends the process instances with the given process definition id. * This means that the execution is stopped, so the token state * will not change. However, actions that do not change token state, like * setting/removing variables, etc. will succeed.

    * *

    Tasks belonging to the suspended process instance will also be suspended. * This means that any actions influencing the tasks' lifecycles will fail, such as *

      *
    • claiming
    • *
    • completing
    • *
    • delegation
    • *
    • changes in task assignees, owners, etc.
    • *
    * Actions that only change task properties will succeed, such as changing variables * or adding comments. *

    * *

    If a process instance is in state suspended, the engine will also not * execute jobs (timers, messages) associated with this instance.

    * *

    If you have a process instance hierarchy, suspending * one process instance from the hierarchy will not suspend other * process instances from that hierarchy.

    * *

    Note: for more complex suspend commands use {@link #updateProcessInstanceSuspensionState()}.

    * * @throws ProcessEngineException * if no such processInstance can be found. * @throws AuthorizationException * if the user has none of the following: *
  • {@link ProcessInstancePermissions#SUSPEND} permission on {@link Resources#PROCESS_INSTANCE}
  • *
  • {@link ProcessDefinitionPermissions#SUSPEND_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • {@link Permissions#UPDATE} permission on {@link Resources#PROCESS_INSTANCE}
  • *
  • {@link Permissions#UPDATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}
  • */ void suspendProcessInstanceByProcessDefinitionId(String processDefinitionId); /** *

    Suspends the process instances with the given process definition key. * This means that the execution is stopped, so the token state * will not change. However, actions that do not change token state, like * setting/removing variables, etc. will succeed.

    * *

    Tasks belonging to the suspended process instance will also be suspended. * This means that any actions influencing the tasks' lifecycles will fail, such as *

      *
    • claiming
    • *
    • completing
    • *
    • delegation
    • *
    • changes in task assignees, owners, etc.
    • *
    * Actions that only change task properties will succeed, such as changing variables * or adding comments. *

    * *

    If a process instance is in state suspended, the engine will also not * execute jobs (timers, messages) associated with this instance.

    * *

    If you have a process instance hierarchy, suspending * one process instance from the hierarchy will not suspend other * process instances from that hierarchy.

    * *

    Note: for more complex suspend commands use {@link #updateProcessInstanceSuspensionState()}.

    * * @throws ProcessEngineException * if no such processInstance can be found. * @throws AuthorizationException * if the user has none of the following: *
  • {@link ProcessInstancePermissions#SUSPEND} permission on {@link Resources#PROCESS_INSTANCE}
  • *
  • {@link ProcessDefinitionPermissions#SUSPEND_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • {@link Permissions#UPDATE} permission on {@link Resources#PROCESS_INSTANCE}
  • *
  • {@link Permissions#UPDATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}
  • */ void suspendProcessInstanceByProcessDefinitionKey(String processDefinitionKey); /** *

    Activates the process instance with the given id.

    * *

    If you have a process instance hierarchy, activating * one process instance from the hierarchy will not activate other * process instances from that hierarchy.

    * *

    Note: for more complex activate commands use {@link #updateProcessInstanceSuspensionState()}.

    * * @throws ProcessEngineException * if no such processInstance can be found. * @throws AuthorizationException * if the user has none of the following: *
  • {@link ProcessInstancePermissions#SUSPEND} permission on {@link Resources#PROCESS_INSTANCE}
  • *
  • {@link ProcessDefinitionPermissions#SUSPEND_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • {@link Permissions#UPDATE} permission on {@link Resources#PROCESS_INSTANCE}
  • *
  • {@link Permissions#UPDATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}
  • */ void activateProcessInstanceById(String processInstanceId); /** *

    Activates the process instance with the given process definition id.

    * *

    If you have a process instance hierarchy, activating * one process instance from the hierarchy will not activate other * process instances from that hierarchy.

    * *

    Note: for more complex activate commands use {@link #updateProcessInstanceSuspensionState()}.

    * * @throws ProcessEngineException * if the process definition id is null * @throws AuthorizationException * if the user has none of the following: *
  • {@link ProcessInstancePermissions#SUSPEND} permission on {@link Resources#PROCESS_INSTANCE}
  • *
  • {@link ProcessDefinitionPermissions#SUSPEND_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • {@link Permissions#UPDATE} permission on {@link Resources#PROCESS_INSTANCE}
  • *
  • {@link Permissions#UPDATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}
  • */ void activateProcessInstanceByProcessDefinitionId(String processDefinitionId); /** *

    Activates the process instance with the given process definition key.

    * *

    If you have a process instance hierarchy, activating * one process instance from the hierarchy will not activate other * process instances from that hierarchy.

    * *

    Note: for more complex activate commands use {@link #updateProcessInstanceSuspensionState()}.

    * * @throws ProcessEngineException * if the process definition id is null * @throws AuthorizationException * if the user has none of the following: *
  • {@link ProcessInstancePermissions#SUSPEND} permission on {@link Resources#PROCESS_INSTANCE}
  • *
  • {@link ProcessDefinitionPermissions#SUSPEND_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}
  • *
  • {@link Permissions#UPDATE} permission on {@link Resources#PROCESS_INSTANCE}
  • *
  • {@link Permissions#UPDATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}
  • */ void activateProcessInstanceByProcessDefinitionKey(String processDefinitionKey); /** * Activate or suspend process instances using a fluent builder. Specify the * instances by calling one of the by methods, like * byProcessInstanceId. To update the suspension state call * {@link UpdateProcessInstanceSuspensionStateBuilder#activate()} or * {@link UpdateProcessInstanceSuspensionStateBuilder#suspend()}. * * @return the builder to update the suspension state */ UpdateProcessInstanceSuspensionStateSelectBuilder updateProcessInstanceSuspensionState(); // Events //////////////////////////////////////////////////////////////////////// /** * Notifies the process engine that a signal event of name 'signalName' has * been received. Delivers the signal to all executions waiting on * the signal and to all process definitions that can started by this signal.

    * * NOTE: Notification and instantiation happen synchronously. * * @param signalName * the name of the signal event * * @throws AuthorizationException *

  • if notify an execution and the user has no {@link Permissions#UPDATE} permission on {@link Resources#PROCESS_INSTANCE} * or no {@link Permissions#UPDATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}.
  • *
  • if start a new process instance and the user has no {@link Permissions#CREATE} permission on {@link Resources#PROCESS_INSTANCE} * and no {@link Permissions#CREATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}.
  • */ void signalEventReceived(String signalName); /** * Notifies the process engine that a signal event of name 'signalName' has * been received. Delivers the signal to all executions waiting on * the signal and to all process definitions that can started by this signal.

    * * NOTE: Notification and instantiation happen synchronously. * * @param signalName * the name of the signal event * @param processVariables * a map of variables added to the execution(s) * * @throws AuthorizationException *

  • if notify an execution and the user has no {@link Permissions#UPDATE} permission on {@link Resources#PROCESS_INSTANCE} * or no {@link Permissions#UPDATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}.
  • *
  • if start a new process instance and the user has no {@link Permissions#CREATE} permission on {@link Resources#PROCESS_INSTANCE} * and no {@link Permissions#CREATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}.
  • */ void signalEventReceived(String signalName, Map processVariables); /** * Notifies the process engine that a signal event of name 'signalName' has * been received. This method delivers the signal to a single execution, being the * execution referenced by 'executionId'. * The waiting execution is notified synchronously. * * Note that you need to provide the exact execution that is waiting for the signal * if the process instance contains multiple executions. * * @param signalName * the name of the signal event * @param executionId * id of the process instance or the execution to deliver the signal to * * @throws ProcessEngineException * if no such execution exists or if the execution * has not subscribed to the signal * @throws AuthorizationException * if the user has no {@link Permissions#UPDATE} permission on {@link Resources#PROCESS_INSTANCE} * or no {@link Permissions#UPDATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}. */ void signalEventReceived(String signalName, String executionId); /** * Notifies the process engine that a signal event of name 'signalName' has * been received. This method delivers the signal to a single execution, being the * execution referenced by 'executionId'. * The waiting execution is notified synchronously. * * Note that you need to provide the exact execution that is waiting for the signal * if the process instance contains multiple executions. * * @param signalName * the name of the signal event * @param executionId * the id of the process instance or the execution to deliver the signal to * @param processVariables * a map of variables added to the execution(s) * * @throws ProcessEngineException * if no such execution exists or if the execution * has not subscribed to the signal * @throws AuthorizationException * if the user has no {@link Permissions#UPDATE} permission on {@link Resources#PROCESS_INSTANCE} * or no {@link Permissions#UPDATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}. */ void signalEventReceived(String signalName, String executionId, Map processVariables); /** * Notifies the process engine that a signal event has been received using a * fluent builder. * * @param signalName * the name of the signal event * @return the fluent builder to send the signal */ SignalEventReceivedBuilder createSignalEvent(String signalName); /** * Notifies the process engine that a message event with name 'messageName' has * been received and has been correlated to an execution with id 'executionId'. * * The waiting execution is notified synchronously. * * Note that you need to provide the exact execution that is waiting for the message * if the process instance contains multiple executions. * * @param messageName * the name of the message event * @param executionId * the id of the process instance or the execution to deliver the message to * * @throws ProcessEngineException * if no such execution exists or if the execution * has not subscribed to the signal * @throws AuthorizationException * if the user has no {@link Permissions#UPDATE} permission on {@link Resources#PROCESS_INSTANCE} * or no {@link Permissions#UPDATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}. */ void messageEventReceived(String messageName, String executionId); /** * Notifies the process engine that a message event with the name 'messageName' has * been received and has been correlated to an execution with id 'executionId'. * * The waiting execution is notified synchronously. * * Note that you need to provide the exact execution that is waiting for the message * if the process instance contains multiple executions. * * @param messageName * the name of the message event * @param executionId * the id of the process instance or the execution to deliver the message to * @param processVariables * a map of variables added to the execution * * @throws ProcessEngineException * if no such execution exists or if the execution * has not subscribed to the signal * @throws AuthorizationException * if the user has no {@link Permissions#UPDATE} permission on {@link Resources#PROCESS_INSTANCE} * or no {@link Permissions#UPDATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}. */ void messageEventReceived(String messageName, String executionId, Map processVariables); /** * Define a complex message correlation using a fluent builder. * * @param messageName the name of the message. Corresponds to the 'name' element * of the message defined in BPMN 2.0 Xml. * Can be null to correlate by other criteria (businessKey, processInstanceId, correlationKeys) only. * * @return the fluent builder for defining the message correlation. */ MessageCorrelationBuilder createMessageCorrelation(String messageName); /** * Correlates a message to either an execution that is waiting for this message or a process definition * that can be started by this message. * * Notification and instantiation happen synchronously. * * @param messageName * the name of the message event; if null, matches any event * * @throws MismatchingMessageCorrelationException * if none or more than one execution or process definition is correlated * @throws ProcessEngineException * if messageName is null * @throws AuthorizationException * if the user has no {@link Permissions#UPDATE} permission on {@link Resources#PROCESS_INSTANCE} * or no {@link Permissions#UPDATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}. */ void correlateMessage(String messageName); /** * Correlates a message to *
      *
    • * an execution that is waiting for a matching message and belongs to a process instance with the given business key *
    • *
    • * a process definition that can be started by a matching message. *
    • *
    * * Notification and instantiation happen synchronously. * * @param messageName * the name of the message event; if null, matches any event * @param businessKey * the business key of process instances to correlate against * * @throws MismatchingMessageCorrelationException * if none or more than one execution or process definition is correlated * @throws ProcessEngineException * if messageName is null and businessKey is null * @throws AuthorizationException * if the user has no {@link Permissions#UPDATE} permission on {@link Resources#PROCESS_INSTANCE} * or no {@link Permissions#UPDATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}. */ void correlateMessage(String messageName, String businessKey); /** * Correlates a message to *
      *
    • * an execution that is waiting for a matching message and can be correlated according * to the given correlation keys. This is typically matched against process instance variables. *
    • *
    • * a process definition that can be started by message with the provided name. *
    • *
    * * Notification and instantiation happen synchronously. * * @param messageName * the name of the message event; if null, matches any event * @param correlationKeys * a map of key value pairs that are used to correlate the message to an execution * * @throws MismatchingMessageCorrelationException * if none or more than one execution or process definition is correlated * @throws ProcessEngineException * if messageName is null and correlationKeys is null * @throws AuthorizationException * if the user has no {@link Permissions#UPDATE} permission on {@link Resources#PROCESS_INSTANCE} * or no {@link Permissions#UPDATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}. */ void correlateMessage(String messageName, Map correlationKeys); /** * Correlates a message to *
      *
    • * an execution that is waiting for a matching message and belongs to a process instance with the given business key *
    • *
    • * a process definition that can be started by this message. *
    • *
    * and updates the process instance variables. * * Notification and instantiation happen synchronously. * * @param messageName * the name of the message event; if null, matches any event * @param businessKey * the business key of process instances to correlate against * @param processVariables * a map of variables added to the execution or newly created process instance * * @throws MismatchingMessageCorrelationException * if none or more than one execution or process definition is correlated * @throws ProcessEngineException * if messageName is null and businessKey is null * @throws AuthorizationException * if the user has no {@link Permissions#UPDATE} permission on {@link Resources#PROCESS_INSTANCE} * or no {@link Permissions#UPDATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}. */ void correlateMessage(String messageName, String businessKey, Map processVariables); /** * Correlates a message to *
      *
    • * an execution that is waiting for a matching message and can be correlated according * to the given correlation keys. This is typically matched against process instance variables. *
    • *
    • * a process definition that can be started by this message. *
    • *
    * and updates the process instance variables. * * Notification and instantiation happen synchronously. * * @param messageName * the name of the message event; if null, matches any event * @param correlationKeys * a map of key value pairs that are used to correlate the message to an execution * @param processVariables * a map of variables added to the execution or newly created process instance * * @throws MismatchingMessageCorrelationException * if none or more than one execution or process definition is correlated * @throws ProcessEngineException * if messageName is null and correlationKeys is null * @throws AuthorizationException * if the user has no {@link Permissions#UPDATE} permission on {@link Resources#PROCESS_INSTANCE} * or no {@link Permissions#UPDATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}. */ void correlateMessage(String messageName, Map correlationKeys, Map processVariables); /** * Correlates a message to *
      *
    • * an execution that is waiting for a matching message and can be correlated according * to the given correlation keys. This is typically matched against process instance variables. * The process instance it belongs to has to have the given business key. *
    • *
    • * a process definition that can be started by this message. *
    • *
    * and updates the process instance variables. * * Notification and instantiation happen synchronously. * * @param messageName * the name of the message event; if null, matches any event * @param businessKey * the business key of process instances to correlate against * @param correlationKeys * a map of key value pairs that are used to correlate the message to an execution * @param processVariables * a map of variables added to the execution or newly created process instance * * @throws MismatchingMessageCorrelationException * if none or more than one execution or process definition is correlated * @throws ProcessEngineException * if messageName is null and businessKey is null and correlationKeys is null * @throws AuthorizationException * if the user has no {@link Permissions#UPDATE} permission on {@link Resources#PROCESS_INSTANCE} * or no {@link Permissions#UPDATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}. */ void correlateMessage(String messageName, String businessKey, Map correlationKeys, Map processVariables); /** * Define a complex asynchronous message correlation using a fluent builder. * * @param messageName the name of the message. Corresponds to the 'name' element * of the message defined in BPMN 2.0 Xml. * Can be null to correlate by other criteria only. * * @return the fluent builder for defining the asynchronous message correlation. */ MessageCorrelationAsyncBuilder createMessageCorrelationAsync(String messageName); /** * Define a modification of a process instance in terms of activity cancellations * and instantiations via a fluent builder. Instructions are executed in the order they are specified. * * @param processInstanceId the process instance to modify */ ProcessInstanceModificationBuilder createProcessInstanceModification(String processInstanceId); /** * Returns a fluent builder to start a new process instance in the exactly * specified version of the process definition with the given id. The builder * can be used to set further properties and specify instantiation * instructions to start the instance at any set of activities in the process. * If no instantiation instructions are set then the instance start at the * default start activity. * * @param processDefinitionId * the id of the process definition, cannot be null. * * @return a builder to create a process instance of the definition */ ProcessInstantiationBuilder createProcessInstanceById(String processDefinitionId); /** * Returns a fluent builder to start a new process instance in the latest * version of the process definition with the given key. The builder can be * used to set further properties and specify instantiation instructions to * start the instance at any set of activities in the process. If no * instantiation instructions are set then the instance start at the default * start activity. * * @param processDefinitionKey * the key of the process definition, cannot be null. * * @return a builder to create a process instance of the definition */ ProcessInstantiationBuilder createProcessInstanceByKey(String processDefinitionKey); /** * Creates a migration plan to migrate process instance between different process definitions. * Returns a fluent builder that can be used to specify migration instructions and build the plan. * * @param sourceProcessDefinitionId the process definition that instances are migrated from * @param targetProcessDefinitionId the process definition that instances are migrated to * @return a fluent builder */ MigrationPlanBuilder createMigrationPlan(String sourceProcessDefinitionId, String targetProcessDefinitionId); /** * Executes a migration plan for a given list of process instances. The migration can * either be executed synchronously or asynchronously. A synchronously migration * blocks the caller until the migration was completed. The migration can only be * successfully completed if all process instances can be migrated. * * If the migration is executed asynchronously a {@link Batch} is immediately returned. * The migration is then executed as jobs from the process engine and the batch can * be used to track the progress of the migration. The Batch splits the migration * in smaller chunks which will be executed independently. * * @param migrationPlan the migration plan to executed * @return a fluent builder */ MigrationPlanExecutionBuilder newMigration(MigrationPlan migrationPlan); /** * Creates a modification of multiple process instances in terms of activity cancellations * and instantiations via a fluent builder. Returns a fluent builder that can be used to specify * modification instructions and set process instances that should be modified. * * The modification can * either be executed synchronously or asynchronously. A synchronously modification * blocks the caller until the modification was completed. The modification can only be * successfully completed if all process instances can be modified. * * If the modification is executed asynchronously a {@link Batch} is immediately returned. * The modification is then executed as jobs from the process engine and the batch can * be used to track the progress of the modification. The Batch splits the modification * in smaller chunks which will be executed independently. * * @param processDefinitionId the process definition that instances are modified of * @return a fluent builder */ ModificationBuilder createModification(String processDefinitionId); /** * Restarts process instances that are completed or deleted with the initial or last set of variables. * * @param processDefinitionId the id of the process definition, cannot be null. * * @throws ProcessEngineException * when no process definition is deployed with the given key or a process instance is still active. * @throws AuthorizationException * if the user has not all of the following permissions *
      *
    • {@link Permissions#CREATE} permission on {@link Resources#PROCESS_INSTANCE}
    • *
    • {@link Permissions#CREATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}
    • *
    • {@link Permissions#READ_HISTORY} permission on {@link Resources#PROCESS_DEFINITION}
    • *
    */ RestartProcessInstanceBuilder restartProcessInstances(String processDefinitionId); /** * Creates an incident * * @param incidentType the type of incident, cannot be null * @param executionId execution id, cannot be null * @param configuration * * @return a new incident * * @throws AuthorizationException * if the user has no {@link Permissions#UPDATE} permission on {@link Resources#PROCESS_INSTANCE} * and no {@link Permissions#UPDATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}. */ Incident createIncident(String incidentType, String executionId, String configuration); /** * Creates an incident * * @param incidentType the type of incident, cannot be null * @param executionId execution id, cannot be null * @param configuration * @param message * * @return a new incident * * @throws AuthorizationException * if the user has no {@link Permissions#UPDATE} permission on {@link Resources#PROCESS_INSTANCE} * and no {@link Permissions#UPDATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}. */ Incident createIncident(String incidentType, String executionId, String configuration, String message); /** * Resolves and remove an incident * * @param incidentId the id of an incident to resolve * * @throws AuthorizationException * if the user has no {@link Permissions#UPDATE} permission on {@link Resources#PROCESS_INSTANCE} * and no {@link Permissions#UPDATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}. */ void resolveIncident(String incidentId); /** * Set an annotation to an incident. * * @throws NotValidException when incident id is {@code null} * @throws BadUserRequestException when no incident could be found * @throws AuthorizationException * if the user has no {@link Permissions#UPDATE} permission on {@link Resources#PROCESS_INSTANCE} * and no {@link Permissions#UPDATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}. * * @param incidentId of the incident that the annotation is updated at * @param annotation that is set to the incident * * @since 7.15 */ void setAnnotationForIncidentById(String incidentId, String annotation); /** * Clear the annotation for an incident. * * @throws NotValidException when incident id is {@code null} * @throws BadUserRequestException when no incident could be found * @throws AuthorizationException * if the user has no {@link Permissions#UPDATE} permission on {@link Resources#PROCESS_INSTANCE} * and no {@link Permissions#UPDATE_INSTANCE} permission on {@link Resources#PROCESS_DEFINITION}. * * @param incidentId of the incident that the annotation is cleared at * * @since 7.15 */ void clearAnnotationForIncidentById(String incidentId); /** * Define a complex condition evaluation using a fluent builder. * * @return the fluent builder for defining the condition evaluation. */ ConditionEvaluationBuilder createConditionEvaluation(); }




    © 2015 - 2025 Weber Informatics LLC | Privacy Policy