提交 e74fb898 编写于 作者: sq3536's avatar sq3536

版本升级

上级 1b85c180
...@@ -219,6 +219,21 @@ public class EntityModel extends BaseModel { ...@@ -219,6 +219,21 @@ public class EntityModel extends BaseModel {
return lastModifyField; return lastModifyField;
} }
private FieldModel orgField;
public FieldModel getOrgField() {
if(fields!=null&&orgField==null)
for(FieldModel fieldModel:fields)
if(fieldModel.isOrgField())
{
orgField=fieldModel;
return orgField;
}
return orgField;
}
public boolean isLogicValid() public boolean isLogicValid()
......
...@@ -186,6 +186,11 @@ public class FieldModel extends BaseModel { ...@@ -186,6 +186,11 @@ public class FieldModel extends BaseModel {
return "CREATEDATE".equals(this.getDataEntityField().getPredefinedType())||"CREATEMAN".equals(this.getDataEntityField().getPredefinedType()); return "CREATEDATE".equals(this.getDataEntityField().getPredefinedType())||"CREATEMAN".equals(this.getDataEntityField().getPredefinedType());
} }
public boolean isOrgField()
{
return "ORGID".equals(this.getDataEntityField().getPredefinedType());
}
public boolean isUnionKeyField() public boolean isUnionKeyField()
{ {
return !StringUtils.isEmpty(this.getDataEntityField().getUnionKeyValue()); return !StringUtils.isEmpty(this.getDataEntityField().getUnionKeyValue());
......
...@@ -10,7 +10,9 @@ import net.ibizsys.model.dataentity.action.IPSDEAction; ...@@ -10,7 +10,9 @@ import net.ibizsys.model.dataentity.action.IPSDEAction;
import net.ibizsys.model.dataentity.action.IPSDELogicAction; import net.ibizsys.model.dataentity.action.IPSDELogicAction;
import net.ibizsys.model.dataentity.action.IPSDEScriptAction; import net.ibizsys.model.dataentity.action.IPSDEScriptAction;
import net.ibizsys.model.wf.*; import net.ibizsys.model.wf.*;
import org.springframework.util.DigestUtils;
import org.springframework.util.ObjectUtils; import org.springframework.util.ObjectUtils;
import org.springframework.util.StringUtils;
import java.util.*; import java.util.*;
...@@ -30,7 +32,7 @@ public class WorkflowModel extends BaseModel{ ...@@ -30,7 +32,7 @@ public class WorkflowModel extends BaseModel{
} }
public IPSWFVersion getWFVersion() public IPSWFVersion getWFVer()
{ {
return (IPSWFVersion)opt; return (IPSWFVersion)opt;
} }
...@@ -43,9 +45,9 @@ public class WorkflowModel extends BaseModel{ ...@@ -43,9 +45,9 @@ public class WorkflowModel extends BaseModel{
if(refGroups==null) if(refGroups==null)
{ {
refGroups=new LinkedHashMap<>(); refGroups=new LinkedHashMap<>();
if(ObjectUtils.isEmpty(getWFVersion().getPSWFProcesses())) if(ObjectUtils.isEmpty(getWFVer().getPSWFProcesses()))
{ {
getWFVersion().getPSWFProcesses().forEach(WFProcess->{ getWFVer().getPSWFProcesses().forEach(WFProcess->{
List<IPSWFProcessRole> roles=null; List<IPSWFProcessRole> roles=null;
if(WFProcess instanceof IPSWFInteractiveProcess) if(WFProcess instanceof IPSWFInteractiveProcess)
roles=((IPSWFInteractiveProcess) WFProcess).getPSWFProcessRoles(); roles=((IPSWFInteractiveProcess) WFProcess).getPSWFProcessRoles();
...@@ -54,11 +56,13 @@ public class WorkflowModel extends BaseModel{ ...@@ -54,11 +56,13 @@ public class WorkflowModel extends BaseModel{
if(!ObjectUtils.isEmpty(roles)) if(!ObjectUtils.isEmpty(roles))
{ {
roles.forEach(role->{ roles.forEach(role->{
if(!"WFROLE".equalsIgnoreCase(role.getWFProcessRoleType()))
return;
String roleId=role.getPSWFRole().getCodeName()+"|"+role.getPSWFRole().getName()+"|"+role.getPSWFRole().getWFRoleType(); String roleId=role.getPSWFRole().getCodeName()+"|"+role.getPSWFRole().getName()+"|"+role.getPSWFRole().getWFRoleType();
if("DEDATASET".equalsIgnoreCase(role.getPSWFRole().getWFRoleType())&&role.getPSWFRole() instanceof IPSWFDEDataSetRole) { if("DEDATASET".equalsIgnoreCase(role.getPSWFRole().getWFRoleType())&&role.getPSWFRole() instanceof IPSWFDEDataSetRole) {
IPSWFDEDataSetRole dsRole=(IPSWFDEDataSetRole)role.getPSWFRole(); IPSWFDEDataSetRole dsRole=(IPSWFDEDataSetRole)role.getPSWFRole();
if(dsRole.getWFUserIdPSDEF()!=null&&dsRole.getPSDEDataSet()!=null&&dsRole.getPSDataEntity()!=null) if(dsRole.getWFUserIdPSDEF()!=null&&dsRole.getPSDEDataSet()!=null&&dsRole.getPSDataEntity()!=null)
roleId += ("/" + StringAdvUtils.pluralize(dsRole.getPSDataEntity().getCodeName())+"/fetch"+dsRole.getPSDEDataSet().getCodeName().toLowerCase()+"."+StringAdvUtils.camelcase(dsRole.getWFUserIdPSDEF().getCodeName())); roleId += ("/" + StringAdvUtils.pluralize(dsRole.getPSDataEntity().getCodeName())+"/fetch"+dsRole.getPSDEDataSet().getCodeName().toLowerCase()+"."+dsRole.getWFUserIdPSDEF().getCodeName().toLowerCase());
} }
refGroups.put(roleId,role); refGroups.put(roleId,role);
}); });
...@@ -70,21 +74,23 @@ public class WorkflowModel extends BaseModel{ ...@@ -70,21 +74,23 @@ public class WorkflowModel extends BaseModel{
return refGroups; return refGroups;
} }
private Map<String,EntityModel> bookings; private Map<String,EntityModel> bookings;
public Map<String,EntityModel> getBookings() public Map<String,EntityModel> getBookings()
{ {
if(bookings==null) if(bookings==null)
{ {
bookings=new LinkedHashMap<>(); bookings=new LinkedHashMap<>();
getWFVersion().getPSWorkflow().getPSWFDEs().forEach(de->{ getWFVer().getPSWorkflow().getPSWFDEs().forEach(de->{
bookings.put(de.getCodeName(),getSystem().getEntity(de.getCodeName())); bookings.put(de.getCodeName(),getSystem().getEntity(de.getCodeName()));
}); });
} }
return bookings; return bookings;
} }
private Map<String,AppModel> mobApps;
public Map<String,AppModel> getMobApps() { private Map<String,Map<String,AppModel>> mobApps;
public Map<String,Map<String,AppModel>> getMobApps() {
if (mobApps == null) { if (mobApps == null) {
mobApps=new LinkedHashMap<>(); mobApps=new LinkedHashMap<>();
getBookings().keySet().forEach(entity->{ getBookings().keySet().forEach(entity->{
...@@ -99,7 +105,15 @@ public class WorkflowModel extends BaseModel{ ...@@ -99,7 +105,15 @@ public class WorkflowModel extends BaseModel{
{ {
if(appEntity.getEntity()!=null&&entity.equalsIgnoreCase(appEntity.getEntity().getCodeName())) if(appEntity.getEntity()!=null&&entity.equalsIgnoreCase(appEntity.getEntity().getCodeName()))
{ {
mobApps.put(app.codeName,app); Map<String,AppModel> refApps=null;
if(mobApps.containsKey(appEntity.getEntity().getCodeName()))
refApps=mobApps.get(appEntity.getEntity().getCodeName());
else
{
refApps=new LinkedHashMap<>();
mobApps.put(appEntity.getEntity().getCodeName(),refApps);
}
refApps.put(app.codeName,app);
return; return;
} }
} }
...@@ -109,8 +123,8 @@ public class WorkflowModel extends BaseModel{ ...@@ -109,8 +123,8 @@ public class WorkflowModel extends BaseModel{
return mobApps; return mobApps;
} }
private Map<String,AppModel> webApps; private Map<String,Map<String,AppModel>> webApps;
public Map<String,AppModel> getWebApps() { public Map<String,Map<String,AppModel>> getWebApps() {
if (webApps == null) { if (webApps == null) {
webApps=new LinkedHashMap<>(); webApps=new LinkedHashMap<>();
getBookings().keySet().forEach(entity->{ getBookings().keySet().forEach(entity->{
...@@ -125,7 +139,15 @@ public class WorkflowModel extends BaseModel{ ...@@ -125,7 +139,15 @@ public class WorkflowModel extends BaseModel{
{ {
if(appEntity.getEntity()!=null&&entity.equalsIgnoreCase(appEntity.getEntity().getCodeName())) if(appEntity.getEntity()!=null&&entity.equalsIgnoreCase(appEntity.getEntity().getCodeName()))
{ {
webApps.put(app.codeName,app); Map<String,AppModel> refApps=null;
if(webApps.containsKey(appEntity.getEntity().getCodeName()))
refApps=webApps.get(appEntity.getEntity().getCodeName());
else
{
refApps=new LinkedHashMap<>();
webApps.put(appEntity.getEntity().getCodeName(),refApps);
}
refApps.put(app.codeName,app);
return; return;
} }
} }
...@@ -135,4 +157,351 @@ public class WorkflowModel extends BaseModel{ ...@@ -135,4 +157,351 @@ public class WorkflowModel extends BaseModel{
return webApps; return webApps;
} }
private List<Map> userTasks;
public List<Map> getUserTasks()
{
if(getWFVer().getPSWFProcesses()!=null)
{
userTasks=new ArrayList<>();
getWFVer().getPSWFProcesses().forEach(WFProcess->{
if(!isUserTask(WFProcess))
return;
Map<String,Object> map=new HashMap<>();
map.put("process",WFProcess);
List<IPSWFProcessRole> roles=null;
List<String> formParam=new ArrayList<>();
if(WFProcess instanceof IPSWFInteractiveProcess)
{
IPSWFInteractiveProcess interactiveProcess=(IPSWFInteractiveProcess)WFProcess;
if("SEQUENTIAL".equalsIgnoreCase(interactiveProcess.getMultiInstMode())) {
map.put("sequential", true);
map.put("multiInstanceLoopCharacteristics",true);
}
else if("PARALLEL".equalsIgnoreCase(interactiveProcess.getMultiInstMode())) {
map.put("sequential", false);
map.put("multiInstanceLoopCharacteristics",true);
}
roles=interactiveProcess.getPSWFProcessRoles();
map.put("hasForm",(!StringUtils.isEmpty(interactiveProcess.getFormCodeName()))||(!StringUtils.isEmpty(interactiveProcess.getMobFormCodeName())));
if(!ObjectUtils.isEmpty(interactiveProcess.getPredefinedActions()))
{
formParam.add("procfunc=\""+String.join(";",interactiveProcess.getPredefinedActions()).toLowerCase()+"\"");
}
if(!StringUtils.isEmpty(interactiveProcess.getFormCodeName()))
formParam.add("process-form=\""+interactiveProcess.getFormCodeName()+"\" ");
if(!StringUtils.isEmpty(interactiveProcess.getMobFormCodeName()))
formParam.add("process-mobform=\""+interactiveProcess.getMobFormCodeName()+"\" ");
if(!StringUtils.isEmpty(interactiveProcess.getUtilFormCodeName()))
formParam.add("process-utilform=\""+interactiveProcess.getUtilFormCodeName()+"\" " +
"process-utilformname=\""+(StringUtils.isEmpty(interactiveProcess.getUtilFormName())?interactiveProcess.getUtilFormCodeName():interactiveProcess.getUtilFormName())+"\" ");
if(!StringUtils.isEmpty(interactiveProcess.getUtil2FormCodeName()))
formParam.add("process-util2form=\""+interactiveProcess.getUtil2FormCodeName()+"\" " +
"process-util2formname=\""+(StringUtils.isEmpty(interactiveProcess.getUtil2FormName())?interactiveProcess.getUtil2FormCodeName():interactiveProcess.getUtil2FormName())+"\" ");
if(!StringUtils.isEmpty(interactiveProcess.getUtil3FormCodeName()))
formParam.add("process-util3form=\""+interactiveProcess.getUtil3FormCodeName()+"\" " +
"process-util3formname=\""+(StringUtils.isEmpty(interactiveProcess.getUtil3FormName())?interactiveProcess.getUtil3FormCodeName():interactiveProcess.getUtil3FormName())+"\" ");
if(!StringUtils.isEmpty(interactiveProcess.getMobUtilFormCodeName()))
formParam.add("process-mobutilform=\""+interactiveProcess.getMobUtilFormCodeName()+"\" " +
"process-mobutilformname=\""+(StringUtils.isEmpty(interactiveProcess.getMobUtilFormName())?interactiveProcess.getMobUtilFormCodeName():interactiveProcess.getMobUtilFormName())+"\" ");
if(!StringUtils.isEmpty(interactiveProcess.getMobUtil2FormCodeName()))
formParam.add("process-mobutil2form=\""+interactiveProcess.getMobUtil2FormCodeName()+"\" " +
"process-mobutil2formname=\""+(StringUtils.isEmpty(interactiveProcess.getMobUtil2FormName())?interactiveProcess.getMobUtil2FormCodeName():interactiveProcess.getMobUtil2FormName())+"\" ");
if(!StringUtils.isEmpty(interactiveProcess.getMobUtil3FormCodeName()))
formParam.add("process-mobutil3form=\""+interactiveProcess.getMobUtil3FormCodeName()+"\" " +
"process-mobutil3formname=\""+(StringUtils.isEmpty(interactiveProcess.getMobUtil3FormName())?interactiveProcess.getMobUtil3FormCodeName():interactiveProcess.getMobUtil3FormName())+"\" ");
String userTag="";
if(!StringUtils.isEmpty(interactiveProcess.getUserData()))
userTag=interactiveProcess.getUserData();
if(!StringUtils.isEmpty(interactiveProcess.getUserData2())) {
if(!StringUtils.isEmpty(userTag))
userTag+="|";
userTag += interactiveProcess.getUserData2();
}
if(!StringUtils.isEmpty(userTag))
formParam.add("usertag=\""+userTag+"\" ");
if(interactiveProcess.isEditable()) {
formParam.add("isEditable=\"" + interactiveProcess.isEditable() + "\" ");
formParam.add("editMode=\"" + interactiveProcess.getEditMode() + "\" ");
}
if(!ObjectUtils.isEmpty(interactiveProcess.getEditFields()))
{
formParam.add("editFields=\""+String.join(";",interactiveProcess.getEditFields()).toLowerCase()+"\"");
}
if(interactiveProcess.isSendInform()&&interactiveProcess.getPSSysMsgTempl()!=null)
formParam.add("msg-template=\""+interactiveProcess.getPSSysMsgTempl().getCodeName().toLowerCase()+"\" , msg-type=\""+interactiveProcess.getMsgType()+"\" " );
}
else if(WFProcess instanceof IPSWFCallOrgActivityProcess) {
roles = ((IPSWFCallOrgActivityProcess) WFProcess).getPSWFProcessRoles();
}
if(!ObjectUtils.isEmpty(roles))
{
List<String> assignCond=new ArrayList<>();
List<String> assignUtCond=new ArrayList<>();
List<String> assignGroupCond=new ArrayList<>();
roles.forEach(processRole-> {
if ("WFROLE".equalsIgnoreCase(processRole.getWFProcessRoleType())) {
String roleId=processRole.getPSWFRole().getCodeName();
if((!StringUtils.isEmpty(processRole.getUserData()))&&(!StringUtils.isEmpty(processRole.getUserData2())))
roleId=roleId+"|"+processRole.getUserData()+"|"+processRole.getUserData2();
assignGroupCond.add(roleId);
}
else if ("CURACTOR".equalsIgnoreCase(processRole.getWFProcessRoleType())) {
assignCond.add("${activedata.createman}");
assignUtCond.add("#activedata.createman");
}
else if(!StringUtils.isEmpty(processRole.getUDField()))
{
for(String str:processRole.getUDField().toLowerCase().split(";|,|;|,"))
{
assignCond.add("${activedata."+str+"}");
assignUtCond.add("#activedata."+str);
}
}
});
if(!ObjectUtils.isEmpty(assignGroupCond))
{
String strAssignGroupCond=String.join(",",assignGroupCond);
assignCond.add("${wfCoreService.getGroupUsers('"+strAssignGroupCond+"',execution)}");
map.put("assignGroupCond",strAssignGroupCond);
map.put("assignCond", String.join(",", assignCond));
String strAssignUtCond="";
if(!ObjectUtils.isEmpty(assignUtCond))
strAssignUtCond=String.join("|", assignUtCond)+"||";
strAssignUtCond+=("#wfCoreService.getGroupUsers2('"+strAssignGroupCond+"',#execution)");
map.put("assignUtCond", strAssignUtCond);
}
else if(!ObjectUtils.isEmpty(assignCond)) {
map.put("assignCond", String.join(",", assignCond));
if(!ObjectUtils.isEmpty(assignUtCond))
map.put("assignUtCond", String.join("|", assignUtCond));
}
if(formParam.size()>0&&map.containsKey("assignUtCond")) {
formParam.add("candidateUsersList=\""+map.get("assignUtCond")+"\" ");
}
}
if(WFProcess.isEnableTimeout())
{
String timeUnit="";
String timeType="";
if("MINUTE".equalsIgnoreCase(WFProcess.getTimeoutType()))
{
timeUnit="M";timeType="PT";
}
else if("HOUR".equalsIgnoreCase(WFProcess.getTimeoutType()))
{
timeUnit="H";timeType="PT";
}
else if("DAY".equalsIgnoreCase(WFProcess.getTimeoutType()))
{
timeUnit="D";timeType="P";
}
if(!ObjectUtils.isEmpty(WFProcess.getPSWFLinks()))
{
boolean timeOut = false;
for(IPSWFLink WFLink:WFProcess.getPSWFLinks()){
if(WFLink.getWFLinkType().equalsIgnoreCase("TIMEOUT"))
{
timeOut=true;
}
}
if(timeOut)
{
map.put("timeOut",true);
map.put("timeoutStrategy",timeType + WFProcess.getTimeout() + timeUnit);
}
}
}
if(formParam.size()>0) {
map.put("formParam", formParam);
}
userTasks.add(map);
});
}
return userTasks;
}
private List<Map> processes;
public List<Map> getProcesses()
{
if(processes==null) {
if(getWFVer().getPSWFProcesses()!=null)
{
processes = new ArrayList<>();
getWFVer().getPSWFProcesses().forEach(WFProcess-> {
Map<String,Object> map=new HashMap<>();
map.put("process",WFProcess);
if (!isUserTask(WFProcess))
map.put("processId","sid-"+WFProcess.getCodeName());
else
map.put("processId","tid-"+WFProcess.getWFStepValue()+"-"+WFProcess.getCodeName());
processes.add(map);
});
}
}
return processes;
}
private List<Map> sequenceFlows;
public List<Map> getSequenceFlows()
{
if(sequenceFlows==null)
{
sequenceFlows=new ArrayList<>();
if(!ObjectUtils.isEmpty(getWFVer().getPSWFLinks()))
{
getWFVer().getPSWFLinks().forEach(WFLink->{
Map<String,Object> map=new HashMap<>();
map.put("link",WFLink);
IPSWFProcess sourceProcess=WFLink.getFromPSWFProcess();
IPSWFProcess targetProcess=WFLink.getToPSWFProcess();
String sourceProcessId="sid-"+sourceProcess.getCodeName();
if(isUserTask(sourceProcess))
sourceProcessId="tid-"+sourceProcess.getWFStepValue()+"-"+sourceProcess.getCodeName();
String targetProcessId="sid-"+targetProcess.getCodeName();
if(isUserTask(targetProcess))
targetProcessId="tid-"+targetProcess.getWFStepValue()+"-"+targetProcess.getCodeName();
String linkDeployId= DigestUtils.md5DigestAsHex((sourceProcessId+sourceProcessId).getBytes());
String flowId="rid-"+linkDeployId;
if(!"ROUTE".equals(WFLink.getWFLinkType()))
flowId="lid-"+(StringUtils.isEmpty(WFLink.getLogicName())?WFLink.getName():WFLink.getLogicName())+"-"+linkDeployId;
map.put(sourceProcessId,sourceProcessId);
map.put(targetProcessId,targetProcessId);
map.put(flowId,flowId);
List<String> linkParam=new ArrayList<>();
if(WFLink instanceof PSWFInteractiveLinkImpl)
{
PSWFInteractiveLinkImpl interactiveLink=(PSWFInteractiveLinkImpl)WFLink;
if(!StringUtils.isEmpty(interactiveLink.getFormCodeName()))
linkParam.add("sequenceFlowForm=\""+interactiveLink.getFormCodeName()+"\" ");
if(!StringUtils.isEmpty(interactiveLink.getMobFormCodeName()))
linkParam.add("sequenceFlowMobForm=\""+interactiveLink.getMobFormCodeName()+"\" ");
if(!StringUtils.isEmpty(interactiveLink.getViewCodeName()))
linkParam.add("sequenceFlowView=\""+interactiveLink.getViewCodeName()+"\" ");
if(!StringUtils.isEmpty(interactiveLink.getMobViewCodeName()))
linkParam.add("sequenceFlowMobView=\""+interactiveLink.getMobViewCodeName()+"\" ");
if(!StringUtils.isEmpty(interactiveLink.getNextCondition()))
linkParam.add("nextCondition=\""+interactiveLink.getNextCondition()+"\" ");
if(!StringUtils.isEmpty(interactiveLink.getCustomCond()))
linkParam.add("customCond=\""+interactiveLink.getCustomCond()+"\" ");
}
if(linkParam.size()>0)
map.put("linkParam",linkParam);
if("TIMEOUT".equalsIgnoreCase(WFLink.getWFLinkType()))
{
if(!"Start001".equalsIgnoreCase(sourceProcess.getCodeName()))
{
String LinkCond="";
if("ROUTE".equalsIgnoreCase(WFLink.getWFLinkType()))
{
if(!StringUtils.isEmpty(WFLink.getCustomCond()))
LinkCond=WFLink.getCustomCond();
else if( WFLink.getPSWFLinkGroupCond()!=null)
{
LinkCond="<![CDATA[${"+getGroupCond(WFLink.getPSWFLinkGroupCond())+"} ]]>";
}
}
else
LinkCond="<![CDATA[${sequenceFlowId==\""+flowId+"\"}]]>";
if(!StringUtils.isEmpty(LinkCond))
map.put("linkCond",LinkCond);
}
}
sequenceFlows.add(map);
});
}
}
return sequenceFlows;
}
private boolean isUserTask(IPSWFProcess WFProcess)
{
String WFProcessType=WFProcess.getWFProcessType();
return !("START".equals(WFProcessType)||"END".equals(WFProcessType)||"PARALLELGATEWAY".equals(WFProcessType)||"INCLUSIVEGATEWAY".equals(WFProcessType)||"EXCLUSIVEGATEWAY".equals(WFProcessType)||"PROCESS".equals(WFProcessType));
}
private String getGroupCond(IPSWFLinkGroupCond WFLinkCond)
{
String strRuleCond="(";
if(!ObjectUtils.isEmpty(WFLinkCond.getPSWFLinkConds()))
{
String conn=WFLinkCond.getGroupOP().replace("AND","&&").replace("OR","||");
for(IPSWFLinkCond childWFLinkCond:WFLinkCond.getPSWFLinkConds())
{
String childLinkType=childWFLinkCond.getCondType();
if ( childWFLinkCond instanceof IPSWFLinkGroupCond && (!ObjectUtils.isEmpty(((IPSWFLinkGroupCond)childWFLinkCond).getPSWFLinkConds())) ) {
if(!strRuleCond.equalsIgnoreCase("("))
strRuleCond=strRuleCond+conn;
strRuleCond = strRuleCond + getGroupCond((IPSWFLinkGroupCond) childWFLinkCond);
}
else if(childWFLinkCond instanceof IPSWFLinkSingleCond ) {
if(!strRuleCond.equalsIgnoreCase("("))
strRuleCond=strRuleCond+conn;
strRuleCond = strRuleCond + getFieldCond((IPSWFLinkSingleCond) childWFLinkCond);
}
}
}
strRuleCond=strRuleCond+")";
return strRuleCond;
}
private String getFieldCond(IPSWFLinkSingleCond WFLinkCond)
{
String fieldCond="(";
String condBody="";
String paramType=WFLinkCond.getParamType()==null?"":WFLinkCond.getParamType();
String targetField=WFLinkCond.getFieldName()==null?"":WFLinkCond.getFieldName().toLowerCase();
String targetDBValueOP=WFLinkCond.getCondType();
String targetValue=WFLinkCond.getParamValue();
if("ISNULL".equalsIgnoreCase(targetDBValueOP)||"ISNOTNULL".equalsIgnoreCase(targetDBValueOP))
condBody="wfCoreService.test(activedata."+targetField+", '"+targetDBValueOP+"', null)";
else if ("ENTITYFIELD".equalsIgnoreCase(paramType)||"CONTEXT".equalsIgnoreCase(paramType))
{
if(!StringUtils.isEmpty(targetValue))
condBody="wfCoreService.test(activedata."+targetField+", '"+targetDBValueOP+"', activedata."+targetValue.toLowerCase()+")";
else
condBody="wfCoreService.test(activedata."+targetField+", '"+targetDBValueOP+"', null)";
}
else if("CURTIME".equalsIgnoreCase(paramType))
{
condBody="wfCoreService.test(activedata."+targetField+", '"+targetDBValueOP+"', wfCoreService.getnow())";
}
else if("OPERATOR".equalsIgnoreCase(paramType))
condBody="wfCoreService.test(activedata."+targetField+", '"+targetDBValueOP+"', curuser.userid)";
else if("OPERATORNAME".equalsIgnoreCase(paramType))
condBody="wfCoreService.test(activedata."+targetField+", '"+targetDBValueOP+"', curuser.personname)";
else if("SESSION".equalsIgnoreCase(paramType)&&(!StringUtils.isEmpty(targetValue)))
condBody="wfCoreService.test(activedata."+targetField+", '"+targetDBValueOP+"', curuser.sessionParams."+targetValue.toLowerCase()+")";
else if (!StringUtils.isEmpty(targetValue))
condBody="wfCoreService.test(activedata."+targetField+", '"+targetDBValueOP+"', '"+targetValue.replace("\"","").replace("‘","").replace("“","").replace("”","")+"')";
else if (StringUtils.isEmpty(targetValue))
condBody="wfCoreService.test(activedata."+targetField+", '"+targetDBValueOP+"', null)";
fieldCond=fieldCond+condBody;
fieldCond=fieldCond+")";
return fieldCond;
}
} }
...@@ -2,4 +2,4 @@ spring: ...@@ -2,4 +2,4 @@ spring:
profiles: profiles:
include: nacos, {{lowerCase app.codeName}}-prod include: nacos, {{lowerCase app.codeName}}-prod
application: application:
name: {{projectName}}-{{lowerCase app.codeName}} name: {{lowerCase system.codeName}}-{{lowerCase app.codeName}}
...@@ -2,6 +2,6 @@ spring: ...@@ -2,6 +2,6 @@ spring:
profiles: profiles:
include: sys , nacos ,{{#each system.apps}} {{lowerCase codeName}}-dev ,{{/each}}{{#each system.apis}} {{lowerCase codeName}}-dev ,{{/each}} dev include: sys , nacos ,{{#each system.apps}} {{lowerCase codeName}}-dev ,{{/each}}{{#each system.apis}} {{lowerCase codeName}}-dev ,{{/each}} dev
application: application:
name: {{projectName}} name: {{lowerCase system.codeName}}
main: main:
allow-bean-definition-overriding: true allow-bean-definition-overriding: true
\ No newline at end of file
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<definitions xmlns="http://www.omg.org/spec/BPMN/20100524/MODEL" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:flowable="http://flowable.org/bpmn" xmlns:bpmndi="http://www.omg.org/spec/BPMN/20100524/DI" xmlns:omgdc="http://www.omg.org/spec/DD/20100524/DC" xmlns:omgdi="http://www.omg.org/spec/DD/20100524/DI" typeLanguage="http://www.w3.org/2001/XMLSchema" expressionLanguage="http://www.w3.org/1999/XPath" targetNamespace="http://www.flowable.org/processdef">
<process id="{{workflow.id}}" isClosed="false" isExecutable="true" name="{{workflow.name}}" processType="None">
<extensionElements>
<flowable:eventListener delegateExpression="${processInstanceListener}" />
{{#if workflow.refGroups}}
<flowable:field name="refgroups">
<flowable:string>{{#each workflow.refGroups as |refGroup|}}{{@key}}{{#unless @last}},{{/unless}}{{/each}}</flowable:string>
</flowable:field>
{{/if}}
{{#if workflow.bookings}}
<flowable:field name="bookings">
<flowable:string>{{#each workflow.bookings as |booking|}}{{pluralize booking.codeName}}{{#unless @last}},{{/unless}}{{/each}}</flowable:string>
</flowable:field>
{{/if}}
{{#if workflow.mobApps}}
{{#each workflow.mobApps as |mobApp|}}
<flowable:field name="bookingmobs_{{pluralize @key}}">
<flowable:string>{{#each this as |app|}}{{app.codeName}}{{#unless @last}},{{/unless}}{{/each}}</flowable:string>
</flowable:field>
{{/each}}
{{/if}}
{{#if workflow.webApps}}
{{#each workflow.webApps as |webApp|}}
<flowable:field name="bookingapps_{{pluralize @key}}">
<flowable:string>{{#each this as |app|}}{{app.codeName}}{{#unless @last}},{{/unless}}{{/each}}</flowable:string>
</flowable:field>
{{/each}}
{{/if}}
{{#each item.psWorkflow().psWFDEs as |wfde|}}
{{#if wfde.wFStepPSDEField}}
<flowable:field name="wfstepfield_{{pluralize wfde.psDataEntity.codeName}}">
<flowable:string>{{lowerCase wfde.wFStepPSDEField.codeName}}</flowable:string>
</flowable:field>
{{/if}}
{{#if wfde.wFInstPSDEField}}
<flowable:field name="wfinstfield_{{pluralize wfde.psDataEntity.codeName}}">
<flowable:string>{{lowerCase wfde.wFInstPSDEField.codeName}}</flowable:string>
</flowable:field>
{{/if}}
{{#if wfde.uDStatePSDEField}}
<flowable:field name="udstatefield_{{pluralize wfde.psDataEntity.codeName}}">
<flowable:string>{{lowerCase wfde.uDStatePSDEField.codeName}}</flowable:string>
</flowable:field>
{{/if}}
{{#if workflow.psWorkflow.entityWFStates}}
{{#neq workflow.psWorkflow.entityWFStates ""}}
<flowable:field name="udstateingval_{{pluralize wfde.psDataEntity.codeName}}">
<flowable:string>{{workflow.psWorkflow.entityWFStates}}</flowable:string>
</flowable:field>
{{/neq}}
{{/if}}
{{#if workflow.psWorkflow.entityWFFinishState}}
{{#neq workflow.psWorkflow.entityWFFinishState ""}}
<flowable:field name="wffinishval_{{pluralize wfde.psDataEntity.codeName}}">
<flowable:string>{{workflow.psWorkflow.entityWFFinishState}}</flowable:string>
</flowable:field>
{{/neq}}
{{/if}}
{{#if workflow.psWorkflow.entityWFErrorState}}
{{#neq workflow.psWorkflow.entityWFErrorState ""}}
<flowable:field name="wferrorval_{{pluralize wfde.psDataEntity.codeName}}">
<flowable:string>{{workflow.psWorkflow.entityWFErrorState}}</flowable:string>
</flowable:field>
{{/neq}}
{{/if}}
{{#if wfde.wFStatePSDEField}}
<flowable:field name="wfstatefield_{{pluralize wfde.psDataEntity.codeName}}">
<flowable:string>{{lowerCase wfde.wFStatePSDEField.codeName}}</flowable:string>
</flowable:field>
{{/if}}
{{#if wfde.wFVerPSDEField}}
<flowable:field name="wfverfield_{{pluralize wfde.psDataEntity.codeName}}">
<flowable:string>{{lowerCase wfde.wFVerPSDEField.codeName}}</flowable:string>
</flowable:field>
{{/if}}
{{#if wfde.psDataEntity.majorPSDEField}}
<flowable:field name="majortext_{{pluralize wfde.psDataEntity.codeName}}">
<flowable:string>{{lowerCase wfde.psDataEntity.majorPSDEField.codeName}}</flowable:string>
</flowable:field>
{{/if}}
{{#if wfde.psDataEntity.orgField}}
<flowable:field name="orgfield_{{pluralize wfde.psDataEntity.codeName}}">
<flowable:string>{{lowerCase wfde.psDataEntity.orgField.codeName}}</flowable:string>
</flowable:field>
{{/if}}
<flowable:field name="isvalid"><flowable:string>{{#if workflow.valid}}1{{else}}0{{/if}}</flowable:string></flowable:field>
{{/each}}
</extensionElements>
{{#if workflow.psWFProcesses}}
{{#each workflow.psWFProcesses as |WFProcess|}}
{{#eq WFProcess.wFProcessType 'START'}}
<startEvent id="sid-{{WFProcess.codeName}}" name="{{WFProcess.name}}">
{{#if (or WFProcess.formCodeName WFProcess.mobFormCodeName)}}
<extensionElements>
<flowable:form {{#if WFProcess.formCodeName}}process-form="{{WFProcess.formCodeName}}"{{/if}} {{#if WFProcess.mobFormCodeName}}process-mobform="{{WFProcess.mobFormCodeName}}"{{/if}} {{#if WFProcess.wFVersion}}wfversion="{{WFProcess.wFVersion}}"{{/if}}/>
</extensionElements>
{{/if}}
</startEvent>
{{/eq}}
{{#eq WFProcess.wFProcessType 'END'}}
<endEvent id="sid-{{WFProcess.codeName}}" name="{{WFProcess.name}}">
{{#if (or (and WFProcess.userData (neq WFProcess.userData "")) (and WFProcess.userData2 (neq WFProcess.userData2 "")))}}
<extensionElements>
<flowable:form {{#if (and WFProcess.userData (neq WFProcess.userData ""))}}userdata="{{WFProcess.userData}}"{{/if}} {{#if (and WFProcess.userData2 (neq WFProcess.userData2 ""))}}userdata2="{{WFProcess.userData2}}"{{/if}} />
</extensionElements>
{{/if}}
</endEvent>
{{/eq}}
{{#eq WFProcess.wFProcessType 'PARALLELGATEWAY'}}
<parallelGateway id="sid-{{WFProcess.codeName}}"/>
{{/eq}}
{{#eq WFProcess.wFProcessType 'INCLUSIVEGATEWAY'}}
<inclusiveGateway id="sid-{{WFProcess.codeName}}"/>
{{/eq}}
{{#eq WFProcess.wFProcessType 'EXCLUSIVEGATEWAY'}}
<exclusiveGateway id="sid-{{WFProcess.codeName}}"/>
{{/eq}}
{{#eq WFProcess.wFProcessType 'PROCESS'}}
<serviceTask id="sid-{{WFProcess.codeName}}" name="{{WFProcess.name}}" flowable:expression="${wfCoreService.execute(execution, activedata)}" >
<extensionElements>
<flowable:field name="service-entity"><flowable:string>{{pluralize WFProcess.psDataEntity.codeName}}</flowable:string></flowable:field>
<flowable:field name="service-deaction"><flowable:string>{{lowerCase WFProcess.psDEAction.codeName}}</flowable:string></flowable:field>
{{#if WFProcess.psWFProcessParams}}
{{#each WFProcess.psWFProcessParams as |processparams|}}
{{#if processparams.dstField (neq processparams.dstField "")}}
{{#if (and processparams.srcValueType (neq processparams.srcValueType ""))}}
{{#eq processparams.srcValue "CURTIME"}}
<flowable:field name="params-{{lowerCase processparams.dstField}}"><flowable:expression><![CDATA[${wfCoreService.getnow()}]]></flowable:expression></flowable:field>
{{/eq}}
{{#eq processparams.srcValue "OPERATOR"}}
<flowable:field name="params-{{lowerCase processparams.dstField}}"><flowable:expression><![CDATA[${curuser.userid}]]></flowable:expression></flowable:field>
{{/eq}}
{{#eq processparams.srcValue "OPERATORNAME"}}
<flowable:field name="params-{{lowerCase processparams.dstField}}"><flowable:expression><![CDATA[${curuser.personname}]]></flowable:expression></flowable:field>
{{/eq}}
{{#eq processparams.srcValue "CONTEXT"}}
<flowable:field name="params-{{lowerCase processparams.dstField}}"><flowable:expression><![CDATA[${activedata.{{lowerCase processparams.srcValue}} }]]></flowable:expression></flowable:field>
{{/eq}}
{{#eq processparams.srcValue "SESSION"}}
<flowable:field name="params-{{lowerCase processparams.dstField}}"><flowable:expression><![CDATA[${curuser.sessionParams.{{lowerCase processparams.srcValue}} }]]></flowable:expression></flowable:field>
{{/eq}}
{{else}}
{{#if (and processparams.srcValue (neq processparams.srcValue ""))}}
<flowable:field name="params-{{lowerCase processparams.dstField}}"><flowable:string>{{processparams.srcValue}}</flowable:string></flowable:field>
{{/if}}
{{/if}}
{{/if}}
{{/each}}
{{/if}}
</extensionElements>
</serviceTask>
{{/eq}}
{{/each}}
{{#each workflow.userTasks as |userTask|}}
<userTask flowable:category="${businessKey}" {{#if userTask.timeOut}}flowable:dueDate="{{userTask.timeoutStrategy}}" {{/if}}flowable:candidateUsers="{{#if userTask.multiInstanceLoopCharacteristics}}${candidateUsers}{{else}}{{userTask.assignCond}}{{/if}}" flowable:exclusive="true"
id="tid-{{userTask.process.wFStepValue}}-{{userTask.process.codeName}}"
name="{{userTask.process.name}}" {{#if (or (eq userTask.process.wFProcessType "CALLORGACTIVITY") (eq userTask.process.wFProcessType "EMBED"))}}flowable:formKey="{{userTask.process.wFProcessType}}"{{/if}}>
<documentation>${majortext}</documentation>
{{#if userTask.formParam}}
<extensionElements>
<flowable:form {{#each userTask.formParam as |itemParam|}}{{itemParam}} {{/each}}/>
</extensionElements>
{{/if}}
{{#if userTask.multiInstanceLoopCharacteristics}}
<multiInstanceLoopCharacteristics flowable:collection="candidateUsersList" flowable:elementVariable="candidateUsers" isSequential="{{userTask.sequential}}">
<completionCondition><![CDATA[${nrOfCompletedInstances/nrOfInstances == 1}]]></completionCondition>
</multiInstanceLoopCharacteristics>
{{/if}}
</userTask>
{{#if userTask.timeOut}}
<boundaryEvent id="bid-{{userTask.process.wFStepValue}}-{{userTask.process.codeName}}" name="timeout-{{userTask.process.name}}" attachedToRef="tid-{{userTask.process.wFStepValue}}-{{userTask.process.codeName}}" cancelActivity="true">
<timerEventDefinition>
<timeDate>{{userTask.timeoutStrategy}}</timeDate>
</timerEventDefinition>
</boundaryEvent>
{{/if}}
{{/each}}
{{/if}}
{{#each workflow.sequenceFlows as |sequenceFlow|}}
<sequenceFlow id="{{sequenceFlow.flowId}}" sourceRef="{{sequenceFlow.sourceProcessId}}" targetRef="{{sequenceFlow.targetProcessId}}" name="{{sequenceFlow.link.logicName}}">
{{#if sequenceFlow.linkCond}}
<conditionExpression xsi:type="tFormalExpression" >{{sequenceFlow.linkCond}}</conditionExpression>
{{/if}}
{{#if sequenceFlow.linkParam}}
<extensionElements>
<flowable:form {{#each sequenceFlow.linkParam as |itemParam|}}{{itemParam}} {{/each}}/>
</extensionElements>
{{/if}}
</sequenceFlow>
{{/each}}
</process>
<bpmndi:BPMNDiagram id="BPMNDiagram_{{workflow.id}}">
<bpmndi:BPMNPlane id="BPMNPlane_{{workflow.id}}" bpmnElement="{{workflow.id}}">
{{#each workflow.processes as |task|}}
<bpmndi:BPMNShape id="BPMNShape-{{task.processId}}" bpmnElement="{{task.processId}}">
<omgdi:Bounds x="{{task.process.leftPos}}" y="{{task.process.topPos}}" width="{{task.process.width}}" height="{{task.process.height}}" />
</bpmndi:BPMNShape>
{{/each}}
{{#each workflow.sequenceFlows as |sequenceFlow|}}
<bpmndi:BPMNEdge id="BPMNEdge-{{sequenceFlow.flowId}}" bpmnElement="{{sequenceFlow.flowId}}">
<omgdi:waypoint x="0" y="0" />
<omgdi:waypoint x="0" y="0" />
</bpmndi:BPMNEdge>
{{/each}}
</bpmndi:BPMNPlane>
</bpmndi:BPMNDiagram>
</definitions>
\ No newline at end of file
<#ibiztemplate>
TARGET=PSWFVERSION
</#ibiztemplate>
<#assign sid = sys.getId()/>
<#assign sname = sys.getCodeName()/>
<#assign slogicname = sys.getName() />
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<definitions xmlns="http://www.omg.org/spec/BPMN/20100524/MODEL" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:flowable="http://flowable.org/bpmn" xmlns:bpmndi="http://www.omg.org/spec/BPMN/20100524/DI" xmlns:omgdc="http://www.omg.org/spec/DD/20100524/DC" xmlns:omgdi="http://www.omg.org/spec/DD/20100524/DI" typeLanguage="http://www.w3.org/2001/XMLSchema" expressionLanguage="http://www.w3.org/1999/XPath" targetNamespace="http://www.flowable.org/processdef">
<process id="${sys.getCodeName()?lower_case}-${item.codeName?lower_case}" isClosed="false" isExecutable="true" name="${item.getName()}" processType="None">
<extensionElements>
<flowable:eventListener delegateExpression="${processInstanceListener}" />
<#if item.getPSWFProcesses?? && item.getPSWFProcesses()??>
<#assign rolesList="">
<#list item.getPSWFProcesses() as WFProcess>
<#if WFProcess.getPSWFProcessRoles?? && WFProcess.getPSWFProcessRoles()??>
<#list WFProcess.getPSWFProcessRoles() as processRole>
<#assign processRoleType=processRole.getWFProcessRoleType()>
<#if processRoleType=='WFROLE'>
<#if processRole.getPSWFRole()?? && processRole.getPSWFRole().getCodeName()??>
<#if !P.exists("refgroups",processRole.getPSWFRole().getCodeName())>
<#if rolesList!=""><#assign rolesList=rolesList+","></#if>
<#assign rolesList=rolesList+processRole.getPSWFRole().getCodeName()+"|"+processRole.getPSWFRole().getName()+"|"+processRole.getPSWFRole().getWFRoleType()>
<#if processRole.getPSWFRole().getWFRoleType()=="DEDATASET">
<#assign rolesList=rolesList+"/"+srfpluralize(processRole.getPSWFRole().getPSDataEntity().getCodeName()?lower_case)+"/fetch"+processRole.getPSWFRole().getPSDEDataSet().getCodeName()?lower_case+"."+processRole.getPSWFRole().getWFUserIdPSDEF().getCodeName()?lower_case>
</#if>
</#if>
</#if>
</#if>
</#list>
</#if>
</#list>
<#if rolesList!="">
<flowable:field name="refgroups">
<flowable:string>${rolesList}</flowable:string>
</flowable:field>
</#if>
</#if>
<#if item.getPSWorkflow()?? && item.getPSWorkflow().getPSWFDEs()??>
<#assign des="">
<#list item.getPSWorkflow().getPSWFDEs() as wfde>
<#if des!=""><#assign des=des+","></#if>
<#assign des=des+srfpluralize(wfde.getPSDataEntity().getCodeName()?lower_case)>
</#list>
<#if des!="">
<flowable:field name="bookings">
<flowable:string>${des}</flowable:string>
</flowable:field>
</#if>
<#list item.getPSWorkflow().getPSWFDEs() as wfde>
<#assign mobApp="">
<#assign pcApp="">
<#if wfde.getPSDataEntity()??>
<#assign refDE=wfde.getPSDataEntity()>
<#if refDE.getAllPSAppDataEntities()??>
<#list refDE.getAllPSAppDataEntities() as refAppDE>
<#assign app=refAppDE.getPSApplication()>
<#if app.isMobileApp()>
<#if !P.exists("mob",app.codeName)>
<#if mobApp=="">
<#assign mobApp=app.codeName>
<#else>
<#assign mobApp=mobApp+","+app.codeName>
</#if>
</#if>
<#else>
<#if !P.exists("pc",app.codeName)>
<#if pcApp=="">
<#assign pcApp=app.codeName>
<#else>
<#assign pcApp=pcApp+","+app.codeName>
</#if>
</#if>
</#if>
</#list>
</#if>
<#if pcApp!="">
<flowable:field name="bookingapps_${srfpluralize(refDE.getCodeName()?lower_case)}">
<flowable:string>${pcApp}</flowable:string>
</flowable:field>
</#if>
<#if mobApp!="">
<flowable:field name="bookingmobs_${srfpluralize(refDE.getCodeName()?lower_case)}">
<flowable:string>${mobApp}</flowable:string>
</flowable:field>
</#if>
</#if>
</#list>
<#list item.getPSWorkflow().getPSWFDEs() as wfde>
<#if wfde.getWFStepPSDEField()??>
<flowable:field name="wfstepfield_${srfpluralize(wfde.getPSDataEntity().getCodeName()?lower_case)}">
<flowable:string>${(wfde.getWFStepPSDEField().getCodeName()?lower_case)}</flowable:string>
</flowable:field>
</#if>
<#if wfde.getWFInstPSDEField()??>
<flowable:field name="wfinstfield_${srfpluralize(wfde.getPSDataEntity().getCodeName()?lower_case)}">
<flowable:string>${(wfde.getWFInstPSDEField().getCodeName()?lower_case)}</flowable:string>
</flowable:field>
</#if>
<#if wfde.getUDStatePSDEField()??>
<flowable:field name="udstatefield_${srfpluralize(wfde.getPSDataEntity().getCodeName()?lower_case)}">
<flowable:string>${(wfde.getUDStatePSDEField().getCodeName()?lower_case)}</flowable:string>
</flowable:field>
</#if>
<#if item.getPSWorkflow().getEntityWFStates?? && item.getPSWorkflow().getEntityWFStates()??>
<#list item.getPSWorkflow().getEntityWFStates() as wfStatus>
<flowable:field name="udstateingval_${srfpluralize(wfde.getPSDataEntity().getCodeName()?lower_case)}">
<flowable:string>${wfStatus}</flowable:string>
</flowable:field>
<#break>
</#list>
</#if>
<#if wfde.getWFStatePSDEField()??>
<flowable:field name="wfstatefield_${srfpluralize(wfde.getPSDataEntity().getCodeName()?lower_case)}">
<flowable:string>${(wfde.getWFStatePSDEField().getCodeName()?lower_case)}</flowable:string>
</flowable:field>
</#if>
<#if wfde.getWFVerPSDEField()??>
<flowable:field name="wfverfield_${srfpluralize(wfde.getPSDataEntity().getCodeName()?lower_case)}">
<flowable:string>${(wfde.getWFVerPSDEField().getCodeName()?lower_case)}</flowable:string>
</flowable:field>
</#if>
<#if wfde.getPSDataEntity().getMajorPSDEField()??&&wfde.getPSDataEntity().getMajorPSDEField().getCodeName()??>
<flowable:field name="majortext_${srfpluralize(wfde.getPSDataEntity().getCodeName()?lower_case)}">
<flowable:string>${(wfde.getPSDataEntity().getMajorPSDEField().getCodeName()?lower_case)}</flowable:string>
</flowable:field>
</#if>
</#list>
</#if>
</extensionElements>
<#comment>绘制处理节点</#comment>
<#if item.getPSWFProcesses?? && item.getPSWFProcesses()??>
<#list item.getPSWFProcesses() as WFProcess>
<#if WFProcess.getWFProcessType()=='START'>
<startEvent id="sid-${WFProcess.getDeployId()}" name="${WFProcess.getName()}"/>
<#elseif WFProcess.getWFProcessType()=='END'>
<endEvent id="sid-${WFProcess.getDeployId()}" name="${WFProcess.getName()}"/>
<#elseif WFProcess.getWFProcessType()=='PARALLELGATEWAY'>
<parallelGateway id="sid-${WFProcess.getDeployId()}"></parallelGateway>
<#elseif WFProcess.getWFProcessType()=='INCLUSIVEGATEWAY'>
<inclusiveGateway id="sid-${WFProcess.getDeployId()}"></inclusiveGateway>
<#elseif WFProcess.getWFProcessType()=='EXCLUSIVEGATEWAY'>
<exclusiveGateway id="sid-${WFProcess.getDeployId()}"></exclusiveGateway>
<#elseif WFProcess.getWFProcessType()=='PROCESS'>
<serviceTask id="sid-${WFProcess.getDeployId()}" name="${WFProcess.getName()}" flowable:expression="${wfCoreService.execute(execution, activedata)}" >
<#if WFProcess.getPSDataEntity()??>
<extensionElements>
<flowable:field name="service-entity"><flowable:string>${srfpluralize(WFProcess.getPSDataEntity().getCodeName()?lower_case)}</flowable:string></flowable:field>
<flowable:field name="service-deaction"><flowable:string>${WFProcess.getPSDEAction().getCodeName()?lower_case}</flowable:string></flowable:field>
<#if WFProcess.getPSWFProcessParams()??>
<#list WFProcess.getPSWFProcessParams() as processparams>
<#if processparams.getSrcValueType()?? && processparams.getSrcValueType()!="" && processparams.getDstField()?? && processparams.getDstField()!="">
<#if processparams.getSrcValueType()=="CURTIME">
<flowable:field name="params-${(processparams.getDstField()?lower_case)}"><flowable:expression><![CDATA[${wfCoreService.getnow()}]]></flowable:expression></flowable:field>
<#elseif processparams.getSrcValueType()=="OPERATOR">
<flowable:field name="params-${(processparams.getDstField()?lower_case)}"><flowable:expression><![CDATA[${curuser.userid}]]></flowable:expression></flowable:field>
<#elseif processparams.getSrcValueType()=="OPERATORNAME">
<flowable:field name="params-${(processparams.getDstField()?lower_case)}"><flowable:expression><![CDATA[${curuser.personname}]]></flowable:expression></flowable:field>
<#elseif processparams.getSrcValueType()=="CONTEXT">
<flowable:field name="params-${(processparams.getDstField()?lower_case)}"><flowable:expression><![CDATA[${activedata.'}${(processparams.getSrcValue()?lower_case)}}]]></flowable:expression></flowable:field>
<#elseif processparams.getSrcValueType()=="SESSION">
<flowable:field name="params-${(processparams.getDstField()?lower_case)}"><flowable:expression><![CDATA[${curuser.sessionParams.'}${processparams.getSrcValue()?lower_case}}]]></flowable:expression></flowable:field>
</#if>
<#elseif processparams.getSrcValue()?? && processparams.getDstField()?? && processparams.getDstField()!="">
<flowable:field name="params-${(processparams.getDstField()?lower_case)}"><flowable:string>${processparams.getSrcValue()}</flowable:string></flowable:field>
</#if>
</#list>
</#if>
</extensionElements>
</#if>
</serviceTask>
<#else>
<#assign assignCond="">
<#assign isSequential="">
<#if WFProcess.getMultiInstMode?? && WFProcess.getMultiInstMode()?? && ( WFProcess.getMultiInstMode()=='PARALLEL' || WFProcess.getMultiInstMode()=='SEQUENTIAL')>
<#assign assignCond="flowable:assignee=\""+"$"+"{assignee}\"">
<#if WFProcess.getMultiInstMode()=='SEQUENTIAL'>
<#assign isSequential="isSequential=\"true\"">
<#else>
<#assign isSequential="isSequential=\"false\"">
</#if>
</#if>
<#assign assignCond="">
<#assign assignGroupCond="">
<#if WFProcess.getPSWFProcessRoles?? && WFProcess.getPSWFProcessRoles()??>
<#list WFProcess.getPSWFProcessRoles() as processRole>
<#assign processRoleType=processRole.getWFProcessRoleType()>
<#assign roleId="">
<#if processRoleType=='WFROLE'>
<#if processRole.getPSWFRole()?? && processRole.getPSWFRole().getCodeName()??>
<#if assignGroupCond!="">
<#assign assignGroupCond=assignGroupCond+",">
</#if>
<#assign assignGroupCond=assignGroupCond+processRole.getPSWFRole().getCodeName()>
<#if processRole.getUserData()?? && processRole.getUserData2()?? && processRole.getUserData()!="" && processRole.getUserData()!="">
<#assign assignGroupCond=assignGroupCond+"|"+processRole.getUserData()+"|"+processRole.getUserData2()>
</#if>
</#if>
<#else>
<#if processRole.getUDField()?? && processRole.getUDField()!="">
<#if assignCond!="">
<#assign assignCond=assignCond+",">
</#if>
<#assign assignCond=assignCond+"$"+"{activedata."+(processRole.getUDField()?lower_case)+"}">
</#if>
</#if>
</#list>
</#if>
<#if assignGroupCond!="">
<#if assignCond!="">
<#assign assignCond=assignCond+",">
</#if>
<#assign assignCond=assignCond+"$"+"{wfCoreService.getGroupUsers('"+assignGroupCond+"',execution)}">
</#if>
<userTask flowable:category="${businessKey}" flowable:candidateUsers="${assignCond}" flowable:exclusive="true" id="tid-${WFProcess.getWFStepValue()}-${WFProcess.getDeployId()}" name="${WFProcess.getName()}" <#if WFProcess.getWFProcessType()?? && (WFProcess.getWFProcessType()=="CALLORGACTIVITY" || WFProcess.getWFProcessType()=="EMBED")>flowable:formKey="${WFProcess.getWFProcessType()}"</#if>><#comment>标记子流程节点</#comment>
<documentation>${majortext}</documentation>
<#if ( ((WFProcess.getPSSysMsgTempl())!'')!='' ) || ((WFProcess.getFormCodeName())!'')!='' || ((WFProcess.getMobFormCodeName())!'')!='' >
<extensionElements>
<#if ( ((WFProcess.getPSSysMsgTempl())!'')!='' ) >
<#assign msgTempl=WFProcess.getPSSysMsgTempl()>
<flowable:formProperty id="${msgTempl.getCodeName()?lower_case}" name="${msgTempl.getName()}" variable="${assignGroupCond}" type="${WFProcess.getMsgType()}" />
</#if>
<#if ((WFProcess.getFormCodeName())!'')!='' || ((WFProcess.getMobFormCodeName())!'')!='' >
<flowable:form <#if ((WFProcess.getFormCodeName())!'')!=''>process-form="${WFProcess.getFormCodeName()}"</#if><#if ((WFProcess.getMobFormCodeName())!'')!=''> process-mobform="${WFProcess.getMobFormCodeName()}"</#if>/>
</#if>
</extensionElements>
</#if>
<#comment>多实例节点</#comment>
<#if WFProcess.getMultiInstMode?? && WFProcess.getMultiInstMode()?? && ( WFProcess.getMultiInstMode()=='PARALLEL' || WFProcess.getMultiInstMode()=='SEQUENTIAL')>
<multiInstanceLoopCharacteristics flowable:collection="candidateUsersList" flowable:elementVariable="candidateUsers" ${isSequential}>
<completionCondition><![CDATA[${nrOfCompletedInstances/nrOfInstances == 1}]]></completionCondition>
</multiInstanceLoopCharacteristics>
</#if>
</userTask>
</#if>
</#list>
</#if>
<#comment>绘制节点连线</#comment>
<#if item.getPSWFLinks?? && item.getPSWFLinks()??>
<#list item.getPSWFLinks() as WFLink>
<#assign sourceProcessId="">
<#assign targetProcessId="">
<#assign sourceProcess=WFLink.getFromPSWFProcess()>
<#assign targetProcess=WFLink.getToPSWFProcess()>
<#assign sourceProcessId="sid-"+sourceProcess.getDeployId()>
<#if sourceProcess.getWFProcessType()=='INTERACTIVE'>
<#assign sourceProcessId="tid-"+sourceProcess.getWFStepValue()+"-"+sourceProcess.getDeployId()>
</#if>
<#assign targetProcessId="sid-"+targetProcess.getDeployId()>
<#if targetProcess.getWFProcessType()=='INTERACTIVE'>
<#assign targetProcessId="tid-"+targetProcess.getWFStepValue()+"-"+targetProcess.getDeployId()>
</#if>
<#assign sourceProcessCodeName=WFLink.getFromPSWFProcess().getCodeName()>
<#assign flowId="rid-"+WFLink.getDeployId()>
<#if WFLink.getWFLinkType()!='ROUTE'>
<#assign flowId="lid-"+WFLink.getName()+"-"+WFLink.getDeployId()>
</#if>
<#assign flowTag=WFLink.getName()>
<sequenceFlow id="${flowId}" sourceRef="${sourceProcessId}" targetRef="${targetProcessId}" name="${WFLink.getLogicName()}">
<#if sourceProcessCodeName!="Start001"><#comment>连接线含有条件</#comment>
<#assign LinkCond="">
<#assign strGroupCond="">
<#if WFLink.getWFLinkType()=='ROUTE'>
<#if WFLink.getCustomCond?? && WFLink.getCustomCond()??>
<#assign LinkCond=WFLink.getCustomCond()>
<#elseif WFLink.getPSWFLinkGroupCond?? && WFLink.getPSWFLinkGroupCond()??>
<#assign WFLinkCond=WFLink.getPSWFLinkGroupCond()>
<#assign strGroupCond=getGroupCond(WFLinkCond)>
<#assign strGroupCond="$\{"+strGroupCond+"} ">
<#assign LinkCond="<![CDATA["+strGroupCond+"]]>">
</#if>
<#else>
<#assign LinkCond="<![CDATA[$\{sequenceFlowId==\""+flowId+"\"}]]>">
</#if>
<#if LinkCond!="">
<conditionExpression xsi:type="tFormalExpression" >${LinkCond}</conditionExpression>
</#if>
</#if>
<#if ((WFLink.getFormCodeName())!'')!='' || ((WFLink.getMobFormCodeName())!'')!='' || ((WFLink.getViewCodeName())!'')!='' || ((WFLink.getMobViewCodeName())!'')!='' >
<extensionElements>
<flowable:form <#if ((WFLink.getFormCodeName())!'')!=''>sequenceFlowForm="${WFLink.getFormCodeName()}"</#if><#if ((WFLink.getMobFormCodeName())!'')!=''> sequenceFlowMobForm="${WFLink.getMobFormCodeName()}"</#if><#if ((WFLink.getViewCodeName())!'')!=''> sequenceFlowView="${WFLink.getViewCodeName()}"</#if><#if ((WFLink.getMobViewCodeName())!'')!=''> sequenceFlowMobView="${WFLink.getMobViewCodeName()}"</#if>/>
</extensionElements>
</#if>
</sequenceFlow>
</#list>
</#if>
</process>
<#comment>下面定义图形位置</#comment>
<bpmndi:BPMNDiagram id="BPMNDiagram_${sys.getCodeName()?lower_case}-${item.codeName?lower_case}">
<bpmndi:BPMNPlane id="BPMNPlane_${sys.getCodeName()?lower_case}-${item.codeName?lower_case}" bpmnElement="${sys.getCodeName()?lower_case}-${item.codeName?lower_case}">
<#comment>绘制处理节点</#comment>
<#if item.getPSWFProcesses?? && item.getPSWFProcesses()??>
<#list item.getPSWFProcesses() as WFProcess>
<#assign sourceProcessId="sid-"+WFProcess.getDeployId()>
<#if WFProcess.getWFProcessType()=='INTERACTIVE'>
<#assign sourceProcessId="tid-"+WFProcess.getWFStepValue()+"-"+WFProcess.getDeployId()>
</#if>
<bpmndi:BPMNShape id="BPMNShape-${WFProcess.getDeployId()}" bpmnElement="${sourceProcessId}">
<omgdi:Bounds x="${WFProcess.getLeftPos()?c}" y="${WFProcess.getTopPos()?c}" width="${WFProcess.getWidth()?c}" height="${WFProcess.getHeight()?c}" />
</bpmndi:BPMNShape>
</#list>
</#if>
<#comment>绘制节点连线</#comment>
<#if item.getPSWFLinks?? && item.getPSWFLinks()??>
<#list item.getPSWFLinks() as WFLink>
<#assign flowId="rid-"+WFLink.getDeployId()>
<#if WFLink.getWFLinkType()!='ROUTE'>
<#assign flowId="lid-"+WFLink.getName()+"-"+WFLink.getDeployId()>
</#if>
<bpmndi:BPMNEdge id="BPMNEdge-${flowId}" bpmnElement="${flowId}">
<omgdi:waypoint x="0" y="0" />
<omgdi:waypoint x="0" y="0" />
</bpmndi:BPMNEdge>
</#list>
</#if>
</bpmndi:BPMNPlane>
</bpmndi:BPMNDiagram>
</definitions>
<#comment>获取组合条件表达式</#comment>
<#function getGroupCond WFLinkCond>
<#assign strRuleCond="(">
<#if WFLinkCond.getPSWFLinkConds()?? && WFLinkCond.getPSWFLinkConds()??><#comment>判断是否有组条件</#comment>
<#assign conn=WFLinkCond.getGroupOP()?replace("AND","&&")?replace("OR","||")>
<#list WFLinkCond.getPSWFLinkConds() as childWFLinkCond><#comment>组条件,递归</#comment>
<#assign childLinkType = childWFLinkCond.getCondType()>
<#if (childWFLinkCond.getPSWFLinkConds?? && childWFLinkCond.getPSWFLinkConds()?? ) || childLinkType=='GROUP'>
<#assign strRuleCond=strRuleCond+getGroupCond(childWFLinkCond)>//getGroupCond
<#else>
<#assign strRuleCond=strRuleCond+getFieldCond(childWFLinkCond)>//getFieldCond
</#if>
<#if childWFLinkCond_has_next>
<#assign strRuleCond=strRuleCond+conn>//拼接连接符
</#if>
</#list>
<#else>
</#if>
<#assign strRuleCond=strRuleCond+")">
<#return strRuleCond/>
</#function>
<#comment>获取单项条件表达式</#comment>
<#function getFieldCond WFLinkCond>
<#assign fieldCond="(" >
<#assign condBody="">
<#assign paramType=((WFLinkCond.getParamType())!'')><#comment>参数类型</#comment>
<#assign targetField=WFLinkCond.getFieldName()><#comment>目标属性</#comment>
<#assign targetDBValueOP=WFLinkCond.getCondOP()><#comment>表达式</#comment>
<#assign targetValue=WFLinkCond.getParamValue()><#comment>值项</#comment>
<#if targetField??>
<#assign targetField=targetField?lower_case>
<#--<#assign strTargetDBValueOP=targetDBValueOP?replace("ISNOTNULL","!= null")?replace("ISNULL","== null")?replace("AND","&&")?replace("OR","||")?replace("GT&&EQ",">=")?replace("LT&&EQ","<=")?replace("NOTEQ","!=")?replace("EQ","==")?replace("GT",">")?replace("LT","<") >-->
<#if targetDBValueOP=="ISNULL" || targetDBValueOP=="ISNOTNULL">
<#assign condBody="wfCoreService.test(activedata."+targetField+", '"+targetDBValueOP+"', null)" >
<#elseif paramType??&&paramType=='ENTITYFIELD'>
<#if targetValue??&&targetValue!="">
<#assign condBody="wfCoreService.test(activedata."+targetField+", '"+targetDBValueOP+"', activedata."+targetValue?lower_case+")" >
<#else>
<#assign condBody="wfCoreService.test(activedata."+targetField+", '"+targetDBValueOP+"', null)" >
</#if>
<#elseif paramType??&&paramType=='CURTIME'>
<#assign condBody="wfCoreService.test(activedata."+targetField+", '"+targetDBValueOP+"', wfCoreService.getnow())" >
<#else>
<#if targetValue??&&targetValue!="">
<#assign condBody="wfCoreService.test(activedata."+targetField+", '"+targetDBValueOP+"', '"+targetValue?replace("\"","")?replace("‘","")?replace("“","")?replace("”","")+"')" >
<#else>
<#assign condBody="wfCoreService.test(activedata."+targetField+", '"+targetDBValueOP+"', null)" >
</#if>
</#if>
</#if>
<#assign fieldCond=fieldCond+condBody >
<#assign fieldCond=fieldCond+")" >
<#return fieldCond/>
</#function>
...@@ -2,4 +2,4 @@ spring: ...@@ -2,4 +2,4 @@ spring:
profiles: profiles:
include: sys ,nacos, {{lowerCase api.codeName}}-prod include: sys ,nacos, {{lowerCase api.codeName}}-prod
application: application:
name: {{projectName}}-{{lowerCase api.codeName}} name: {{lowerCase system.codeName}}-{{lowerCase api.codeName}}
Markdown 格式
0% or
您添加了 0 到此讨论。请谨慎行事。
先完成此消息的编辑!
想要评论请 注册