1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
package com.iailab.module.bpm.controller.admin.task.vo.instance;
 
import cn.hutool.core.util.StrUtil;
import com.fasterxml.jackson.annotation.JsonIgnore;
import io.swagger.v3.oas.annotations.media.Schema;
import lombok.Data;
 
import javax.validation.constraints.AssertTrue;
import java.util.Map;
 
@Schema(description = "管理后台 - 审批详情 Request VO")
@Data
public class BpmApprovalDetailReqVO {
 
    @Schema(description = "流程定义的编号", example = "1024")
    private String processDefinitionId; // 使用场景:发起流程时,传流程定义 ID
 
    @Schema(description = "流程变量")
    private Map<String, Object> processVariables; // 使用场景:同 processDefinitionId,用于流程预测
 
    @Schema(description = "流程实例的编号", example = "1024")
    private String processInstanceId;  // 使用场景:流程已发起时候传流程实例 ID
 
    // TODO @芋艿:如果未来 BPMN 增加流程图,它没有发起人节点,会有问题。
    @Schema(description = "流程活动编号", example = "StartUserNode")
    private String activityId; // 用于获取表单权限。1)发起流程时,传“发起人节点” activityId 可获取发起人的表单权限;2)从抄送列表界面进来时,传抄送的 activityId 可获取抄送人的表单权限;
 
    @Schema(description = "流程任务编号", example = "95f2f08b-621b-11ef-bf39-00ff4722db8b")
    private String taskId; // 用于获取表单权限。1)从待审批/已审批界面进来时,传递 taskId 任务编号,可获取任务节点的变得权限
 
    @AssertTrue(message = "流程定义的编号和流程实例的编号不能同时为空")
    @JsonIgnore
    public boolean isValidProcessParam() {
        return StrUtil.isNotEmpty(processDefinitionId) || StrUtil.isNotEmpty(processInstanceId);
    }
 
}