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

org.camunda.bpm.engine.HistoryService 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 org.camunda.bpm.engine.authorization.BatchPermissions;
import org.camunda.bpm.engine.authorization.HistoricProcessInstancePermissions;
import org.camunda.bpm.engine.authorization.HistoricTaskPermissions;
import org.camunda.bpm.engine.authorization.Permissions;
import org.camunda.bpm.engine.authorization.ProcessDefinitionPermissions;
import org.camunda.bpm.engine.authorization.Resources;
import org.camunda.bpm.engine.authorization.UserOperationLogCategoryPermissions;
import org.camunda.bpm.engine.batch.Batch;
import org.camunda.bpm.engine.batch.history.HistoricBatchQuery;
import org.camunda.bpm.engine.exception.NotValidException;
import org.camunda.bpm.engine.history.HistoricActivityInstance;
import org.camunda.bpm.engine.history.HistoricActivityInstanceQuery;
import org.camunda.bpm.engine.history.HistoricActivityStatisticsQuery;
import org.camunda.bpm.engine.history.HistoricCaseActivityInstance;
import org.camunda.bpm.engine.history.HistoricCaseActivityInstanceQuery;
import org.camunda.bpm.engine.history.HistoricCaseActivityStatisticsQuery;
import org.camunda.bpm.engine.history.HistoricCaseInstance;
import org.camunda.bpm.engine.history.HistoricCaseInstanceQuery;
import org.camunda.bpm.engine.history.HistoricDecisionInstance;
import org.camunda.bpm.engine.history.HistoricDecisionInstanceQuery;
import org.camunda.bpm.engine.history.HistoricDetail;
import org.camunda.bpm.engine.history.HistoricDetailQuery;
import org.camunda.bpm.engine.history.HistoricExternalTaskLogQuery;
import org.camunda.bpm.engine.history.CleanableHistoricBatchReport;
import org.camunda.bpm.engine.history.CleanableHistoricCaseInstanceReport;
import org.camunda.bpm.engine.history.CleanableHistoricDecisionInstanceReport;
import org.camunda.bpm.engine.history.CleanableHistoricProcessInstanceReport;
import org.camunda.bpm.engine.history.HistoricExternalTaskLog;
import org.camunda.bpm.engine.history.HistoricIdentityLinkLog;
import org.camunda.bpm.engine.history.HistoricIdentityLinkLogQuery;
import org.camunda.bpm.engine.history.HistoricIncident;
import org.camunda.bpm.engine.history.HistoricIncidentQuery;
import org.camunda.bpm.engine.history.HistoricJobLog;
import org.camunda.bpm.engine.history.HistoricJobLogQuery;
import org.camunda.bpm.engine.history.HistoricProcessInstance;
import org.camunda.bpm.engine.history.HistoricProcessInstanceQuery;
import org.camunda.bpm.engine.history.HistoricProcessInstanceReport;
import org.camunda.bpm.engine.history.HistoricTaskInstance;
import org.camunda.bpm.engine.history.HistoricTaskInstanceQuery;
import org.camunda.bpm.engine.history.HistoricTaskInstanceReport;
import org.camunda.bpm.engine.history.HistoricVariableInstance;
import org.camunda.bpm.engine.history.HistoricVariableInstanceQuery;
import org.camunda.bpm.engine.history.NativeHistoricActivityInstanceQuery;
import org.camunda.bpm.engine.history.NativeHistoricCaseActivityInstanceQuery;
import org.camunda.bpm.engine.history.NativeHistoricCaseInstanceQuery;
import org.camunda.bpm.engine.history.NativeHistoricDecisionInstanceQuery;
import org.camunda.bpm.engine.history.NativeHistoricProcessInstanceQuery;
import org.camunda.bpm.engine.history.NativeHistoricTaskInstanceQuery;
import org.camunda.bpm.engine.history.NativeHistoricVariableInstanceQuery;
import org.camunda.bpm.engine.history.SetRemovalTimeSelectModeForHistoricBatchesBuilder;
import org.camunda.bpm.engine.history.SetRemovalTimeSelectModeForHistoricDecisionInstancesBuilder;
import org.camunda.bpm.engine.history.SetRemovalTimeSelectModeForHistoricProcessInstancesBuilder;
import org.camunda.bpm.engine.history.SetRemovalTimeToHistoricBatchesBuilder;
import org.camunda.bpm.engine.history.SetRemovalTimeToHistoricDecisionInstancesBuilder;
import org.camunda.bpm.engine.history.UserOperationLogEntry;
import org.camunda.bpm.engine.history.UserOperationLogQuery;
import org.camunda.bpm.engine.history.HistoricDecisionInstanceStatisticsQuery;
import org.camunda.bpm.engine.history.SetRemovalTimeToHistoricProcessInstancesBuilder;
import org.camunda.bpm.engine.impl.cfg.ProcessEngineConfigurationImpl;
import org.camunda.bpm.engine.repository.ProcessDefinition;
import org.camunda.bpm.engine.runtime.Job;

import java.util.Date;
import java.util.List;

/**
 * Service exposing information about ongoing and past process instances.  This is different
 * from the runtime information in the sense that this runtime information only contains
 * the actual runtime state at any given moment and it is optimized for runtime
 * process execution performance.  The history information is optimized for easy
 * querying and remains permanent in the persistent storage.
 *
 * @author Christian Stettler
 * @author Tom Baeyens
 * @author Joram Barrez
 */
public interface HistoryService {

  /**
   * 

Creates a new programmatic query to search for {@link HistoricProcessInstance}s. * *

The result of the query is empty in the following cases: *

    *
  • The user has no {@link Permissions#READ_HISTORY} permission on * {@link Resources#PROCESS_DEFINITION} OR *
  • The user has no {@link HistoricProcessInstancePermissions#READ} permission on * {@link Resources#HISTORIC_PROCESS_INSTANCE} ({@code enableHistoricInstancePermissions} in * {@link ProcessEngineConfigurationImpl} must be set to {@code true}) * */ HistoricProcessInstanceQuery createHistoricProcessInstanceQuery(); /** *

    Creates a new programmatic query to search for {@link HistoricActivityInstance}s. * *

    The result of the query is empty in the following cases: *

      *
    • The user has no {@link Permissions#READ_HISTORY} permission on * {@link Resources#PROCESS_DEFINITION} OR *
    • The user has no {@link HistoricProcessInstancePermissions#READ} permission on * {@link Resources#HISTORIC_PROCESS_INSTANCE} ({@code enableHistoricInstancePermissions} in * {@link ProcessEngineConfigurationImpl} must be set to {@code true}) * * */ HistoricActivityInstanceQuery createHistoricActivityInstanceQuery(); /** *

      Query for the number of historic activity instances aggregated by activities of a single * process definition. * *

      The result of the query is empty when the user has no {@link Permissions#READ_HISTORY} * permission on {@link Resources#PROCESS_DEFINITION} */ HistoricActivityStatisticsQuery createHistoricActivityStatisticsQuery(String processDefinitionId); /** * Query for the number of historic case activity instances aggregated by case activities of a single case definition. */ HistoricCaseActivityStatisticsQuery createHistoricCaseActivityStatisticsQuery(String caseDefinitionId); /** *

      Creates a new programmatic query to search for {@link HistoricTaskInstance}s. * *

      The result of the query is empty in the following cases: *

        *
      • The user has no {@link Permissions#READ_HISTORY} permission on * {@link Resources#PROCESS_DEFINITION} OR *
      • The user has no {@link HistoricProcessInstancePermissions#READ} permission on * {@link Resources#HISTORIC_PROCESS_INSTANCE} ({@code enableHistoricInstancePermissions} in * {@link ProcessEngineConfigurationImpl} must be set to {@code true}) OR *
      • The user has no {@link HistoricTaskPermissions#READ} permission on * {@link Resources#HISTORIC_TASK} ({@code enableHistoricInstancePermissions} in * {@link ProcessEngineConfigurationImpl} must be set to {@code true}) * */ HistoricTaskInstanceQuery createHistoricTaskInstanceQuery(); /** *

        Creates a new programmatic query to search for {@link HistoricDetail}s. * *

        The result of the query is empty in the following cases: *

          *
        • The user has no {@link Permissions#READ_HISTORY} permission on * {@link Resources#PROCESS_DEFINITION} OR *
        • The user has no {@link HistoricTaskPermissions#READ} permission on * {@link Resources#HISTORIC_TASK} ({@code enableHistoricInstancePermissions} in * {@link ProcessEngineConfigurationImpl} must be set to {@code true}) OR *
        • The user has no {@link HistoricProcessInstancePermissions#READ} permission on * {@link Resources#HISTORIC_PROCESS_INSTANCE} ({@code enableHistoricInstancePermissions} in * {@link ProcessEngineConfigurationImpl} must be set to {@code true}) OR *
        • The user has no {@link ProcessDefinitionPermissions#READ_HISTORY_VARIABLE} permission on * {@link Resources#PROCESS_DEFINITION} * ({@link ProcessEngineConfigurationImpl#enforceSpecificVariablePermission} must be set to * {@code true}) OR *
        • The user has no {@link HistoricTaskPermissions#READ_VARIABLE} permission on * {@link Resources#HISTORIC_TASK} ({@code enforceSpecificVariablePermission} and * {@code enableHistoricInstancePermissions} * in {@link ProcessEngineConfigurationImpl} must be set to {@code true}) * */ HistoricDetailQuery createHistoricDetailQuery(); /** *

          Creates a new programmatic query to search for {@link HistoricVariableInstance}s. * *

          The result of the query is empty in the following cases: *

            *
          • The user has no {@link Permissions#READ_HISTORY} permission on * {@link Resources#PROCESS_DEFINITION} OR *
          • The user has no {@link HistoricTaskPermissions#READ} permission on * {@link Resources#HISTORIC_TASK} ({@code enableHistoricInstancePermissions} in * {@link ProcessEngineConfigurationImpl} must be set to {@code true}) OR *
          • The user has no {@link HistoricProcessInstancePermissions#READ} permission on * {@link Resources#HISTORIC_PROCESS_INSTANCE} ({@code enableHistoricInstancePermissions} in * {@link ProcessEngineConfigurationImpl} must be set to {@code true}) OR *
          • The user has no {@link ProcessDefinitionPermissions#READ_HISTORY_VARIABLE} permission on * {@link Resources#PROCESS_DEFINITION} * ({@link ProcessEngineConfigurationImpl#enforceSpecificVariablePermission} must be set to * {@code true}) OR *
          • The user has no {@link HistoricTaskPermissions#READ_VARIABLE} permission on * {@link Resources#HISTORIC_TASK} ({@code enforceSpecificVariablePermission} and * {@code enableHistoricInstancePermissions} * in {@link ProcessEngineConfigurationImpl} must be set to {@code true}) * */ HistoricVariableInstanceQuery createHistoricVariableInstanceQuery(); /**

            Creates a new programmatic query to search for {@link UserOperationLogEntry} instances. * *

            The result of the query is empty in the following cases: *

              *
            • The user has no {@link Permissions#READ_HISTORY} permission on * {@link Resources#PROCESS_DEFINITION} OR *
            • The user has no {@link HistoricProcessInstancePermissions#READ} permission on * {@link Resources#HISTORIC_PROCESS_INSTANCE} ({@code enableHistoricInstancePermissions} in * {@link ProcessEngineConfigurationImpl} must be set to {@code true}) OR *
            • The user has no {@link HistoricTaskPermissions#READ} permission on * {@link Resources#HISTORIC_TASK} ({@code enableHistoricInstancePermissions} in * {@link ProcessEngineConfigurationImpl} must be set to {@code true}) * * */ UserOperationLogQuery createUserOperationLogQuery(); /** *

              Creates a new programmatic query to search for {@link HistoricIncident historic incidents}. * *

              The result of the query is empty in the following cases: *

                *
              • The user has no {@link Permissions#READ_HISTORY} permission on * {@link Resources#PROCESS_DEFINITION} OR *
              • The user has no {@link HistoricProcessInstancePermissions#READ} permission on * {@link Resources#HISTORIC_PROCESS_INSTANCE} ({@code enableHistoricInstancePermissions} in * {@link ProcessEngineConfigurationImpl} must be set to {@code true}) * */ HistoricIncidentQuery createHistoricIncidentQuery(); /** *

                Creates a new programmatic query to search for * {@link HistoricIdentityLinkLog historic identity links}. * *

                The result of the query is empty in the following cases: *

                  *
                • The user has no {@link Permissions#READ_HISTORY} permission on * {@link Resources#PROCESS_DEFINITION} OR *
                • The user has no {@link HistoricTaskPermissions#READ} permission on * {@link Resources#HISTORIC_TASK} ({@code enableHistoricInstancePermissions} in * {@link ProcessEngineConfigurationImpl} must be set to {@code true}) * */ HistoricIdentityLinkLogQuery createHistoricIdentityLinkLogQuery(); /** Creates a new programmatic query to search for {@link HistoricCaseInstance}s. */ HistoricCaseInstanceQuery createHistoricCaseInstanceQuery(); /** Creates a new programmatic query to search for {@link HistoricCaseActivityInstance}s. */ HistoricCaseActivityInstanceQuery createHistoricCaseActivityInstanceQuery(); /** * Creates a new programmatic query to search for {@link HistoricDecisionInstance}s. * * If the user has no {@link Permissions#READ_HISTORY} permission on {@link Resources#DECISION_DEFINITION} * then the result of the query is empty. */ HistoricDecisionInstanceQuery createHistoricDecisionInstanceQuery(); /** * Deletes historic task instance. This might be useful for tasks that are * {@link TaskService#newTask() dynamically created} and then {@link TaskService#complete(String) completed}. * If the historic task instance doesn't exist, no exception is thrown and the * method returns normal. * * @throws AuthorizationException * If the user has no {@link Permissions#DELETE_HISTORY} permission on {@link Resources#PROCESS_DEFINITION}. */ void deleteHistoricTaskInstance(String taskId); /** * Deletes historic process instance. All historic activities, historic task and * historic details (variable updates, form properties) are deleted as well. * * @throws AuthorizationException * If the user has no {@link Permissions#DELETE_HISTORY} permission on {@link Resources#PROCESS_DEFINITION}. */ void deleteHistoricProcessInstance(String processInstanceId); /** * Deletes historic process instance. All historic activities, historic task and * historic details (variable updates, form properties) are deleted as well. * Does not fail if a process instance was not found. * * @throws AuthorizationException * If the user has no {@link Permissions#DELETE_HISTORY} permission on {@link Resources#PROCESS_DEFINITION}. */ void deleteHistoricProcessInstanceIfExists(String processInstanceId); /** * Deletes historic process instances. All historic activities, historic task and * historic details (variable updates, form properties) are deleted as well. * * @throws BadUserRequestException * when no process instances are found with the given ids or ids are null. * @throws AuthorizationException * If the user has no {@link Permissions#DELETE_HISTORY} permission on {@link Resources#PROCESS_DEFINITION}. */ void deleteHistoricProcessInstances(List processInstanceIds); /** * Deletes historic process instances. All historic activities, historic task and * historic details (variable updates, form properties) are deleted as well. Does not * fail if a process instance was not found. * * @throws AuthorizationException * If the user has no {@link Permissions#DELETE_HISTORY} permission on {@link Resources#PROCESS_DEFINITION}. */ void deleteHistoricProcessInstancesIfExists(List processInstanceIds); /** * Deletes historic process instances and all related historic data in bulk manner. DELETE SQL statement will be created for each entity type. They will have list * of given process instance ids in IN clause. Therefore, DB limitation for number of values in IN clause must be taken into account. * * @param processInstanceIds list of process instance ids for removal * * @throws BadUserRequestException * when no process instances are found with the given ids or ids are null or when some of the process instances are not finished yet * @throws AuthorizationException * If the user has no {@link Permissions#DELETE_HISTORY} permission on {@link Resources#PROCESS_DEFINITION}. */ void deleteHistoricProcessInstancesBulk(List processInstanceIds); /** * Schedules history cleanup job at batch window start time. The job will delete historic data for * finished process, decision and case instances, and batch operations taking into account {@link ProcessDefinition#getHistoryTimeToLive()}, * {@link DecisionDefinition#getHistoryTimeToLive()}, {@link CaseDefinition#getHistoryTimeToLive()}, {@link ProcessEngineConfigurationImpl#getBatchOperationHistoryTimeToLive()} * and {@link ProcessEngineConfigurationImpl#getBatchOperationsForHistoryCleanup()} values. * * @throws AuthorizationException * If the user has no {@link Permissions#DELETE_HISTORY} permission on {@link Resources#PROCESS_DEFINITION} * @return history cleanup job. NB! As of v. 7.9.0, method does not guarantee to return a job. Use {@link #findHistoryCleanupJobs()} instead. */ Job cleanUpHistoryAsync(); /** * Schedules history cleanup job at batch window start time. The job will delete historic data for * finished process, decision and case instances, and batch operations taking into account {@link ProcessDefinition#getHistoryTimeToLive()}, * {@link DecisionDefinition#getHistoryTimeToLive()}, {@link CaseDefinition#getHistoryTimeToLive()}, {@link ProcessEngineConfigurationImpl#getBatchOperationHistoryTimeToLive()} * and {@link ProcessEngineConfigurationImpl#getBatchOperationsForHistoryCleanup()} values. * * @param immediatelyDue must be true if cleanup must be scheduled at once, otherwise is will be scheduled according to configured batch window * @throws AuthorizationException * If the user has no {@link Permissions#DELETE_HISTORY} permission on {@link Resources#PROCESS_DEFINITION} * @return history cleanup job. Job id can be used to check job logs, incident etc. * */ Job cleanUpHistoryAsync(boolean immediatelyDue); /** * Finds history cleanup job, if present. * @deprecated As of v. 7.9.0, because there can be more than one history cleanup job at once, use {@link #findHistoryCleanupJobs} instead. * @return job entity */ @Deprecated Job findHistoryCleanupJob(); /** * Finds history cleanup job if present. * @return job entity */ List findHistoryCleanupJobs(); /** * Deletes historic process instances asynchronously. All historic activities, historic task and * historic details (variable updates, form properties) are deleted as well. * * @throws BadUserRequestException * when no process instances is found with the given ids or ids are null. * @throws AuthorizationException * If the user has no {@link Permissions#CREATE} or * {@link BatchPermissions#CREATE_BATCH_DELETE_FINISHED_PROCESS_INSTANCES} permission on {@link Resources#BATCH}. */ Batch deleteHistoricProcessInstancesAsync(List processInstanceIds, String deleteReason); /** * Deletes historic process instances asynchronously based on query. All historic activities, historic task and * historic details (variable updates, form properties) are deleted as well. * * @throws BadUserRequestException * when no process instances is found with the given ids or ids are null. * @throws AuthorizationException * If the user has no {@link Permissions#CREATE} or * {@link BatchPermissions#CREATE_BATCH_DELETE_FINISHED_PROCESS_INSTANCES} permission on {@link Resources#BATCH}. */ Batch deleteHistoricProcessInstancesAsync(HistoricProcessInstanceQuery query, String deleteReason); /** * Deletes historic process instances asynchronously based on query and a list of process instances. Query result and * list of ids will be merged. * All historic activities, historic task and historic details (variable updates, form properties) are deleted as well. * * @throws BadUserRequestException * when no process instances is found with the given ids or ids are null. * @throws AuthorizationException * If the user has no {@link Permissions#CREATE} or * {@link BatchPermissions#CREATE_BATCH_DELETE_FINISHED_PROCESS_INSTANCES} permission on {@link Resources#BATCH}. */ Batch deleteHistoricProcessInstancesAsync(List processInstanceIds, HistoricProcessInstanceQuery query, String deleteReason); /** * Deletes a user operation log entry. Does not cascade to any related entities. * * @throws AuthorizationException * For entries related to process definition keys: If the user has * neither {@link Permissions#DELETE_HISTORY} permission on * {@link Resources#PROCESS_DEFINITION} nor * {@link UserOperationLogCategoryPermissions#DELETE} permission on * {@link Resources#OPERATION_LOG_CATEGORY}. For entries not related * to process definition keys: If the user has no * {@link UserOperationLogCategoryPermissions#DELETE} permission on * {@link Resources#OPERATION_LOG_CATEGORY}. */ void deleteUserOperationLogEntry(String entryId); /** * Deletes historic case instance. All historic case activities, historic task and * historic details are deleted as well. */ void deleteHistoricCaseInstance(String caseInstanceId); /** * Deletes historic case instances and all related historic data in bulk manner. DELETE SQL statement will be created for each entity type. They will have list * of given case instance ids in IN clause. Therefore, DB limitation for number of values in IN clause must be taken into account. * * @param caseInstanceIds list of case instance ids for removal */ void deleteHistoricCaseInstancesBulk(List caseInstanceIds); /** * Deletes historic decision instances of a decision definition. All historic * decision inputs and outputs are deleted as well. * * @deprecated Note that this method name is not expressive enough, because it is also possible to delete the historic * decision instance by the instance id. Therefore use {@link #deleteHistoricDecisionInstanceByDefinitionId} instead * to delete the historic decision instance by the definition id. * * @param decisionDefinitionId * the id of the decision definition * * @throws AuthorizationException * If the user has no {@link Permissions#DELETE_HISTORY} permission on {@link Resources#DECISION_DEFINITION}. */ @Deprecated void deleteHistoricDecisionInstance(String decisionDefinitionId); /** * Deletes decision instances and all related historic data in bulk manner. DELETE SQL statement will be created for each entity type. They will have list * of given decision instance ids in IN clause. Therefore, DB limitation for number of values in IN clause must be taken into account. * * @param decisionInstanceIds list of decision instance ids for removal. * * @throws AuthorizationException * If the user has no {@link Permissions#DELETE_HISTORY} permission on {@link Resources#DECISION_DEFINITION}. */ void deleteHistoricDecisionInstancesBulk(List decisionInstanceIds); /** * Deletes historic decision instances of a decision definition. All historic * decision inputs and outputs are deleted as well. * * @param decisionDefinitionId * the id of the decision definition * * @throws AuthorizationException * If the user has no {@link Permissions#DELETE_HISTORY} permission on {@link Resources#DECISION_DEFINITION}. */ void deleteHistoricDecisionInstanceByDefinitionId(String decisionDefinitionId); /** * Deletes historic decision instances by its id. All historic * decision inputs and outputs are deleted as well. * * @param historicDecisionInstanceId * the id of the historic decision instance * @throws AuthorizationException * If the user has no {@link Permissions#DELETE_HISTORY} permission on {@link Resources#DECISION_DEFINITION}. */ void deleteHistoricDecisionInstanceByInstanceId(String historicDecisionInstanceId); /** * Deletes historic decision instances asynchronously based on a list of decision instances. * * @throws BadUserRequestException * when no decision instances are found with the given ids or ids are null. * @throws AuthorizationException * If the user has no {@link Permissions#CREATE} or * {@link BatchPermissions#CREATE_BATCH_DELETE_DECISION_INSTANCES} permission on {@link Resources#BATCH}. */ Batch deleteHistoricDecisionInstancesAsync(List decisionInstanceIds, String deleteReason); /** * Deletes historic decision instances asynchronously based on query of decision instances. * * @throws BadUserRequestException * when no decision instances are found with the given ids or ids are null. * @throws AuthorizationException * If the user has no {@link Permissions#CREATE} or * {@link BatchPermissions#CREATE_BATCH_DELETE_DECISION_INSTANCES} permission on {@link Resources#BATCH}. */ Batch deleteHistoricDecisionInstancesAsync(HistoricDecisionInstanceQuery query, String deleteReason); /** * Deletes historic decision instances asynchronously based on query and a list of decision instances, whereby query result and * list of ids will be merged. * * @throws BadUserRequestException * when no decision instances are found with the given ids or ids are null. * @throws AuthorizationException * If the user has no {@link Permissions#CREATE} or * {@link BatchPermissions#CREATE_BATCH_DELETE_DECISION_INSTANCES} permission on {@link Resources#BATCH}. */ Batch deleteHistoricDecisionInstancesAsync(List decisionInstanceIds, HistoricDecisionInstanceQuery query, String deleteReason); /** * Deletes a historic variable instance by its id. All related historic * details (variable updates, form properties) are deleted as well. * * @param variableInstanceId * the id of the variable instance * @throws BadUserRequestException * when the historic variable instance is not found by the given id * or if id is null * @throws AuthorizationException * If the variable instance has a process definition key and * the user has no {@link Permissions#DELETE_HISTORY} permission on * {@link Resources#PROCESS_DEFINITION}. */ void deleteHistoricVariableInstance(String variableInstanceId); /** * Deletes all historic variables and historic details (variable updates, form properties) of a process instance. * * @param processInstanceId * the id of the process instance * @throws AuthorizationException * If the user has no {@link Permissions#DELETE_HISTORY} permission on {@link Resources#PROCESS_DEFINITION}. */ void deleteHistoricVariableInstancesByProcessInstanceId(String processInstanceId); /** * creates a native query to search for {@link HistoricProcessInstance}s via SQL */ NativeHistoricProcessInstanceQuery createNativeHistoricProcessInstanceQuery(); /** * creates a native query to search for {@link HistoricTaskInstance}s via SQL */ NativeHistoricTaskInstanceQuery createNativeHistoricTaskInstanceQuery(); /** * creates a native query to search for {@link HistoricActivityInstance}s via SQL */ NativeHistoricActivityInstanceQuery createNativeHistoricActivityInstanceQuery(); /** * creates a native query to search for {@link HistoricCaseInstance}s via SQL */ NativeHistoricCaseInstanceQuery createNativeHistoricCaseInstanceQuery(); /** * creates a native query to search for {@link HistoricCaseActivityInstance}s via SQL */ NativeHistoricCaseActivityInstanceQuery createNativeHistoricCaseActivityInstanceQuery(); /** * creates a native query to search for {@link HistoricDecisionInstance}s via SQL */ NativeHistoricDecisionInstanceQuery createNativeHistoricDecisionInstanceQuery(); /** * creates a native query to search for {@link HistoricVariableInstance}s via SQL */ NativeHistoricVariableInstanceQuery createNativeHistoricVariableInstanceQuery(); /** *

                  Creates a new programmatic query to search for {@link HistoricJobLog historic job logs}. * *

                  The result of the query is empty in the following cases: *

                    *
                  • The user has no {@link Permissions#READ_HISTORY} permission on * {@link Resources#PROCESS_DEFINITION} OR *
                  • The user has no {@link HistoricProcessInstancePermissions#READ} permission on * {@link Resources#HISTORIC_PROCESS_INSTANCE} ({@code enableHistoricInstancePermissions} in * {@link ProcessEngineConfigurationImpl} must be set to {@code true}) * * @since 7.3 */ HistoricJobLogQuery createHistoricJobLogQuery(); /** * Returns the full stacktrace of the exception that occurs when the * historic job log with the given id was last executed. Returns null * when the historic job log has no exception stacktrace. * * @param historicJobLogId id of the historic job log, cannot be null. * @throws ProcessEngineException when no historic job log exists with the given id. * * @throws AuthorizationException * If the user has no {@link Permissions#READ_HISTORY} permission on {@link Resources#PROCESS_DEFINITION}. * * @since 7.3 */ String getHistoricJobLogExceptionStacktrace(String historicJobLogId); /** * Creates a new programmatic query to create a historic process instance report. * * @since 7.5 */ HistoricProcessInstanceReport createHistoricProcessInstanceReport(); /** *

                    Creates a new programmatic query to create a historic task instance report. * *

                    Subsequent builder methods throw {@link AuthorizationException} when the user has no * {@link Permissions#READ_HISTORY} permission on any {@link Resources#PROCESS_DEFINITION}. * * @since 7.6 */ HistoricTaskInstanceReport createHistoricTaskInstanceReport(); /** * Creates a new programmatic query to create a cleanable historic process instance report. * * @since 7.8 */ CleanableHistoricProcessInstanceReport createCleanableHistoricProcessInstanceReport(); /** * Creates a new programmatic query to create a cleanable historic decision instance report. * * @since 7.8 */ CleanableHistoricDecisionInstanceReport createCleanableHistoricDecisionInstanceReport(); /** * Creates a new programmatic query to create a cleanable historic case instance report. * * @since 7.8 */ CleanableHistoricCaseInstanceReport createCleanableHistoricCaseInstanceReport(); /** * Creates a new programmatic query to create a cleanable historic batch report. * * @since 7.8 */ CleanableHistoricBatchReport createCleanableHistoricBatchReport(); /** * Creates a query to search for {@link org.camunda.bpm.engine.batch.history.HistoricBatch} instances. * * @since 7.5 */ HistoricBatchQuery createHistoricBatchQuery(); /** * Deletes a historic batch instance. All corresponding historic job logs are deleted as well; * * @since 7.5 * * @throws AuthorizationException * If the user has no {@link Permissions#DELETE} permission on {@link Resources#BATCH} */ void deleteHistoricBatch(String id); /** * Query for the statistics of DRD evaluation. * * @param decisionRequirementsDefinitionId - id of decision requirement definition * @since 7.6 */ HistoricDecisionInstanceStatisticsQuery createHistoricDecisionInstanceStatisticsQuery(String decisionRequirementsDefinitionId); /** *

                    Creates a new programmatic query to search for * {@link HistoricExternalTaskLog historic external task logs}. * *

                    The result of the query is empty in the following cases: *

                      *
                    • The user has no {@link Permissions#READ_HISTORY} permission on * {@link Resources#PROCESS_DEFINITION} OR *
                    • The user has no {@link HistoricProcessInstancePermissions#READ} permission on * {@link Resources#HISTORIC_PROCESS_INSTANCE} ({@code enableHistoricInstancePermissions} in * {@link ProcessEngineConfigurationImpl} must be set to {@code true}) * * @since 7.7 */ HistoricExternalTaskLogQuery createHistoricExternalTaskLogQuery(); /** * Returns the full error details that occurs when the * historic external task log with the given id was last executed. Returns null * when the historic external task log contains no error details. * * @param historicExternalTaskLogId id of the historic external task log, cannot be null. * @throws ProcessEngineException when no historic external task log exists with the given id. * * @throws AuthorizationException * If the user has no {@link Permissions#READ_HISTORY} permission on {@link Resources#PROCESS_DEFINITION}. * * @since 7.7 */ String getHistoricExternalTaskLogErrorDetails(String historicExternalTaskLogId); /** *

                      Set a removal time to historic process instances and * all associated historic entities using a fluent builder. * *

                      Historic process instances can be specified by passing a query to * {@link SetRemovalTimeToHistoricProcessInstancesBuilder#byQuery(HistoricProcessInstanceQuery)}. * *

                      An absolute time can be specified via * {@link SetRemovalTimeSelectModeForHistoricProcessInstancesBuilder#absoluteRemovalTime(Date)}. * Pass {@code null} to clear the removal time. * *

                      As an alternative, the removal time can also be calculated via * {@link SetRemovalTimeSelectModeForHistoricProcessInstancesBuilder#calculatedRemovalTime()} * based on the configured time to live values. * *

                      To additionally take those historic process instances into account that are part of * a hierarchy, enable the flag * {@link SetRemovalTimeToHistoricProcessInstancesBuilder#hierarchical()} * *

                      To create the batch and complete the configuration chain, call * {@link SetRemovalTimeToHistoricProcessInstancesBuilder#executeAsync()}. * * @since 7.11 */ SetRemovalTimeSelectModeForHistoricProcessInstancesBuilder setRemovalTimeToHistoricProcessInstances(); /** *

                      Set a removal time to historic decision instances and * all associated historic entities using a fluent builder. * *

                      Historic decision instances can be specified by passing a query to * {@link SetRemovalTimeToHistoricDecisionInstancesBuilder#byQuery(HistoricDecisionInstanceQuery)}. * *

                      An absolute time can be specified via * {@link SetRemovalTimeSelectModeForHistoricDecisionInstancesBuilder#absoluteRemovalTime(Date)}. * Pass {@code null} to clear the removal time. * *

                      As an alternative, the removal time can also be calculated via * {@link SetRemovalTimeSelectModeForHistoricDecisionInstancesBuilder#calculatedRemovalTime()} * based on the configured time to live values. * *

                      To additionally take those historic decision instances into account that are part of * a hierarchy, enable the flag * {@link SetRemovalTimeToHistoricProcessInstancesBuilder#hierarchical()} * *

                      To create the batch and complete the configuration chain, call * {@link SetRemovalTimeToHistoricDecisionInstancesBuilder#executeAsync()}. * * @since 7.11 */ SetRemovalTimeSelectModeForHistoricDecisionInstancesBuilder setRemovalTimeToHistoricDecisionInstances(); /** *

                      Set a removal time to historic batches and all * associated historic entities using a fluent builder. * *

                      Historic batches can be specified by passing a query to * {@link SetRemovalTimeToHistoricBatchesBuilder#byQuery(HistoricBatchQuery)}. * *

                      An absolute time can be specified via * {@link SetRemovalTimeSelectModeForHistoricBatchesBuilder#absoluteRemovalTime(Date)}. * Pass {@code null} to clear the removal time. * *

                      As an alternative, the removal time can also be calculated via * {@link SetRemovalTimeSelectModeForHistoricBatchesBuilder#calculatedRemovalTime()} * based on the configured time to live values. * *

                      To create the batch and complete the configuration chain, call * {@link SetRemovalTimeToHistoricBatchesBuilder#executeAsync()}. * * @since 7.11 */ SetRemovalTimeSelectModeForHistoricBatchesBuilder setRemovalTimeToHistoricBatches(); /** *

                      Set an annotation to user operation log entries.

                      * * @throws NotValidException when operation id is {@code null} * @throws BadUserRequestException when no user operation could be found * @throws AuthorizationException *
                        *
                      • * when no {@link ProcessDefinitionPermissions#UPDATE_HISTORY} permission * is granted on {@link Resources#PROCESS_DEFINITION}
                      • *
                      • * or when no {@link UserOperationLogCategoryPermissions#UPDATE} permission * is granted on {@link Resources#OPERATION_LOG_CATEGORY} *
                      • *
                      * * @param operationId of the user operation log entries that are updated * @param annotation that is set to the user operation log entries * * @since 7.12 */ void setAnnotationForOperationLogById(String operationId, String annotation); /** *

                      Clear the annotation for user operation log entries.

                      * * @throws NotValidException when operation id is {@code null} * @throws BadUserRequestException when no user operation could be found * @throws AuthorizationException *
                        *
                      • * when no {@link ProcessDefinitionPermissions#UPDATE_HISTORY} permission * is granted on {@link Resources#PROCESS_DEFINITION}
                      • *
                      • * or when no {@link UserOperationLogCategoryPermissions#UPDATE} permission * is granted on {@link Resources#OPERATION_LOG_CATEGORY} *
                      • *
                      * * @param operationId of the user operation log entries that are updated * * @since 7.12 */ void clearAnnotationForOperationLogById(String operationId); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy