记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);
复制代码
posted @   糖醋小灰  阅读(7931)  评论(9编辑  收藏  举报
编辑推荐:
· 从 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生成工具
点击右上角即可分享
微信分享提示