org.camunda.bpm.engine.impl.optimize.OptimizeManager 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.optimize;
import org.camunda.bpm.engine.history.HistoricActivityInstance;
import org.camunda.bpm.engine.history.HistoricDecisionInstance;
import org.camunda.bpm.engine.history.HistoricProcessInstance;
import org.camunda.bpm.engine.history.HistoricTaskInstance;
import org.camunda.bpm.engine.history.HistoricVariableUpdate;
import org.camunda.bpm.engine.history.UserOperationLogEntry;
import org.camunda.bpm.engine.impl.HistoricDecisionInstanceQueryImpl;
import org.camunda.bpm.engine.impl.db.CompositePermissionCheck;
import org.camunda.bpm.engine.impl.db.PermissionCheckBuilder;
import org.camunda.bpm.engine.impl.db.sql.DbSqlSessionFactory;
import org.camunda.bpm.engine.impl.persistence.AbstractManager;
import org.camunda.bpm.engine.impl.persistence.entity.optimize.OptimizeHistoricIdentityLinkLogEntity;
import org.camunda.bpm.engine.impl.util.CollectionUtil;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import static org.camunda.bpm.engine.authorization.Authorization.ANY;
import static org.camunda.bpm.engine.authorization.Permissions.READ;
import static org.camunda.bpm.engine.authorization.Permissions.READ_HISTORY;
import static org.camunda.bpm.engine.authorization.Resources.DECISION_DEFINITION;
import static org.camunda.bpm.engine.authorization.Resources.PROCESS_DEFINITION;
import static org.camunda.bpm.engine.authorization.Resources.TENANT;
public class OptimizeManager extends AbstractManager {
/**
* Loads the byte arrays into the cache; does currently not return a list
* because it is not needed by the calling code and we can avoid concatenating
* lists in the implementation that way.
*/
public void fetchHistoricVariableUpdateByteArrays(List byteArrayIds) {
List> partitions = CollectionUtil.partition(byteArrayIds, DbSqlSessionFactory.MAXIMUM_NUMBER_PARAMS);
for (List partition : partitions) {
getDbEntityManager().selectList("selectByteArrays", partition);
}
}
@SuppressWarnings("unchecked")
public List getCompletedHistoricActivityInstances(Date finishedAfter,
Date finishedAt,
int maxResults) {
checkIsAuthorizedToReadHistoryAndTenants();
Map params = new HashMap<>();
params.put("finishedAfter", finishedAfter);
params.put("finishedAt", finishedAt);
params.put("maxResults", maxResults);
return getDbEntityManager().selectList("selectCompletedHistoricActivityPage", params);
}
@SuppressWarnings("unchecked")
public List getRunningHistoricActivityInstances(Date startedAfter,
Date startedAt,
int maxResults) {
checkIsAuthorizedToReadHistoryAndTenants();
Map params = new HashMap<>();
params.put("startedAfter", startedAfter);
params.put("startedAt", startedAt);
params.put("maxResults", maxResults);
return getDbEntityManager().selectList("selectRunningHistoricActivityPage", params);
}
@SuppressWarnings("unchecked")
public List getCompletedHistoricTaskInstances(Date finishedAfter,
Date finishedAt,
int maxResults) {
checkIsAuthorizedToReadHistoryAndTenants();
Map params = new HashMap<>();
params.put("finishedAfter", finishedAfter);
params.put("finishedAt", finishedAt);
params.put("maxResults", maxResults);
return getDbEntityManager().selectList("selectCompletedHistoricTaskInstancePage", params);
}
@SuppressWarnings("unchecked")
public List getRunningHistoricTaskInstances(Date startedAfter,
Date startedAt,
int maxResults) {
checkIsAuthorizedToReadHistoryAndTenants();
Map params = new HashMap<>();
params.put("startedAfter", startedAfter);
params.put("startedAt", startedAt);
params.put("maxResults", maxResults);
return getDbEntityManager().selectList("selectRunningHistoricTaskInstancePage", params);
}
@SuppressWarnings("unchecked")
public List getHistoricUserOperationLogs(Date occurredAfter,
Date occurredAt,
int maxResults) {
checkIsAuthorizedToReadHistoryAndTenants();
String[] operationTypes = new String[]{
UserOperationLogEntry.OPERATION_TYPE_SUSPEND_JOB,
UserOperationLogEntry.OPERATION_TYPE_ACTIVATE_JOB,
UserOperationLogEntry.OPERATION_TYPE_SUSPEND_PROCESS_DEFINITION,
UserOperationLogEntry.OPERATION_TYPE_ACTIVATE_PROCESS_DEFINITION,
UserOperationLogEntry.OPERATION_TYPE_SUSPEND,
UserOperationLogEntry.OPERATION_TYPE_ACTIVATE};
Map params = new HashMap<>();
params.put("occurredAfter", occurredAfter);
params.put("occurredAt", occurredAt);
params.put("operationTypes", operationTypes);
params.put("maxResults", maxResults);
return getDbEntityManager().selectList("selectHistoricUserOperationLogPage", params);
}
@SuppressWarnings("unchecked")
public List getHistoricIdentityLinkLogs(Date occurredAfter,
Date occurredAt,
int maxResults) {
checkIsAuthorizedToReadHistoryAndTenants();
Map params = new HashMap<>();
params.put("occurredAfter", occurredAfter);
params.put("occurredAt", occurredAt);
params.put("maxResults", maxResults);
return getDbEntityManager().selectList("selectHistoricIdentityLinkPage", params);
}
@SuppressWarnings("unchecked")
public List getCompletedHistoricProcessInstances(Date finishedAfter,
Date finishedAt,
int maxResults) {
checkIsAuthorizedToReadHistoryAndTenants();
Map params = new HashMap<>();
params.put("finishedAfter", finishedAfter);
params.put("finishedAt", finishedAt);
params.put("maxResults", maxResults);
return getDbEntityManager().selectList("selectCompletedHistoricProcessInstancePage", params);
}
@SuppressWarnings("unchecked")
public List getRunningHistoricProcessInstances(Date startedAfter,
Date startedAt,
int maxResults) {
checkIsAuthorizedToReadHistoryAndTenants();
Map params = new HashMap<>();
params.put("startedAfter", startedAfter);
params.put("startedAt", startedAt);
params.put("maxResults", maxResults);
return getDbEntityManager().selectList("selectRunningHistoricProcessInstancePage", params);
}
@SuppressWarnings("unchecked")
public List getHistoricVariableUpdates(Date occurredAfter,
Date occurredAt,
int maxResults) {
checkIsAuthorizedToReadHistoryAndTenants();
Map params = new HashMap<>();
params.put("occurredAfter", occurredAfter);
params.put("occurredAt", occurredAt);
params.put("maxResults", maxResults);
return getDbEntityManager().selectList("selectHistoricVariableUpdatePage", params);
}
@SuppressWarnings("unchecked")
public List getHistoricDecisionInstances(Date evaluatedAfter,
Date evaluatedAt,
int maxResults) {
checkIsAuthorizedToReadHistoryAndTenants();
Map params = new HashMap<>();
params.put("evaluatedAfter", evaluatedAfter);
params.put("evaluatedAt", evaluatedAt);
params.put("maxResults", maxResults);
List decisionInstances =
getDbEntityManager().selectList("selectHistoricDecisionInstancePage", params);
HistoricDecisionInstanceQueryImpl query =
(HistoricDecisionInstanceQueryImpl) new HistoricDecisionInstanceQueryImpl()
.disableBinaryFetching()
.disableCustomObjectDeserialization()
.includeInputs()
.includeOutputs();
List> partitions = CollectionUtil.partition(decisionInstances, DbSqlSessionFactory.MAXIMUM_NUMBER_PARAMS);
for (List partition : partitions) {
getHistoricDecisionInstanceManager()
.enrichHistoricDecisionsWithInputsAndOutputs(query, partition);
}
return decisionInstances;
}
private void checkIsAuthorizedToReadHistoryAndTenants() {
CompositePermissionCheck necessaryPermissionsForOptimize = new PermissionCheckBuilder()
.conjunctive()
.atomicCheckForResourceId(PROCESS_DEFINITION, ANY, READ_HISTORY)
.atomicCheckForResourceId(DECISION_DEFINITION, ANY, READ_HISTORY)
.atomicCheckForResourceId(TENANT, ANY, READ)
.build();
getAuthorizationManager().checkAuthorization(necessaryPermissionsForOptimize);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy