org.camunda.bpm.engine.impl.cfg.CommandChecker 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.impl.cfg;
import org.camunda.bpm.engine.ProcessEngineException;
import org.camunda.bpm.engine.authorization.Permission;
import org.camunda.bpm.engine.history.HistoricCaseInstance;
import org.camunda.bpm.engine.history.HistoricDecisionInstance;
import org.camunda.bpm.engine.history.HistoricProcessInstance;
import org.camunda.bpm.engine.history.UserOperationLogEntry;
import org.camunda.bpm.engine.impl.batch.BatchEntity;
import org.camunda.bpm.engine.impl.batch.history.HistoricBatchEntity;
import org.camunda.bpm.engine.impl.dmn.entity.repository.DecisionDefinitionEntity;
import org.camunda.bpm.engine.impl.dmn.entity.repository.DecisionRequirementsDefinitionEntity;
import org.camunda.bpm.engine.impl.history.event.HistoricExternalTaskLogEntity;
import org.camunda.bpm.engine.impl.persistence.entity.ExecutionEntity;
import org.camunda.bpm.engine.impl.persistence.entity.HistoricJobLogEventEntity;
import org.camunda.bpm.engine.impl.persistence.entity.HistoricProcessInstanceEntity;
import org.camunda.bpm.engine.impl.persistence.entity.HistoricTaskInstanceEntity;
import org.camunda.bpm.engine.impl.persistence.entity.HistoricVariableInstanceEntity;
import org.camunda.bpm.engine.impl.persistence.entity.JobEntity;
import org.camunda.bpm.engine.impl.persistence.entity.TaskEntity;
import org.camunda.bpm.engine.repository.CaseDefinition;
import org.camunda.bpm.engine.repository.DecisionDefinition;
import org.camunda.bpm.engine.repository.ProcessDefinition;
import org.camunda.bpm.engine.runtime.CaseExecution;
/**
* Is invoked while executing a command to check if the current operation is
* allowed on the entity. If it is not allowed, the checker throws a
* {@link ProcessEngineException}.
*/
public interface CommandChecker {
/**
* Checks if it is allowed to evaluate the given decision.
*/
void checkEvaluateDecision(DecisionDefinition decisionDefinition);
/**
* Checks if it is allowed to create an instance of the given process definition.
*/
void checkCreateProcessInstance(ProcessDefinition processDefinition);
/**
* Checks if it is allowed to read the given process definition.
*/
void checkReadProcessDefinition(ProcessDefinition processDefinition);
/**
* Checks if it is allowed to create an instance of the given case definition.
*/
void checkCreateCaseInstance(CaseDefinition caseDefinition);
/**
* Checks if it is allowed to update a process definition of the given process definition id.
*/
void checkUpdateProcessDefinitionById(String processDefinitionId);
/**
* Checks if it is allowed to update the suspension state of a process definition.
*/
void checkUpdateProcessDefinitionSuspensionStateById(String processDefinitionId);
/**
* Checks if it is allowed to update a process instance of the given process definition id.
*/
void checkUpdateProcessInstanceByProcessDefinitionId(String processDefinitionId);
/**
* Checks if it is allowed to update a process instance's retries of the given process definition.
*/
void checkUpdateRetriesProcessInstanceByProcessDefinitionId(String processDefinitionId);
/**
* Checks if it is allowed to update a process instance's suspension state of the given process definition.
*/
void checkUpdateProcessInstanceSuspensionStateByProcessDefinitionId(String processDefinitionId);
/**
* Checks if it is allowed to update a decision definition with given id.
*/
void checkUpdateDecisionDefinitionById(String decisionDefinitionId);
/**
* Checks if it is allowed to update a process definition of the given process definition key.
*/
void checkUpdateProcessDefinitionByKey(String processDefinitionKey);
/**
* Checks if it is allowed to update the suspension state of a process definition.
*/
void checkUpdateProcessDefinitionSuspensionStateByKey(String processDefinitionKey);
/**
* Checks if it is allowed to delete a process definition, which corresponds to the given id.
*
* @param processDefinitionId the id which corresponds to the process definition
*/
void checkDeleteProcessDefinitionById(String processDefinitionId);
/**
* Checks if it is allowed to delete a process definition, which corresponds to the given key.
*
* @param processDefinitionKey the key which corresponds to the process definition
*/
void checkDeleteProcessDefinitionByKey(String processDefinitionKey);
/**
* Checks if it is allowed to update a process instance of the given process definition key.
*/
void checkUpdateProcessInstanceByProcessDefinitionKey(String processDefinitionKey);
/**
* Checks if it is allowed to update a process instance's suspension state of the given process definition.
*/
void checkUpdateProcessInstanceSuspensionStateByProcessDefinitionKey(String processDefinitionKey);
/**
* Checks if it is allowed to update a process instance of the given process instance id.
*/
void checkUpdateProcessInstanceById(String processInstanceId);
/**
* Checks if it is allowed to update a process instance's suspension state.
*/
void checkUpdateProcessInstanceSuspensionStateById(String processInstanceId);
/**
* Checks if it is allowed to update a process instance of the given execution.
*/
void checkUpdateProcessInstance(ExecutionEntity execution);
/**
* Checks if it is allowed to update a process instance's variables of the given execution.
*/
void checkUpdateProcessInstanceVariables(ExecutionEntity execution);
void checkCreateMigrationPlan(ProcessDefinition sourceProcessDefinition, ProcessDefinition targetProcessDefinition);
void checkMigrateProcessInstance(ExecutionEntity processInstance, ProcessDefinition targetProcessDefinition);
void checkReadProcessInstance(String processInstanceId);
/**
* Checks if it is allowed to read the given job.
*/
void checkReadJob(JobEntity job);
/**
* Checks if it is allowed to update the given job.
*/
void checkUpdateJob(JobEntity job);
/**
* Checks if it is allowed to update a job retries.
*/
void checkUpdateRetriesJob(JobEntity job);
/**
* Checks if it is allowed to read a process instance of the given execution.
*/
void checkReadProcessInstance(ExecutionEntity execution);
/**
* Checks if it is allowed to read a process instance's variables of the given execution.
*/
void checkReadProcessInstanceVariable(ExecutionEntity execution);
/**
* Check if it is allowed to delete a process instance of the given execution.
*/
void checkDeleteProcessInstance(ExecutionEntity execution);
/**
* Check if it is allowed to read a task.
*/
void checkReadTask(TaskEntity task);
/**
* Check if it is allowed to read a task's variable.
*/
void checkReadTaskVariable(TaskEntity task);
/**
* Check if it is allowed to update a task's variable
*/
void checkUpdateTaskVariable(TaskEntity task);
/**
* Check if it is allowed to create a batch
*/
void checkCreateBatch(Permission permission);
/**
* Check if it is allowed to delete a batch
*/
void checkDeleteBatch(BatchEntity batch);
/**
* Check if it is allowed to delete a historic batch
*/
void checkDeleteHistoricBatch(HistoricBatchEntity batch);
/**
* Check if it is allowed to suspend a batch
*/
void checkSuspendBatch(BatchEntity batch);
/**
* Check if it is allowed to activate a batch
*/
void checkActivateBatch(BatchEntity batch);
/**
* Check if it is allowed to read historic batch
*/
void checkReadHistoricBatch();
/**
* Checks if it is allowed to create a deployment.
*/
void checkCreateDeployment();
/**
* Checks if it is allowed to read a deployment of the given deployment id.
*/
void checkReadDeployment(String deploymentId);
/**
* Checks if it is allowed to delete a deployment of the given deployment id.
*/
void checkDeleteDeployment(String deploymentId);
/**
* Check if it is allowed to assign a task
*/
void checkTaskAssign(TaskEntity task);
/**
* Check if it is allowed to create a task
*/
void checkCreateTask(TaskEntity task);
/**
* Check if it is allowed to create a task
*/
void checkCreateTask();
/**
* Check if it is allowed to work on a task
*/
void checkTaskWork(TaskEntity task);
/**
* Check if it is allowed to delete a task
*/
void checkDeleteTask(TaskEntity task);
/**
* Checks if it is allowed to read the given decision definition.
*/
void checkReadDecisionDefinition(DecisionDefinitionEntity decisionDefinition);
/**
* Checks if it is allowed to read the given decision requirements definition.
*/
void checkReadDecisionRequirementsDefinition(DecisionRequirementsDefinitionEntity decisionRequirementsDefinition);
/**
* Checks if it is allowed to read the given case definition.
*/
void checkReadCaseDefinition(CaseDefinition caseDefinition);
/**
* Checks if it is allowed to update the given case definition.
*/
void checkUpdateCaseDefinition(CaseDefinition caseDefinition);
/**
* Checks if it is allowed to delete the given historic task instance.
*/
void checkDeleteHistoricTaskInstance(HistoricTaskInstanceEntity task);
/**
* Checks if it is allowed to delete the given historic process instance.
*/
void checkDeleteHistoricProcessInstance(HistoricProcessInstance instance);
/**
* Checks if it is allowed to delete the given historic case instance.
*/
void checkDeleteHistoricCaseInstance(HistoricCaseInstance instance);
/**
* Checks if it is allowed to delete the historic decision instance of the given
* decision definition key.
*/
void checkDeleteHistoricDecisionInstance(String decisionDefinitionKey);
/**
* Checks if it is allowed to delete the given historic decision instance.
*/
void checkDeleteHistoricDecisionInstance(HistoricDecisionInstance instance);
/**
* Checks if it is allowed to read the given historic job log.
*/
void checkReadHistoricJobLog(HistoricJobLogEventEntity historicJobLog);
/**
* Check if it is allowed to read the history for any process definition.
*/
void checkReadHistoryAnyProcessDefinition();
/**
* Check if it is allowed to read the history of the given process definition.
*/
void checkReadHistoryProcessDefinition(String processDefinitionId);
/**
* Check if it is allowed to update a case instance of the given case execution.
*/
void checkUpdateCaseInstance(CaseExecution caseExecution);
/**
* Check if it is allowed to delete the user operation log of the given user operation log entry.
*/
void checkDeleteUserOperationLog(UserOperationLogEntry entry);
/**
* Check if it is allowed to update the user operation log of the given user operation log entry.
*/
void checkUpdateUserOperationLog(UserOperationLogEntry entry);
/**
* Check if it is allowed to read a case instance of the given case execution.
*/
void checkReadCaseInstance(CaseExecution caseExecution);
/**
* Checks if it is allowed to read the given historic external task log.
*/
void checkReadHistoricExternalTaskLog(HistoricExternalTaskLogEntity historicExternalTaskLog);
/**
* Checks if it is allowed to delete the given historic variable instance.
*/
void checkDeleteHistoricVariableInstance(HistoricVariableInstanceEntity variable);
/**
* Checks if it is allowed to delete the historic variable instances of the given process instance.
*/
void checkDeleteHistoricVariableInstancesByProcessInstance(HistoricProcessInstanceEntity instance);
/**
* Checks if it is allowed to read collected telemetry data.
*/
void checkReadTelemetryData();
/**
* Checks if it is allowed to toggle telemetry collection.
*/
void checkConfigureTelemetry();
/**
* Checks if it is allowed to read the status (ON/OFF) of the telemetry collection.
*/
void checkReadTelemetryCollectionStatusData();
/*
* Checks if it is allowed to read the history level.
*/
void checkReadHistoryLevel();
/*
* Checks if it is allowed to read the database table count.
*/
void checkReadTableCount();
/*
* Checks if it is allowed to read the database table name for an entity class.
*/
void checkReadTableName();
/*
* Checks if it is allowed to read the table meta data for a table with a given name.
*/
void checkReadTableMetaData();
/*
* Checks if it is allowed to read system properties.
*/
void checkReadProperties();
/*
* Checks if it is allowed to set a system property.
*/
void checkSetProperty();
/*
* Checks if it is allowed to delete a system property
*/
void checkDeleteProperty();
/*
* Checks if it is allowed to delete the license key.
*/
void checkDeleteLicenseKey();
/*
* Checks if it is allowed to set the license key.
*/
void checkSetLicenseKey();
/*
* Checks if it is allowed to read the license key.
*/
void checkReadLicenseKey();
/*
* Checks if it is allowed to register a process application.
*/
void checkRegisterProcessApplication();
/*
* Checks if it is allowed to unregister a process application.
*/
void checkUnregisterProcessApplication();
/*
* Checks if it is allowed to read the registered deployments.
*/
void checkReadRegisteredDeployments();
/*
* Checks if it is allowed to read the process application for a deployment.
*/
void checkReadProcessApplicationForDeployment();
/*
* Checks if it is allowed to register a deployment.
*/
void checkRegisterDeployment();
/*
* Checks if it is allowed to unregister a deployment.
*/
void checkUnregisterDeployment();
/*
* Checks if it is allowed to delete metrics.
*/
void checkDeleteMetrics();
/*
* Checks if it is allowed to delete task metrics.
*/
void checkDeleteTaskMetrics();
/*
* Checks if it is allowed to read schema log data.
*/
void checkReadSchemaLog();
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy