yangys
2025-07-08 c6e3205fa2003550f6edfa966635c93e614a6f43
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
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
/**
 * BladeX Commercial License Agreement
 * Copyright (c) 2018-2099, https://bladex.cn. All rights reserved.
 * <p>
 * Use of this software is governed by the Commercial License Agreement
 * obtained after purchasing a license from BladeX.
 * <p>
 * 1. This software is for development use only under a valid license
 * from BladeX.
 * <p>
 * 2. Redistribution of this software's source code to any third party
 * without a commercial license is strictly prohibited.
 * <p>
 * 3. Licensees may copyright their own code but cannot use segments
 * from this software for such purposes. Copyright of this software
 * remains with BladeX.
 * <p>
 * Using this software signifies agreement to this License, and the software
 * must not be used for illegal purposes.
 * <p>
 * THIS SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY. The author is
 * not liable for any claims arising from secondary or illegal development.
 * <p>
 * Author: Chill Zhuang (bladejava@qq.com)
 */
package org.springblade.flow.core.feign;
 
import org.springblade.core.launch.constant.AppConstant;
import org.springblade.core.tool.api.R;
import org.springblade.flow.core.pojo.entity.BladeFlow;
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestParam;
 
import java.util.Map;
 
/**
 * 工作流远程调用接口.
 *
 * @author Chill
 */
@FeignClient(
    value = AppConstant.APPLICATION_FLOW_NAME,
    fallback = IFlowClientFallback.class
)
public interface IFlowClient {
 
    String API_PREFIX = "/feign/client/flow";
    String START_PROCESS_INSTANCE_BY_ID = API_PREFIX + "/start-process-instance-by-id";
    String START_PROCESS_INSTANCE_BY_KEY = API_PREFIX + "/start-process-instance-by-key";
    String COMPLETE_TASK = API_PREFIX + "/complete-task";
    String TASK_VARIABLE = API_PREFIX + "/task-variable";
    String TASK_VARIABLES = API_PREFIX + "/task-variables";
 
    /**
     * 开启流程
     *
     * @param processDefinitionId 流程id
     * @param businessKey         业务key
     * @param variables           参数
     * @return BladeFlow
     */
    @PostMapping(START_PROCESS_INSTANCE_BY_ID)
    R<BladeFlow> startProcessInstanceById(@RequestParam("processDefinitionId") String processDefinitionId, @RequestParam("businessKey") String businessKey, @RequestBody Map<String, Object> variables);
 
    /**
     * 开启流程
     *
     * @param processDefinitionKey 流程标识
     * @param businessKey          业务key
     * @param variables            参数
     * @return BladeFlow
     */
    @PostMapping(START_PROCESS_INSTANCE_BY_KEY)
    R<BladeFlow> startProcessInstanceByKey(@RequestParam("processDefinitionKey") String processDefinitionKey, @RequestParam("businessKey") String businessKey, @RequestBody Map<String, Object> variables);
 
    /**
     * 完成任务
     *
     * @param taskId            任务id
     * @param processInstanceId 流程实例id
     * @param comment           评论
     * @param variables         参数
     * @return R
     */
    @PostMapping(COMPLETE_TASK)
    R completeTask(@RequestParam("taskId") String taskId, @RequestParam("processInstanceId") String processInstanceId, @RequestParam("comment") String comment, @RequestBody Map<String, Object> variables);
 
    /**
     * 获取流程变量
     *
     * @param taskId       任务id
     * @param variableName 变量名
     * @return R
     */
    @GetMapping(TASK_VARIABLE)
    R<Object> taskVariable(@RequestParam("taskId") String taskId, @RequestParam("variableName") String variableName);
 
    /**
     * 获取流程变量集合
     *
     * @param taskId 任务id
     * @return R
     */
    @GetMapping(TASK_VARIABLES)
    R<Map<String, Object>> taskVariables(@RequestParam("taskId") String taskId);
}