package org.activiti.crystalball.simulator.impl; /* Licensed under the Apache License, Version 2.0 (the "License"); * 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. */ import java.util.HashMap; import java.util.Map; import org.activiti.crystalball.simulator.SimulationEvent; import org.activiti.crystalball.simulator.SimulationEventHandler; import org.activiti.crystalball.simulator.SimulationRunContext; import org.slf4j.Logger; import org.slf4j.LoggerFactory; /** * This class schedules replay start simulation event and takes care about process start and * next event schedule * * @author martin.grofcik */ public class StartReplayLogEventHandler implements SimulationEventHandler { private static Logger log = LoggerFactory.getLogger(StartReplayLogEventHandler.class.getName()); /** variable name where original process instance ID is stored - only for internal replay purposes */ public static final String PROCESS_INSTANCE_ID = "_replay.processInstanceId"; public static final String SIMULATION_RUN_ID = "_replay.simulationRunId"; private final String processInstanceId; private final String processToStartIdKey; private final String businessKey; private final String variablesKey; public StartReplayLogEventHandler(String processInstanceId, String processToStartIdKey, String businessKey, String variablesKey) { this.processInstanceId = processInstanceId; this.processToStartIdKey = processToStartIdKey; this.businessKey = businessKey; this.variablesKey = variablesKey; } @Override public void init() { } @SuppressWarnings("unchecked") @Override public void handle(SimulationEvent event) { // start process now String processDefinitionId = (String) event.getProperty(processToStartIdKey); String eventBusinessKey = (String) event.getProperty(this.businessKey); Map<String, Object> variables = new HashMap<String, Object>(); Map<String, Object> processVariables = (Map<String, Object>) event.getProperty(variablesKey); if (processVariables != null) { variables.putAll(processVariables); } variables.put(PROCESS_INSTANCE_ID, processInstanceId); variables.put(SIMULATION_RUN_ID, SimulationRunContext.getSimulationRunId()); String startBusinessKey = null; if (eventBusinessKey != null) { startBusinessKey = eventBusinessKey; } else { startBusinessKey = this.businessKey; } log.debug("Starting new processDefId[{}] businessKey[{}] with variables[{}]", processDefinitionId, startBusinessKey, variables); SimulationRunContext.getRuntimeService().startProcessInstanceById(processDefinitionId, startBusinessKey, variables); } }