org.camunda.bpm.engine.impl.migration.batch.MigrationBatchJobHandler 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.migration.batch;
import org.camunda.bpm.engine.batch.Batch;
import org.camunda.bpm.engine.impl.batch.AbstractBatchJobHandler;
import org.camunda.bpm.engine.impl.batch.BatchJobContext;
import org.camunda.bpm.engine.impl.batch.BatchJobDeclaration;
import org.camunda.bpm.engine.impl.context.Context;
import org.camunda.bpm.engine.impl.core.variable.VariableUtil;
import org.camunda.bpm.engine.impl.interceptor.CommandContext;
import org.camunda.bpm.engine.impl.jobexecutor.JobDeclaration;
import org.camunda.bpm.engine.impl.json.MigrationBatchConfigurationJsonConverter;
import org.camunda.bpm.engine.impl.migration.MigrateProcessInstanceCmd;
import org.camunda.bpm.engine.impl.migration.MigrationPlanExecutionBuilderImpl;
import org.camunda.bpm.engine.impl.migration.MigrationPlanImpl;
import org.camunda.bpm.engine.impl.persistence.entity.ExecutionEntity;
import org.camunda.bpm.engine.impl.persistence.entity.JobEntity;
import org.camunda.bpm.engine.impl.persistence.entity.MessageEntity;
import org.camunda.bpm.engine.impl.persistence.entity.ProcessDefinitionEntity;
import org.camunda.bpm.engine.migration.MigrationPlanExecutionBuilder;
import org.camunda.bpm.engine.variable.impl.VariableMapImpl;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
/**
* Job handler for batch migration jobs. The batch migration job
* migrates a list of process instances.
*/
public class MigrationBatchJobHandler extends AbstractBatchJobHandler {
public static final BatchJobDeclaration JOB_DECLARATION = new BatchJobDeclaration(Batch.TYPE_PROCESS_INSTANCE_MIGRATION);
public String getType() {
return Batch.TYPE_PROCESS_INSTANCE_MIGRATION;
}
public JobDeclaration getJobDeclaration() {
return JOB_DECLARATION;
}
protected MigrationBatchConfigurationJsonConverter getJsonConverterInstance() {
return MigrationBatchConfigurationJsonConverter.INSTANCE;
}
@Override
protected MigrationBatchConfiguration createJobConfiguration(MigrationBatchConfiguration configuration, List processIdsForJob) {
return new MigrationBatchConfiguration(
processIdsForJob,
configuration.getMigrationPlan(),
configuration.isSkipCustomListeners(),
configuration.isSkipIoMappings(),
configuration.getBatchId()
);
}
@Override
protected void postProcessJob(MigrationBatchConfiguration configuration, JobEntity job, MigrationBatchConfiguration jobConfiguration) {
if (job.getDeploymentId() == null) {
CommandContext commandContext = Context.getCommandContext();
String sourceProcessDefinitionId = configuration.getMigrationPlan().getSourceProcessDefinitionId();
ProcessDefinitionEntity processDefinition = getProcessDefinition(commandContext, sourceProcessDefinitionId);
job.setDeploymentId(processDefinition.getDeploymentId());
}
}
@Override
public void executeHandler(MigrationBatchConfiguration batchConfiguration,
ExecutionEntity execution,
CommandContext commandContext,
String tenantId) {
MigrationPlanImpl migrationPlan = (MigrationPlanImpl) batchConfiguration.getMigrationPlan();
String batchId = batchConfiguration.getBatchId();
setVariables(batchId, migrationPlan, commandContext);
MigrationPlanExecutionBuilder executionBuilder = commandContext.getProcessEngineConfiguration()
.getRuntimeService()
.newMigration(migrationPlan)
.processInstanceIds(batchConfiguration.getIds());
if (batchConfiguration.isSkipCustomListeners()) {
executionBuilder.skipCustomListeners();
}
if (batchConfiguration.isSkipIoMappings()) {
executionBuilder.skipIoMappings();
}
commandContext.executeWithOperationLogPrevented(
new MigrateProcessInstanceCmd((MigrationPlanExecutionBuilderImpl)executionBuilder, true));
}
protected void setVariables(String batchId,
MigrationPlanImpl migrationPlan,
CommandContext commandContext) {
Map variables = null;
if (batchId != null) {
variables = VariableUtil.findBatchVariablesSerialized(batchId, commandContext);
if (variables != null) {
migrationPlan.setVariables(new VariableMapImpl(new HashMap<>(variables)));
}
}
}
protected ProcessDefinitionEntity getProcessDefinition(CommandContext commandContext, String processDefinitionId) {
return commandContext.getProcessEngineConfiguration()
.getDeploymentCache()
.findDeployedProcessDefinitionById(processDefinitionId);
}
}