Skip to content

Commit

Permalink
https://github.com/TheOpenCloudEngine/uengine-bpm/issues/15
Browse files Browse the repository at this point in the history
  • Loading branch information
jinyoung committed Mar 29, 2017
1 parent 4d0c935 commit 7474b97
Show file tree
Hide file tree
Showing 10 changed files with 534 additions and 171 deletions.
15 changes: 14 additions & 1 deletion pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@
<module>bpmn-model</module>
<module>uengine-client-example</module>
<module>uengine-social-bpm-portal</module>
<module>uengine-persistence-couchbase</module>
</modules>


Expand Down Expand Up @@ -50,6 +51,18 @@
<enabled>true</enabled>
</snapshots>
</repository>
<repository>
<id>central</id>
<url>http://repo1.maven.org/maven2/</url>
<releases>
<enabled>true</enabled>
</releases>
<snapshots>
<enabled>true</enabled>
</snapshots>
</repository>



</repositories>

Expand Down Expand Up @@ -99,4 +112,4 @@

</build>

</project>
</project>
209 changes: 73 additions & 136 deletions uengine-core/src/main/java/org/uengine/kernel/EJBProcessInstance.java
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,11 @@
import java.util.Set;
import java.util.Vector;

import org.metaworks.dwr.MetaworksRemoteService;
import org.uengine.contexts.ComplexType;
import org.uengine.modeling.resource.DefaultResource;
import org.uengine.modeling.resource.IResource;
import org.uengine.modeling.resource.ResourceManager;
import org.uengine.persistence.dao.UniqueKeyGenerator;
import org.uengine.persistence.processinstance.ProcessInstanceDAO;
import org.uengine.persistence.processinstance.ProcessInstanceDAOType;
Expand Down Expand Up @@ -51,10 +55,10 @@ public class EJBProcessInstance extends DefaultProcessInstance implements Transa
Map cachedRoleMappings;
//

private boolean fileBasedPersistence = GlobalContext.getPropertyString("persistence.file-based", "true").equals("true");

//for caching
boolean caching;
private boolean fileBasedPersistence = GlobalContext.getPropertyString("persistence.file-based", "false").equals("true");

public boolean isCaching() {
return caching;
}
Expand Down Expand Up @@ -303,7 +307,7 @@ public void applyChanges() throws Exception{
if(modifiedKeyMap!=null){

if(fileBasedPersistence) {
setProcessVariablesFile(getVariables());
setProcessVariablesToFile(getVariables());
}else {
/*DB based.*/

Expand Down Expand Up @@ -544,7 +548,7 @@ private void setImpl(String scopeByTracingTag, String key, Serializable val, int

if(fileBasedPersistence) {
if(!isBatch)
setProcessVariablesFile(createFullKey(scopeByTracingTag, key, isProperty), val);
setProcessVariablesToFile(createFullKey(scopeByTracingTag, key, isProperty), val);
}else {


Expand Down Expand Up @@ -622,22 +626,11 @@ private void beginCaching(String scopeByTracingTag, String key, boolean isProper
//20130815 var filePath save

if(fileBasedPersistence){ //file based variable persistence is disabled for concurrent variable data change.
Date starteddate = (Date)getProcessInstanceDAO().get("STARTEDDATE");
Calendar cal = Calendar.getInstance();
cal.setTime(starteddate);
String calendarDirectory = cal.get(Calendar.YEAR)
+ "/" + (cal.get(Calendar.MONTH) + 1) + "/"
+ cal.get(Calendar.DAY_OF_MONTH);

String filePath =GlobalContext.FILE_SYSTEM_PATH + (GlobalContext.FILE_SYSTEM_PATH.endsWith("/") ? "" : "/") + calendarDirectory +"/vars_" + getInstanceId() + ".json";
Map fileVariables = getAllFromFile();
fileVariables.putAll(variables);


File varFile = new File(filePath);
if (varFile.exists()) {
Map fileVariables = (Map) GlobalContext.deserialize(new FileInputStream(filePath), Object.class);
fileVariables.putAll(variables);
variables = fileVariables;
}
variables = fileVariables;

} else {

Expand Down Expand Up @@ -761,7 +754,7 @@ public Serializable getImpl(String scopeByTracingTag, String key, boolean isProp
}

if(sourceValue==null)
sourceValue = getFile(scopeByTracingTag, key, firstPart, isProperty);
sourceValue = getFromFile(scopeByTracingTag, key, firstPart, isProperty);

if(sourceValue == null){
ProcessDefinition pd = getProcessDefinition();
Expand Down Expand Up @@ -833,7 +826,7 @@ public Map getAll(String scope) throws Exception {
return variables;

// if(fileBasedPersistence)
// return getAllFile();
// return getAllFromFile();
// else
// return getProcessVariableDAOFacade().getAll(getInstanceId());
}
Expand Down Expand Up @@ -1392,165 +1385,109 @@ public String getMainExecutionScope() {
}
}

private void setProcessVariablesFile (Map modifiedVariables) throws FileNotFoundException, Exception {
Date starteddate = (Date)getProcessInstanceDAO().get("STARTEDDATE");
Calendar cal = Calendar.getInstance();
cal.setTime(starteddate);
String calendarDirectory = cal.get(Calendar.YEAR)
+ "/" + (cal.get(Calendar.MONTH) + 1) + "/"
+ cal.get(Calendar.DAY_OF_MONTH);
String filePath = GlobalContext.FILE_SYSTEM_PATH + (GlobalContext.FILE_SYSTEM_PATH.endsWith("/") ? "" : "/") + calendarDirectory ;
private void setProcessVariablesToFile(Map modifiedVariables) throws FileNotFoundException, Exception {
String filePath = getSaveFilePath();

File newFile = new File(filePath);
File dir = newFile.getParentFile();
if (!dir.exists()) {
dir.mkdirs();
}
if (!newFile.exists()) {
newFile.mkdirs();
}
ResourceManager resourceManager = MetaworksRemoteService.getComponent(ResourceManager.class);

IResource resource = new DefaultResource(filePath);

File varFile = new File(filePath +"/vars_"+getInstanceId() + ".json");
Map procVars = null;

if ( varFile.exists() ) {
procVars = (Map) GlobalContext.deserialize(new FileInputStream(varFile), Object.class);
if ( resourceManager.exists(resource) ) {
procVars = (Map) resourceManager.getObject(resource);
} else {
DefaultProcessInstance shotProcessInstance = getProcessVariableDAOFacade().getAllVariablesAsDefaultProcessInstance(getInstanceId());
procVars = shotProcessInstance.variables;
}

procVars.putAll(modifiedVariables);

GlobalContext.serialize(procVars,new FileOutputStream(filePath +"/vars_"+getInstanceId() + ".json"), Object.class);
resourceManager.save(resource, procVars);

}

private void setProcessVariablesToFile(String key, Serializable val) throws FileNotFoundException, Exception {
Map change = new HashMap();
change.put(key, val);
setProcessVariablesToFile(change);
}

private void setProcessVariablesFile (String key, Serializable val) throws FileNotFoundException, Exception {
private String getSaveFilePath() throws Exception {
Date starteddate = (Date)getProcessInstanceDAO().get("STARTEDDATE");
Calendar cal = Calendar.getInstance();
cal.setTime(starteddate);
String calendarDirectory = cal.get(Calendar.YEAR)
+ "/" + (cal.get(Calendar.MONTH) + 1) + "/"
+ cal.get(Calendar.DAY_OF_MONTH);
String filePath = GlobalContext.FILE_SYSTEM_PATH + (GlobalContext.FILE_SYSTEM_PATH.endsWith("/") ? "" : "/") + calendarDirectory ;

File newFile = new File(filePath);
File dir = newFile.getParentFile();
if (!dir.exists()) {
dir.mkdirs();
}
if (!newFile.exists()) {
newFile.mkdirs();
}

File varFile = new File(filePath +"/vars_"+getInstanceId() + ".json");
Map procVars = null;

if ( varFile.exists() ) {
procVars = (Map) GlobalContext.deserialize(new FileInputStream(varFile), Object.class);
} else {
DefaultProcessInstance shotProcessInstance = getProcessVariableDAOFacade().getAllVariablesAsDefaultProcessInstance(getInstanceId());
procVars = shotProcessInstance.variables;
}
String folder = GlobalContext.FILE_SYSTEM_PATH + (GlobalContext.FILE_SYSTEM_PATH.endsWith("/") ? "" : "/") + calendarDirectory;

if(val != null){
procVars.put(key, val);
}

GlobalContext.serialize(procVars,new FileOutputStream(filePath +"/vars_"+getInstanceId() + ".json"), Object.class);
return folder +"/vars_"+getInstanceId() + ".json";
}

private Map getAllFile() throws FileNotFoundException, Exception {
Date starteddate = (Date)getProcessInstanceDAO().get("STARTEDDATE");
Calendar cal = Calendar.getInstance();
cal.setTime(starteddate);
String calendarDirectory = cal.get(Calendar.YEAR)
+ "/" + (cal.get(Calendar.MONTH) + 1) + "/"
+ cal.get(Calendar.DAY_OF_MONTH);
String filePath = GlobalContext.FILE_SYSTEM_PATH + calendarDirectory ;
private Map getAllFromFile() throws FileNotFoundException, Exception {
ResourceManager resourceManager = MetaworksRemoteService.getComponent(ResourceManager.class);

File varFile = new File(filePath +"/vars_"+getInstanceId() + ".json");
Map procVars = null;
IResource resource = new DefaultResource(getSaveFilePath());

if (varFile.exists()) {
return (Map) GlobalContext.deserialize(new FileInputStream(varFile), Object.class);
if ( resourceManager.exists(resource) ) {
return (Map) resourceManager.getObject(resource);
}else{
return new HashMap(); // return empty one
}
else
return getProcessVariableDAOFacade().getAll(getInstanceId());
}

private ProcessVariableValue getMultipeFromFile(String scopeByTracingTag, String key) throws FileNotFoundException, Exception {
Date starteddate = (Date)getProcessInstanceDAO().get("STARTEDDATE");
Calendar cal = Calendar.getInstance();
cal.setTime(starteddate);
String calendarDirectory = cal.get(Calendar.YEAR)
+ "/" + (cal.get(Calendar.MONTH) + 1) + "/"
+ cal.get(Calendar.DAY_OF_MONTH);

String filePath =GlobalContext.FILE_SYSTEM_PATH +"/"+ calendarDirectory +"/vars_" + getInstanceId() + ".json";
File varFile = new File(filePath);
if (varFile.exists()) {
Map fileVariables = (Map) GlobalContext.deserialize(new FileInputStream(filePath), Object.class);
Map fileVariables = getAllFromFile();

Object originalValue = fileVariables.get(createFullKey(scopeByTracingTag, key, false));
Object originalValue = fileVariables.get(createFullKey(scopeByTracingTag, key, false));

if(originalValue instanceof IndexedProcessVariableMap) {
IndexedProcessVariableMap ipvm = (IndexedProcessVariableMap) originalValue;
if(originalValue instanceof IndexedProcessVariableMap) {
IndexedProcessVariableMap ipvm = (IndexedProcessVariableMap) originalValue;

if (ipvm != null) {
if (ipvm != null) {

int maxIndex = ipvm.getMaxIndex();
ProcessVariableValue pvv = new ProcessVariableValue();
for (int i = 0; i < maxIndex + 1; i++) {
Serializable value = ipvm.getProcessVariableAt(i);
int maxIndex = ipvm.getMaxIndex();
ProcessVariableValue pvv = new ProcessVariableValue();
for (int i = 0; i < maxIndex + 1; i++) {
Serializable value = ipvm.getProcessVariableAt(i);
pvv.setValue(value);
pvv.moveToAdd();
}
pvv.beforeFirst();
if (pvv.size() == 0 || (pvv.size() == 1 && pvv.getValue() == null)) {
try {
Serializable value = (Serializable) getProcessDefinition().getProcessVariable(key).getDefaultValue();
pvv.setValue(value);
pvv.moveToAdd();
}
pvv.beforeFirst();
if (pvv.size() == 0 || (pvv.size() == 1 && pvv.getValue() == null)) {
try {
Serializable value = (Serializable) getProcessDefinition().getProcessVariable(key).getDefaultValue();
pvv.setValue(value);

return pvv;
} catch (Exception e) {
}
}

return pvv;
} else {
// ProcessVariableValue pvv = new ProcessVariableValue();
// pvv.setName(key);

return null;
return pvv;
} catch (Exception e) {
}
}
}else{

ProcessVariableValue pvv = new ProcessVariableValue();
pvv.setValue(originalValue);

return pvv;
} else {
// ProcessVariableValue pvv = new ProcessVariableValue();
// pvv.setName(key);

return null;
}
}else{

ProcessVariableValue pvv = new ProcessVariableValue();
pvv.setValue(originalValue);

return pvv;
}

return getProcessVariableDAOFacade().getAsProcessVariableValue(getInstanceId(), scopeByTracingTag, key);
}
private Serializable getFile(String scopeByTracingTag, String key, String firstPart, boolean isProperty) throws FileNotFoundException, Exception {
Date starteddate = (Date)getProcessInstanceDAO().get("STARTEDDATE");
Calendar cal = Calendar.getInstance();
cal.setTime(starteddate);
String calendarDirectory = cal.get(Calendar.YEAR)
+ "/" + (cal.get(Calendar.MONTH) + 1) + "/"
+ cal.get(Calendar.DAY_OF_MONTH);

String filePath =GlobalContext.FILE_SYSTEM_PATH +"/"+ calendarDirectory +"/vars_" + getInstanceId() + ".json";
File varFile = new File(filePath);

private Serializable getFromFile(String scopeByTracingTag, String key, String firstPart, boolean isProperty) throws FileNotFoundException, Exception {

Serializable sourceValue;
if (varFile.exists()) {
Map fileVariables = (Map) GlobalContext.deserialize(new FileInputStream(filePath), Object.class);
sourceValue = (Serializable)fileVariables.get(createFullKey(scopeByTracingTag, key, isProperty));
} else
sourceValue = getProcessVariableDAOFacade().get(getInstanceId(), scopeByTracingTag, firstPart);
Map fileVariables = getAllFromFile();
sourceValue = (Serializable)fileVariables.get(createFullKey(scopeByTracingTag, key, isProperty));

return sourceValue;
}
Expand Down
Loading

0 comments on commit 7474b97

Please sign in to comment.