Please wait. This can take some minutes ...
Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance.
Project price only 1 $
You can buy this project and download/modify it how often you want.
com.opendynamic.ff.handler.ServiceTaskNodeHandler Maven / Gradle / Ivy
package com.opendynamic.ff.handler;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Date;
import java.util.List;
import java.util.Map;
import javax.el.ExpressionFactory;
import javax.el.ValueExpression;
import org.apache.commons.lang3.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Propagation;
import org.springframework.transaction.annotation.Transactional;
import com.opendynamic.OdUtils;
import com.opendynamic.ff.service.FfHelper;
import com.opendynamic.ff.service.FfNodeService;
import com.opendynamic.ff.service.FfService;
import com.opendynamic.ff.vo.Candidate;
import com.opendynamic.ff.vo.CandidateList;
import com.opendynamic.ff.vo.FfResult;
import com.opendynamic.ff.vo.Node;
import com.opendynamic.ff.vo.NodeDef;
import com.opendynamic.ff.vo.Proc;
import com.opendynamic.ff.vo.ProcDef;
import com.opendynamic.ff.vo.Task;
import de.odysseus.el.ExpressionFactoryImpl;
import de.odysseus.el.util.SimpleContext;
@Service
@Transactional(propagation = Propagation.REQUIRED, rollbackFor = Exception.class)
public class ServiceTaskNodeHandler implements NodeHandler {
@Autowired
private FfService ffService;
@Autowired
private FfNodeService ffNodeService;
@Autowired
private FfHelper ffHelper;
@Override
public String getNodeType() {
return FfService.NODE_TYPE_SERVICE_TASK;
}
@Override
public FfResult insertNodeByNodeDef(NodeDef nodeDef, Node branchNode, String previousNodeIds, CandidateList candidateList, String triggerOperation, String executor) {
FfResult ffResult = new FfResult();// 返回值
Proc proc = ffService.loadProc(branchNode.getProcId());
Node serviceTaskNode;
// 新增节点
String serviceTaskNodeId = OdUtils.getUuid();
ffNodeService.insertNode(serviceTaskNodeId, branchNode.getNodeId(), branchNode.getProcId(), previousNodeIds, null, branchNode.getSubProcDefId(), branchNode.getAdjustSubProcDefId(), FfService.NODE_TYPE_SERVICE_TASK, nodeDef.getNodeCode(), nodeDef.getNodeName(), nodeDef.getParentNodeCode(), nodeDef.getCandidateAssignee(), nodeDef.getCompleteExpression(), nodeDef.getCompleteReturn(), nodeDef.getExclusive(), nodeDef.getAutoCompleteSameAssignee(), nodeDef.getAutoCompleteEmptyAssignee(), nodeDef.getInform(), nodeDef.getAssignee(), nodeDef.getAction(), nodeDef.getDueDate(), nodeDef.getClaim(), nodeDef.getForwardable(), nodeDef.getPriority(), null, null, null, null, null, null, null, FfService.NODE_STATUS_ACTIVE, new Date());
serviceTaskNode = ffService.loadNode(serviceTaskNodeId);
ffResult.addCreateNode(serviceTaskNode);
// 执行服务
// 设置JUEL解析环境
Map nodeVarMap = ffService.createNodeVarQuery().setNodeId(branchNode.getNodeId()).setRecursive(true).queryForMap();// 获取节点变量
nodeVarMap.putAll(ffService.getInternalServiceMap());
nodeVarMap.putAll(ffService.getExternalServiceMap());
nodeVarMap.put("proc", proc);
nodeVarMap.put("branch", branchNode);
nodeVarMap.put("node", serviceTaskNode);
ExpressionFactory expressionFactory = new ExpressionFactoryImpl();
SimpleContext simpleContext = new SimpleContext();
for (Map.Entry entry : nodeVarMap.entrySet()) {
simpleContext.setVariable(entry.getKey(), expressionFactory.createValueExpression(entry.getValue(), Object.class));
}
// JUEL解析
ValueExpression expression = expressionFactory.createValueExpression(simpleContext, nodeDef.getAction(), String.class);
expression.getValue(simpleContext);
// 完成节点
ffResult.addAll(completeNode(serviceTaskNode, serviceTaskNode.getNodeId(), candidateList, FfService.OPERATION_INSERT, executor));
return ffResult;
}
@Override
public FfResult appendCandidate(Node node, CandidateList candidateList, String executor) {
return new FfResult();
}
@Override
public FfResult completeNode(Node node, String previousNodeIds, CandidateList candidateList, String triggerOperation, String executor) {
FfResult ffResult = new FfResult();// 返回值
if (node.getNodeStatus().equals(FfService.NODE_STATUS_COMPLETE)) {// 如已经完成,直接返回
return ffResult;
}
// 完成节点
String nodeEndUserName = ffHelper.getUserName(executor);
Date nodeEndDate = new Date();
ffNodeService.updateNodeStatus(node.getNodeId(), executor, nodeEndUserName, nodeEndDate, candidateList.toJson(), FfService.NODE_STATUS_COMPLETE);// 完成节点
node.setNodeEndUser(executor);
node.setNodeEndUserName(nodeEndUserName);
node.setNodeEndDate(nodeEndDate);
node.setNextCandidate(candidateList.toJson());
node.setNodeStatus(FfService.NODE_STATUS_COMPLETE);
ffResult.addCompleteNode(node);
// 设置JUEL解析环境
Map nodeVarMap = ffService.createNodeVarQuery().setNodeId(node.getNodeId()).setRecursive(true).queryForMap();// 获取节点变量
nodeVarMap.putAll(ffService.getInternalServiceMap());
nodeVarMap.putAll(ffService.getExternalServiceMap());
nodeVarMap.put("proc", ffService.loadProc(node.getProcId()));
nodeVarMap.put("branch", ffService.loadNode(node.getParentNodeId()));
nodeVarMap.put("node", node);
nodeVarMap.putAll(ffNodeService.getTaskStatistic(node.getNodeId()));// 获取节点任务完成信息
ExpressionFactory expressionFactory = new ExpressionFactoryImpl();
SimpleContext simpleContext = new SimpleContext();
for (Map.Entry entry : nodeVarMap.entrySet()) {
simpleContext.setVariable(entry.getKey(), expressionFactory.createValueExpression(entry.getValue(), Object.class));
}
// JUEL解析
String completeReturn = FfService.BOOLEAN_FALSE;
ValueExpression expression;
if (StringUtils.isNotEmpty(node.getCompleteReturn())) {
expression = expressionFactory.createValueExpression(simpleContext, node.getCompleteReturn(), String.class);// 判断是否满足节点完成表达式
completeReturn = (String) expression.getValue(simpleContext);
}
ProcDef procDef = ffService.getNodeProcDef(node); // 获取当前节点所属流程定义
NodeDef nodeDef = procDef.getNodeDef((node.getNodeCode()));// 获取当前节点所属节点定义
List extends NodeDef> nextNodeDefList = nodeDef.getNextNodeDefList(nodeVarMap);// 查找下一个节点定义
Node parentNode = ffService.loadNode(node.getParentNodeId());
if (nextNodeDefList.size() > 0) {// 有后续节点定义,新增后续节点。
for (NodeDef nextNodeDef : nextNodeDefList) {
ffResult.addAll(ffService.getNodeHandler(nextNodeDef.getNodeType()).insertNodeByNodeDef(nextNodeDef, parentNode, previousNodeIds, candidateList, FfService.OPERATION_COMPLETE, executor));
}
}
else// 无后续节点定义。
if (FfService.BOOLEAN_TRUE.equals(completeReturn)) {// 完成返回节点,激活前一个节点。
Node previousNode = ffService.loadNode(node.getPreviousNodeIds());// 获取前一个节点。
NodeDef previousNodeDef = ffService.getNodeProcDef(previousNode).getNodeDef((previousNode.getNodeCode()));// 获取当前节点所属节点定义
// 计算激活的办理人,为上一次该节点任务的办理人。
List taskList = ffService.createTaskQuery().setNodeId(previousNode.getNodeId()).queryForObjectList();
List assigneeList = new ArrayList<>();
for (Task task : taskList) {
assigneeList.add(task.getAssignee());
}
candidateList.add(new Candidate(ffService.getSubProcPath(previousNode), previousNode.getNodeCode(), StringUtils.join(assigneeList, ",")));
ffResult.addAll(ffService.getNodeHandler(previousNode.getNodeType()).insertNodeByNodeDef(previousNodeDef, parentNode, previousNode.getPreviousNodeIds(), candidateList, FfService.OPERATION_COMPLETE, executor));
}
else {// 非完成返回节点,递归完成上级节点。
ffResult.addAll(ffService.getNodeHandler(parentNode.getNodeType()).completeNode(parentNode, node.getNodeId(), candidateList, triggerOperation, executor));
}
return ffResult;
}
@Override
public FfResult rejectNode(Node node, CandidateList candidateList, String triggerOperation, String executor) {
return new FfResult();// 返回值
}
@Override
public FfResult activateNode(Node node, String previousNodeIds, CandidateList candidateList, String triggerOperation, String executor) {
FfResult ffResult = new FfResult();// 返回值
// 有并发子节点不能驳回
if (ffService.createNodeQuery().setParentNodeId(node.getParentNodeId()).setPreviousNodeIds(node.getPreviousNodeIds()).setNodeStatusList(Arrays.asList(FfService.NODE_STATUS_ACTIVE, FfService.NODE_STATUS_SUSPEND, FfService.NODE_STATUS_COMPLETE)).count() > 1) {
throw new RuntimeException("errors.cannotRejectInParallel");
}
Node parentNode = ffService.loadNode(node.getParentNodeId());
if (StringUtils.isNotEmpty(node.getPreviousNodeIds()) && !node.getPreviousNodeIds().equals(parentNode.getPreviousNodeIds())) {// 有前一个节点,且与上级节点的前一个节点不同,激活前一个节点。
Node previousNode;
for (String previousNodeId : node.getPreviousNodeIds().split(",")) {
previousNode = ffService.loadNode(previousNodeId);
ffResult.addAll(ffService.getNodeHandler(previousNode.getNodeType()).activateNode(previousNode, null, candidateList, FfService.OPERATION_REJECT, executor));
}
}
else {// 递归驳回上级节点
ffResult.addAll(ffService.getNodeHandler(parentNode.getNodeType()).rejectNode(parentNode, candidateList, FfService.OPERATION_ACTIVATE, executor));
}
return ffResult;
}
}