de.viadee.bpm.vPAV.processing.model.data.BpmnElement Maven / Gradle / Ivy
/**
* BSD 3-Clause License
*
* Copyright © 2018, viadee Unternehmensberatung GmbH
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* * Redistributions of source code must retain the above copyright notice, this
* list of conditions and the following disclaimer.
*
* * Redistributions in binary form must reproduce the above copyright notice,
* this list of conditions and the following disclaimer in the documentation
* and/or other materials provided with the distribution.
*
* * Neither the name of the copyright holder nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
package de.viadee.bpm.vPAV.processing.model.data;
import java.util.ArrayList;
import java.util.Collection;
import java.util.HashMap;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Set;
import org.camunda.bpm.model.bpmn.instance.BaseElement;
/**
* Represents an BPMN element
*
*/
public class BpmnElement {
private String processdefinition;
private BaseElement baseElement;
private Map used = new HashMap();
private Map defined = new HashMap();
private Map in = new HashMap();
private Map out = new HashMap();
/* in interface for call activity */
private Collection inCa;
/* out interface for call activity */
private Collection outCa;
private Map processVariables;
public BpmnElement(final String processdefinition, final BaseElement element) {
this.processdefinition = processdefinition;
this.baseElement = element;
this.processVariables = new HashMap();
}
public String getProcessdefinition() {
return processdefinition;
}
public BaseElement getBaseElement() {
return baseElement;
}
public Map getProcessVariables() {
return processVariables;
}
public void setProcessVariables(final Map variables) {
this.processVariables = variables;
}
public void setProcessVariable(final String variableName, final ProcessVariableOperation variableObject) {
processVariables.put(variableName, variableObject);
}
@Override
public int hashCode() {
return baseElement.getId().hashCode();
}
@Override
public boolean equals(Object o) {
if (o instanceof BpmnElement && this.hashCode() == o.hashCode()) {
return true;
}
return false;
}
@Override
public String toString() {
return baseElement.getId();
}
public Map getIn() {
return in;
}
public Map getOut() {
return out;
}
public void setIn(final Map outPredecessor) {
this.in = outPredecessor;
// TODO: call activity (create own method)
if (inCa != null) {
final Collection removeCandidates = new ArrayList();
for (final String variable : in.keySet()) {
if (!inCa.contains(variable)) {
removeCandidates.add(variable);
}
}
for (final String var : removeCandidates) {
in.remove(var);
}
}
}
public void setOut() {
out.putAll(defined());
changeStatusToRead(in);
out.putAll(killed());
// TODO: call activity (create own method)
if (outCa != null) {
final Collection removeCandidates = new ArrayList();
for (final String variable : out.keySet()) {
if (!outCa.contains(variable)) {
removeCandidates.add(variable);
} else {
final InOutState state = out.get(variable);
if (state == InOutState.DELETED) {
removeCandidates.add(variable);
}
}
}
for (final String var : removeCandidates) {
out.remove(var);
}
}
}
private Map used() {
if (this.used.isEmpty()) {
for (final ProcessVariableOperation var : processVariables.values()) {
if (var.getOperation() == VariableOperation.READ) {
used.put(var.getName(), InOutState.READ);
}
}
}
return used;
}
public Map defined() {
if (this.defined.isEmpty()) {
for (final ProcessVariableOperation var : processVariables.values()) {
if (var.getOperation() == VariableOperation.WRITE) {
defined.put(var.getName(), InOutState.DEFINED);
}
}
}
return defined;
}
private Map killed() {
final Map killedVariables = new HashMap();
for (final ProcessVariableOperation var : processVariables.values()) {
if (var.getOperation() == VariableOperation.DELETE) {
killedVariables.put(var.getName(), InOutState.DELETED);
}
}
return killedVariables;
}
public void setInCa(final Collection in) {
this.inCa = in;
}
public void setOutCa(final Collection out) {
this.outCa = out;
}
public boolean ur(final String varName) {
if ((in.containsKey(varName) == false
|| (in.containsKey(varName) == true && in.get(varName) == InOutState.DELETED))
&& used().containsKey(varName)) {
return true;
}
return false;
}
public boolean du(final String varName) {
if (in.containsKey(varName) && in.get(varName) == InOutState.DEFINED && out.containsKey(varName)
&& out.get(varName) == InOutState.DELETED) {
return true;
}
return false;
}
public boolean dd(final String varName) {
if (in.containsKey(varName) && in.get(varName) == InOutState.DEFINED
&& defined().containsKey(varName)) {
return true;
}
return false;
}
public Map> getAnomalies() {
final Map> anomalyMap = new HashMap>();
final Set variableNames = new HashSet();
variableNames.addAll(used().keySet());
for (final String variableName : in.keySet()) {
if (in.get(variableName) == InOutState.DEFINED) {
variableNames.add(variableName);
}
}
final List anomalies = new ArrayList();
for (final String variableName : variableNames) {
if (ur(variableName)) {
anomalies.add(new AnomalyContainer(variableName, Anomaly.UR, baseElement.getId(),
processVariables.get(variableName)));
}
if (du(variableName)) {
anomalies.add(new AnomalyContainer(variableName, Anomaly.DU, baseElement.getId(),
processVariables.get(variableName)));
}
if (dd(variableName)) {
anomalies.add(new AnomalyContainer(variableName, Anomaly.DD, baseElement.getId(),
processVariables.get(variableName)));
}
}
anomalyMap.put(this, anomalies);
return anomalyMap;
}
private void changeStatusToRead(final Map inVariables) {
for (final String varName : inVariables.keySet()) {
if (used().containsKey(varName)) {
out.put(varName, InOutState.READ);
} else {
out.put(varName, inVariables.get(varName));
}
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy