package org.activiti.crystalball.simulator.delegate.event.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.io.IOException;
import java.util.HashMap;
import java.util.Map;
import org.activiti.crystalball.simulator.CrystalballException;
import org.activiti.crystalball.simulator.SimulationEvent;
import org.activiti.engine.delegate.event.ActivitiEventType;
import org.activiti.engine.event.EventLogEntry;
import org.activiti.engine.impl.event.logger.handler.Fields;
import com.fasterxml.jackson.core.type.TypeReference;
import com.fasterxml.jackson.databind.ObjectMapper;
/**
* @author martin.grofcik
*/
public class EventLogUserTaskCompleteTransformer extends EventLog2SimulationEventFunction {
public static final String PROCESS_INSTANCE_ID = "processInstanceId";
public static final String TASK_DEFINITION_KEY = "taskDefinitionKey";
public static final String TASK_VARIABLES = "taskVariables";
public static final String VARIABLES_LOCAL_SCOPE = "variablesLocalScope";
public EventLogUserTaskCompleteTransformer(String simulationEventType) {
super(simulationEventType);
}
@SuppressWarnings("unchecked")
@Override
public SimulationEvent apply(EventLogEntry event) {
if (ActivitiEventType.TASK_COMPLETED.toString().equals(event.getType())) {
ObjectMapper objectMapper = new ObjectMapper();
Map<String, Object> data;
try {
data = objectMapper.readValue(event.getData(), new TypeReference<HashMap<String, Object>>() {});
} catch (IOException e) {
throw new CrystalballException("unable to parse JSON string.", e);
}
String taskIdValue = (String) data.get(Fields.ACTIVITY_ID);
boolean localScope = false;
Map<String, Object> variableMap = null;
if (data.get(Fields.VARIABLES) != null) {
variableMap = (Map<String, Object>) data.get(Fields.VARIABLES);
} else {
variableMap = (Map<String, Object>) data.get(Fields.LOCAL_VARIABLES);
localScope = true;
}
String taskDefinitionKeyValue = (String) data.get(Fields.TASK_DEFINITION_KEY);
Map<String, Object> properties = new HashMap<String, Object>();
properties.put("taskId", taskIdValue);
properties.put(TASK_DEFINITION_KEY, taskDefinitionKeyValue);
properties.put(PROCESS_INSTANCE_ID, event.getProcessInstanceId());
if (variableMap != null) {
properties.put(TASK_VARIABLES, variableMap);
properties.put(VARIABLES_LOCAL_SCOPE, localScope);
}
return new SimulationEvent.Builder(this.simulationEventType)
.priority((int) event.getLogNumber())
.properties(properties)
.build();
}
return null;
}
}