All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.activiti.crystalball.simulator.impl.StartReplayLogEventHandler Maven / Gradle / Ivy

The newest version!
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 variables = new HashMap();
    Map processVariables = (Map) 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);
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy