From c9433fab340a766a99b2c01ca018609cac407cee Mon Sep 17 00:00:00 2001
From: yangys <y_ys79@sina.com>
Date: 星期日, 24 八月 2025 15:17:29 +0800
Subject: [PATCH] 偏离单文件名+P1
---
blade-service/blade-mdm/src/main/java/org/springblade/mdm/flow/controller/DispatchController.java | 27 +++++++++++++++++++++++----
1 files changed, 23 insertions(+), 4 deletions(-)
diff --git a/blade-service/blade-mdm/src/main/java/org/springblade/mdm/flow/controller/DispatchController.java b/blade-service/blade-mdm/src/main/java/org/springblade/mdm/flow/controller/DispatchController.java
index 5382be2..1deafdc 100644
--- a/blade-service/blade-mdm/src/main/java/org/springblade/mdm/flow/controller/DispatchController.java
+++ b/blade-service/blade-mdm/src/main/java/org/springblade/mdm/flow/controller/DispatchController.java
@@ -21,6 +21,7 @@
import org.springblade.core.tool.utils.StringUtil;
import org.springblade.mdm.flow.constants.FlowContants;
import org.springblade.mdm.flow.entity.ApproveRecord;
+import org.springblade.mdm.flow.entity.TaskDispatch;
import org.springblade.mdm.flow.excution.StartDispatcher;
import org.springblade.mdm.flow.service.ApproveRecordService;
import org.springblade.mdm.flow.service.FlowCommonService;
@@ -32,6 +33,7 @@
import org.springblade.mdm.program.entity.ProcessProgRef;
import org.springblade.mdm.program.service.NcNodeAutoCreateService;
import org.springblade.mdm.program.service.ProcessProgRefService;
+import org.springframework.beans.BeanUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
@@ -70,16 +72,33 @@
@Operation(summary = "浠诲姟璁″垝(娲惧伐娴佺▼)", description = "鍚姩娲惧伐娴佺▼")
public R<Boolean> start(@RequestBody TaskAssignVO startVO) {
try {
- long id= taskDispatchService.saveTask(startVO);
- String instId = dispatcher.start(startVO);
- taskDispatchService.updateSuccess(id,instId);
- return R.data(true);
+ TaskDispatch dispatch = taskDispatchService.saveTask(startVO);
+ boolean isDup = taskDispatchService.checkIsDuplicate(startVO);
+ if (isDup) {
+ dispatch.setStatus(TaskDispatch.STATUS_DUP);
+ taskDispatchService.updateById(dispatch);
+ return R.fail("閲嶅娲惧伐");
+ }else {
+ try {
+ String instId = dispatcher.start(startVO);
+ dispatch.setStatus(TaskDispatch.STATUS_STARTED);
+ dispatch.setProcessInstanceId(instId);
+ taskDispatchService.updateById(dispatch);
+ return R.data(true);
+ }catch (Exception e) {
+ dispatch.setStatus(TaskDispatch.STATUS_EXCEPTION);
+ taskDispatchService.updateById(dispatch);
+ return R.fail("浠诲姟鍚姩寮傚父");
+ }
+ }
+
}catch(Exception e){
return R.fail(e.getMessage());
}
}
+
AbstractFlowCompleteService getActualService(String processInstanceId){
ProcessInstance inst = runtimeService.createProcessInstanceQuery().processInstanceId(processInstanceId).includeProcessVariables().singleResult();
if(inst.getProcessDefinitionKey().equals(FlowContants.TRY_PROCESS_KEY) || inst.getProcessDefinitionKey().equals(FlowContants.CURE_PROCESS_KEY)
--
Gitblit v1.9.3