org.camunda.bpm.engine.impl.batch.message.MessageCorrelationBatchJobHandler 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.batch.message;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import org.camunda.bpm.engine.batch.Batch;
import org.camunda.bpm.engine.impl.MessageCorrelationBuilderImpl;
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.cmd.CorrelateAllMessageCmd;
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.MessageCorrelationBatchConfigurationJsonConverter;
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.runtime.MessageCorrelationBuilder;
import org.camunda.bpm.engine.variable.impl.VariableMapImpl;
/**
* Job handler for message correlation jobs. The jobs correlate a message to a
* list of process instances.
*/
public class MessageCorrelationBatchJobHandler extends AbstractBatchJobHandler {
public static final BatchJobDeclaration JOB_DECLARATION = new BatchJobDeclaration(Batch.TYPE_CORRELATE_MESSAGE);
public String getType() {
return Batch.TYPE_CORRELATE_MESSAGE;
}
public JobDeclaration getJobDeclaration() {
return JOB_DECLARATION;
}
protected MessageCorrelationBatchConfigurationJsonConverter getJsonConverterInstance() {
return MessageCorrelationBatchConfigurationJsonConverter.INSTANCE;
}
@Override
protected MessageCorrelationBatchConfiguration createJobConfiguration(MessageCorrelationBatchConfiguration configuration, List processIdsForJob) {
return new MessageCorrelationBatchConfiguration(
processIdsForJob,
configuration.getMessageName(),
configuration.getBatchId());
}
@Override
protected void postProcessJob(MessageCorrelationBatchConfiguration configuration, JobEntity job, MessageCorrelationBatchConfiguration jobConfiguration) {
// if there is only one process instance to adjust, set its ID to the job so exclusive scheduling is possible
if (jobConfiguration.getIds() != null && jobConfiguration.getIds().size() == 1) {
job.setProcessInstanceId(jobConfiguration.getIds().get(0));
}
}
@Override
public void executeHandler(MessageCorrelationBatchConfiguration batchConfiguration,
ExecutionEntity execution,
CommandContext commandContext,
String tenantId) {
String batchId = batchConfiguration.getBatchId();
MessageCorrelationBuilderImpl correlationBuilder = new MessageCorrelationBuilderImpl(commandContext, batchConfiguration.getMessageName());
correlationBuilder.executionsOnly();
setVariables(batchId, correlationBuilder, commandContext);
for (String id : batchConfiguration.getIds()) {
correlationBuilder.processInstanceId(id);
commandContext.executeWithOperationLogPrevented(new CorrelateAllMessageCmd(correlationBuilder, false, false));
}
}
protected void setVariables(String batchId,
MessageCorrelationBuilder correlationBuilder,
CommandContext commandContext) {
Map variables = null;
if (batchId != null) {
variables = VariableUtil.findBatchVariablesSerialized(batchId, commandContext);
if (variables != null) {
correlationBuilder.setVariables(new VariableMapImpl(new HashMap<>(variables)));
}
}
}
}