| | |
| | | package com.iailab.module.bpm.framework.flowable.core.candidate; |
| | | |
| | | import com.iailab.module.bpm.framework.flowable.core.enums.BpmTaskCandidateStrategyEnum; |
| | | import org.flowable.bpmn.model.BpmnModel; |
| | | import org.flowable.engine.delegate.DelegateExecution; |
| | | |
| | | import java.util.Map; |
| | | import java.util.Set; |
| | | |
| | | /** |
| | | * BPM 任务的候选人的策略接口 |
| | | * |
| | | * <p> |
| | | * 例如说:分配审批人 |
| | | * |
| | | * @author iailab |
| | | * @author hou |
| | | */ |
| | | public interface BpmTaskCandidateStrategy { |
| | | |
| | |
| | | void validateParam(String param); |
| | | |
| | | /** |
| | | * 基于执行任务,获得任务的候选用户们 |
| | | * |
| | | * @param execution 执行任务 |
| | | * @return 用户编号集合 |
| | | */ |
| | | Set<Long> calculateUsers(DelegateExecution execution, String param); |
| | | |
| | | /** |
| | | * 是否一定要输入参数 |
| | | * |
| | | * @return 是否 |
| | |
| | | return true; |
| | | } |
| | | |
| | | /** |
| | | * 基于候选人参数,获得任务的候选用户们 |
| | | * |
| | | * 注意:实现 calculateUsers 系列方法时,有两种选择: |
| | | * 1. 只重写 calculateUsers 默认方法 |
| | | * 2. 都重写 calculateUsersByTask 和 calculateUsersByActivity 两个方法 |
| | | * |
| | | * @param param 执行任务 |
| | | * @return 用户编号集合 |
| | | */ |
| | | default Set<Long> calculateUsers(String param) { |
| | | throw new UnsupportedOperationException("该分配方法未实现,请检查!"); |
| | | } |
| | | |
| | | /** |
| | | * 基于【执行任务】,获得任务的候选用户们 |
| | | * |
| | | * @param execution 执行任务 |
| | | * @return 用户编号集合 |
| | | */ |
| | | default Set<Long> calculateUsersByTask(DelegateExecution execution, String param) { |
| | | return calculateUsers(param); |
| | | } |
| | | |
| | | /** |
| | | * 基于【流程活动】,获得任务的候选用户们 |
| | | * <p> |
| | | * 目的:用于获取未执行节点的候选用户们 |
| | | * |
| | | * @param bpmnModel 流程图 |
| | | * @param activityId 活动 ID (对应 Bpmn XML id) |
| | | * @param param 节点的参数 |
| | | * @param startUserId 流程发起人编号 |
| | | * @param processDefinitionId 流程定义编号 |
| | | * @param processVariables 流程变量 |
| | | * @return 用户编号集合 |
| | | */ |
| | | @SuppressWarnings("unused") |
| | | default Set<Long> calculateUsersByActivity(BpmnModel bpmnModel, String activityId, String param, |
| | | Long startUserId, String processDefinitionId, Map<String, Object> processVariables) { |
| | | return calculateUsers(param); |
| | | } |
| | | |
| | | } |