记camunda串行会签的使用(同节点多人顺序审批)
背景
由于流程引擎的需求较多,最近出现一个不定长的有序审批需求,之前一直做的都是最基础的流程审批,一下子被难住了,查了好多资料,大概确定方向是camunda的会签,但资料又有些欠缺。
后来在看并行会签的时候发现了这个功能,大致实现的功能是:某一个节点,可以选择多个不同的审批人,按照顺序审批下去,最后一个人审批通过则通过
绘图
绘图工具拿了Camunda Modeler,这边摘取其中一个节点作为示例。
如图,流程从发起申请开始,到达领导审批节点,领导审批节点会存在多个审批人,且需要按照顺序,若有一个人不通过,则流程返回发起申请,否则流程完结。
流程图
串行审批节点
选择如图横着的三条杠,左侧竖着的是并行
会签参数
主要参数见右侧
Collection:指集合名称(所有需要审批人的标识列表)
Element Variable:集合内的元素变量(当处于某个审批人时,该变量里存的会是当前审批人的标识)
Completion Condition:向下流转的条件(这边设置了未完成的审批=0或达成拒绝的条件时向下流转)
注意
需要注意的是,右侧的Assignee,Candidate Users,Candidate Groups依然按需填写,按照负责人/归属用户/归属组等条件查询时依然需要。
若采用Assignee的话,填写上一步中的Element Variable字段的内容,即可获取当前审批人。
会签自动生成的字段
处于会签节点时,该task会自动生成以下几个字段(可用于上述作为节点完成的判断条件),字段与任务完成时塞入的map同一层级:
nrOfInstances
实例的数目nrOfCompletedInstances
完成实例的数目nrOfActiveInstances
未完成实例的数目loopCounter
循环计数器,办理人在列表中的索引。
代码
代码逻辑与普通的流程处理无差,只是在流转到串行审批节点时,需要将Collection中的字段传入map中然后执行complete。
// 以下为流转代码 String taskId = request.getTaskId(); // 统一逻辑,获取当前process_id的下一个节点(nextNode)的分支的参数 Map<String,Object> map = taskCommonService.getBranchMap(request.getNextNode(),CommonConstans.PROCESS_ID); // 获取下一个节点的审批人列表 List<String> approverIds = taskCommonService.getApproverIds(request.getNextNode(),CommonConstans.PROCESS_ID); // 置入上述Collection中所需列表 map.put("assigneeList", approverIds); // 完成当前任务 taskSerice.complete(taskId, map);
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· winform 绘制太阳,地球,月球 运作规律
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 上周热点回顾(3.3-3.9)
· AI 智能体引爆开源社区「GitHub 热点速览」
· 写一个简单的SQL生成工具