成立单独的冀北技术监督项目
This commit is contained in:
@@ -16,7 +16,6 @@
|
|||||||
<maven.compiler.source>8</maven.compiler.source>
|
<maven.compiler.source>8</maven.compiler.source>
|
||||||
<maven.compiler.target>8</maven.compiler.target>
|
<maven.compiler.target>8</maven.compiler.target>
|
||||||
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
|
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
|
||||||
<flowable.version>6.8.0</flowable.version>
|
|
||||||
<mapstruct.version>1.5.5.Final</mapstruct.version>
|
<mapstruct.version>1.5.5.Final</mapstruct.version>
|
||||||
<easy-trans.version>2.2.11</easy-trans.version>
|
<easy-trans.version>2.2.11</easy-trans.version>
|
||||||
</properties>
|
</properties>
|
||||||
@@ -39,17 +38,7 @@
|
|||||||
<version>${project.version}</version>
|
<version>${project.version}</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<!-- Flowable 工作流相关 -->
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.flowable</groupId>
|
|
||||||
<artifactId>flowable-spring-boot-starter-process</artifactId>
|
|
||||||
<version>${flowable.version}</version>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.flowable</groupId>
|
|
||||||
<artifactId>flowable-spring-boot-starter-actuator</artifactId>
|
|
||||||
<version>${flowable.version}</version>
|
|
||||||
</dependency>
|
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.mapstruct</groupId>
|
<groupId>org.mapstruct</groupId>
|
||||||
|
|||||||
@@ -0,0 +1,30 @@
|
|||||||
|
package com.njcn.bpm.api;
|
||||||
|
|
||||||
|
import com.njcn.bpm.api.fallback.BpmProcessFeignClientFallbackFactory;
|
||||||
|
import com.njcn.bpm.pojo.dto.BpmProcessInstanceCreateReqDTO;
|
||||||
|
import com.njcn.common.pojo.constant.ServerInfo;
|
||||||
|
import com.njcn.common.pojo.response.HttpResult;
|
||||||
|
import org.springframework.cloud.openfeign.FeignClient;
|
||||||
|
import org.springframework.web.bind.annotation.PostMapping;
|
||||||
|
import org.springframework.web.bind.annotation.RequestBody;
|
||||||
|
import org.springframework.web.bind.annotation.RequestParam;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 流程实例 Api 接口
|
||||||
|
*
|
||||||
|
* @author 芋道源码
|
||||||
|
*/
|
||||||
|
@FeignClient(value = ServerInfo.SUPERVISION,path = "/process",fallbackFactory = BpmProcessFeignClientFallbackFactory.class)
|
||||||
|
public interface BpmProcessFeignClient {
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param userId 用户编号
|
||||||
|
* @param reqDTO 创建信息
|
||||||
|
* @return 实例的编号
|
||||||
|
*/
|
||||||
|
@PostMapping("/createProcessInstance")
|
||||||
|
HttpResult<String> createProcessInstance(@RequestParam("userId") String userId, @RequestBody BpmProcessInstanceCreateReqDTO reqDTO);
|
||||||
|
|
||||||
|
}
|
||||||
@@ -0,0 +1,39 @@
|
|||||||
|
package com.njcn.bpm.api.fallback;
|
||||||
|
|
||||||
|
import com.njcn.bpm.api.BpmProcessFeignClient;
|
||||||
|
import com.njcn.bpm.pojo.dto.BpmProcessInstanceCreateReqDTO;
|
||||||
|
import com.njcn.bpm.utils.BpmEnumUtil;
|
||||||
|
import com.njcn.common.pojo.enums.response.CommonResponseEnum;
|
||||||
|
import com.njcn.common.pojo.exception.BusinessException;
|
||||||
|
import com.njcn.common.pojo.response.HttpResult;
|
||||||
|
import lombok.extern.slf4j.Slf4j;
|
||||||
|
import org.springframework.stereotype.Component;
|
||||||
|
import feign.hystrix.FallbackFactory;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author denghuajun
|
||||||
|
* @version 1.0.0
|
||||||
|
* @date 2022/3/16
|
||||||
|
*/
|
||||||
|
@Slf4j
|
||||||
|
@Component
|
||||||
|
public class BpmProcessFeignClientFallbackFactory implements FallbackFactory<BpmProcessFeignClient> {
|
||||||
|
@Override
|
||||||
|
public BpmProcessFeignClient create(Throwable throwable) {
|
||||||
|
//判断抛出异常是否为解码器抛出的业务异常
|
||||||
|
Enum<?> exceptionEnum = CommonResponseEnum.SERVICE_FALLBACK;
|
||||||
|
if (throwable.getCause() instanceof BusinessException) {
|
||||||
|
BusinessException businessException = (BusinessException) throwable.getCause();
|
||||||
|
exceptionEnum = BpmEnumUtil.getExceptionEnum(businessException.getResult());
|
||||||
|
}
|
||||||
|
Enum<?> finalExceptionEnum = exceptionEnum;
|
||||||
|
return new BpmProcessFeignClient() {
|
||||||
|
@Override
|
||||||
|
public HttpResult<String> createProcessInstance(String userId, BpmProcessInstanceCreateReqDTO reqDTO) {
|
||||||
|
log.error("{}异常,降级处理,异常为:{}", "创建流程实例", throwable.toString());
|
||||||
|
throw new BusinessException(finalExceptionEnum);
|
||||||
|
}
|
||||||
|
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,38 @@
|
|||||||
|
package com.njcn.bpm.enums;
|
||||||
|
|
||||||
|
import lombok.AllArgsConstructor;
|
||||||
|
import lombok.Getter;
|
||||||
|
|
||||||
|
import java.util.Arrays;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 流程实例 ProcessInstance 的状态
|
||||||
|
*
|
||||||
|
* @author 芋道源码
|
||||||
|
*/
|
||||||
|
@Getter
|
||||||
|
@AllArgsConstructor
|
||||||
|
public enum BpmProcessInstanceStatusEnum implements IntArrayValuable {
|
||||||
|
|
||||||
|
RUNNING(1, "审批中"),
|
||||||
|
APPROVE(2, "审批通过"),
|
||||||
|
REJECT(3, "审批不通过"),
|
||||||
|
CANCEL(4, "已取消");
|
||||||
|
|
||||||
|
public static final int[] ARRAYS = Arrays.stream(values()).mapToInt(BpmProcessInstanceStatusEnum::getStatus).toArray();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 状态
|
||||||
|
*/
|
||||||
|
private final Integer status;
|
||||||
|
/**
|
||||||
|
* 描述
|
||||||
|
*/
|
||||||
|
private final String desc;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int[] array() {
|
||||||
|
return new int[0];
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
@@ -25,6 +25,10 @@ public enum BpmResponseEnum {
|
|||||||
|
|
||||||
PROCESS_DEFINITION_NOT_EXISTS("A00568","流程定义不存在"),
|
PROCESS_DEFINITION_NOT_EXISTS("A00568","流程定义不存在"),
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
PROCESS_DEFINITION_IS_SUSPENDED("A00568", "流程定义处于挂起状态"),
|
||||||
|
|
||||||
FORM_NOT_EXISTS("A00568","动态表单不存在"),
|
FORM_NOT_EXISTS("A00568","动态表单不存在"),
|
||||||
|
|
||||||
MODEL_DEPLOY_FAIL_FORM_NOT_CONFIG("A00568","部署流程失败,原因:流程表单未配置,请点击【修改流程】按钮进行配置"),
|
MODEL_DEPLOY_FAIL_FORM_NOT_CONFIG("A00568","部署流程失败,原因:流程表单未配置,请点击【修改流程】按钮进行配置"),
|
||||||
|
|||||||
@@ -0,0 +1,44 @@
|
|||||||
|
package com.njcn.bpm.pojo.dto;
|
||||||
|
|
||||||
|
import lombok.Builder;
|
||||||
|
import lombok.Data;
|
||||||
|
|
||||||
|
import javax.validation.constraints.NotEmpty;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 流程实例的创建 Request DTO
|
||||||
|
*/
|
||||||
|
@Data
|
||||||
|
public class BpmProcessInstanceCreateReqDTO {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 流程定义的标识
|
||||||
|
*/
|
||||||
|
@NotEmpty(message = "流程定义的标识不能为空")
|
||||||
|
private String processDefinitionKey;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 变量实例(动态表单)
|
||||||
|
*/
|
||||||
|
private Map<String, Object> variables;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 业务的唯一标识
|
||||||
|
*
|
||||||
|
* 例如说,请假申请的编号。通过它,可以查询到对应的实例
|
||||||
|
*/
|
||||||
|
@NotEmpty(message = "业务的唯一标识")
|
||||||
|
private String businessKey;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 发起人自选审批人 Map
|
||||||
|
*
|
||||||
|
* key:taskKey 任务编码
|
||||||
|
* value:审批人的数组
|
||||||
|
* 例如:{ taskKey1 :[1, 2] },则表示 taskKey1 这个任务,提前设定了,由 userId 为 1,2 的用户进行审批
|
||||||
|
*/
|
||||||
|
private Map<String, List<String>> startUserSelectAssignees;
|
||||||
|
|
||||||
|
}
|
||||||
@@ -44,9 +44,10 @@ public class BpmModelParam implements Serializable {
|
|||||||
|
|
||||||
private Integer formType = 10;
|
private Integer formType = 10;
|
||||||
|
|
||||||
|
@ApiModelProperty("表单提交路由")
|
||||||
private String formCustomCreatePath;
|
private String formCustomCreatePath;
|
||||||
|
|
||||||
|
@ApiModelProperty("表单查看路由")
|
||||||
private String formCustomViewPath;
|
private String formCustomViewPath;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@@ -15,7 +15,7 @@ import java.util.Objects;
|
|||||||
* @version 1.0.0
|
* @version 1.0.0
|
||||||
* @date 2021年12月20日 10:03
|
* @date 2021年12月20日 10:03
|
||||||
*/
|
*/
|
||||||
public class ProcessEnumUtil {
|
public class BpmEnumUtil {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取HarmonicResponseEnum实例
|
* 获取HarmonicResponseEnum实例
|
||||||
@@ -15,6 +15,7 @@
|
|||||||
<maven.compiler.source>8</maven.compiler.source>
|
<maven.compiler.source>8</maven.compiler.source>
|
||||||
<maven.compiler.target>8</maven.compiler.target>
|
<maven.compiler.target>8</maven.compiler.target>
|
||||||
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
|
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
|
||||||
|
<flowable.version>6.8.0</flowable.version>
|
||||||
</properties>
|
</properties>
|
||||||
|
|
||||||
<dependencies>
|
<dependencies>
|
||||||
@@ -37,6 +38,18 @@
|
|||||||
<version>${project.version}</version>
|
<version>${project.version}</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
|
<!-- Flowable 工作流相关 -->
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.flowable</groupId>
|
||||||
|
<artifactId>flowable-spring-boot-starter-process</artifactId>
|
||||||
|
<version>${flowable.version}</version>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.flowable</groupId>
|
||||||
|
<artifactId>flowable-spring-boot-starter-actuator</artifactId>
|
||||||
|
<version>${flowable.version}</version>
|
||||||
|
</dependency>
|
||||||
|
|
||||||
</dependencies>
|
</dependencies>
|
||||||
|
|
||||||
<build>
|
<build>
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
package com.njcn.bpm.enums;
|
package com.njcn.bpm.constant;
|
||||||
|
|
||||||
import org.flowable.engine.runtime.ProcessInstance;
|
import org.flowable.engine.runtime.ProcessInstance;
|
||||||
|
|
||||||
@@ -2,6 +2,7 @@ package com.njcn.bpm.controller;
|
|||||||
|
|
||||||
import cn.hutool.core.collection.CollUtil;
|
import cn.hutool.core.collection.CollUtil;
|
||||||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||||
|
import com.njcn.bpm.pojo.dto.BpmProcessInstanceCreateReqDTO;
|
||||||
import com.njcn.bpm.pojo.param.BpmProcessDefinitionInfoParam;
|
import com.njcn.bpm.pojo.param.BpmProcessDefinitionInfoParam;
|
||||||
import com.njcn.bpm.pojo.po.BpmCategory;
|
import com.njcn.bpm.pojo.po.BpmCategory;
|
||||||
import com.njcn.bpm.pojo.po.BpmForm;
|
import com.njcn.bpm.pojo.po.BpmForm;
|
||||||
@@ -10,9 +11,11 @@ import com.njcn.bpm.pojo.vo.BpmProcessDefinitionInfoVO;
|
|||||||
import com.njcn.bpm.service.IBpmCategoryService;
|
import com.njcn.bpm.service.IBpmCategoryService;
|
||||||
import com.njcn.bpm.service.IBpmFormService;
|
import com.njcn.bpm.service.IBpmFormService;
|
||||||
import com.njcn.bpm.service.IBpmProcessDefinitionService;
|
import com.njcn.bpm.service.IBpmProcessDefinitionService;
|
||||||
|
import com.njcn.bpm.service.task.IBpmProcessInstanceService;
|
||||||
import com.njcn.bpm.strategy.BpmTaskCandidateStartUserSelectStrategy;
|
import com.njcn.bpm.strategy.BpmTaskCandidateStartUserSelectStrategy;
|
||||||
import com.njcn.bpm.utils.BpmProcessDefinitionConvert;
|
import com.njcn.bpm.utils.BpmProcessDefinitionConvert;
|
||||||
import com.njcn.common.pojo.annotation.OperateInfo;
|
import com.njcn.common.pojo.annotation.OperateInfo;
|
||||||
|
import com.njcn.common.pojo.constant.OperateType;
|
||||||
import com.njcn.common.pojo.enums.common.LogEnum;
|
import com.njcn.common.pojo.enums.common.LogEnum;
|
||||||
import com.njcn.common.pojo.enums.response.CommonResponseEnum;
|
import com.njcn.common.pojo.enums.response.CommonResponseEnum;
|
||||||
import com.njcn.common.pojo.response.HttpResult;
|
import com.njcn.common.pojo.response.HttpResult;
|
||||||
@@ -54,6 +57,8 @@ public class BpmProcessDefinitionController extends BaseController {
|
|||||||
|
|
||||||
private final IBpmCategoryService categoryService;
|
private final IBpmCategoryService categoryService;
|
||||||
|
|
||||||
|
private final IBpmProcessInstanceService processInstanceService;
|
||||||
|
|
||||||
@OperateInfo(info = LogEnum.BUSINESS_COMMON)
|
@OperateInfo(info = LogEnum.BUSINESS_COMMON)
|
||||||
@PostMapping("/page")
|
@PostMapping("/page")
|
||||||
@ApiOperation("获得流程定义分页")
|
@ApiOperation("获得流程定义分页")
|
||||||
@@ -120,4 +125,13 @@ public class BpmProcessDefinitionController extends BaseController {
|
|||||||
processDefinition, null, null, null, null, bpmnModel, userTaskList), methodDescribe);
|
processDefinition, null, null, null, null, bpmnModel, userTaskList), methodDescribe);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@OperateInfo(info = LogEnum.BUSINESS_COMMON, operateType = OperateType.ADD)
|
||||||
|
@ApiOperation("创建流程实例")
|
||||||
|
@PostMapping("/createProcessInstance")
|
||||||
|
HttpResult<String> createProcessInstance(@RequestParam("userId") String userId, @RequestBody BpmProcessInstanceCreateReqDTO reqDTO){
|
||||||
|
String methodDescribe = getMethodDescribe("createProcessInstance");
|
||||||
|
String instanceId = processInstanceService.createProcessInstance(userId, reqDTO);
|
||||||
|
return HttpResultUtil.assembleCommonResponseResult(CommonResponseEnum.SUCCESS, instanceId, methodDescribe);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -50,11 +50,11 @@ public interface IBpmCategoryService extends IService<BpmCategory> {
|
|||||||
/**
|
/**
|
||||||
* 获得流程分类 Map,基于指定编码
|
* 获得流程分类 Map,基于指定编码
|
||||||
*
|
*
|
||||||
* @param codes 编号数组
|
* @param ids 编号数组
|
||||||
* @return 流程分类 Map
|
* @return 流程分类 Map
|
||||||
*/
|
*/
|
||||||
default Map<String, BpmCategory> getCategoryMap(Collection<String> codes) {
|
default Map<String, BpmCategory> getCategoryMap(Collection<String> ids) {
|
||||||
return convertMap(getCategoryListByCode(codes), BpmCategory::getCode);
|
return convertMap(getCategoryListById(ids), BpmCategory::getId);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -62,7 +62,7 @@ public interface IBpmCategoryService extends IService<BpmCategory> {
|
|||||||
*
|
*
|
||||||
* @return 流程分类列表
|
* @return 流程分类列表
|
||||||
*/
|
*/
|
||||||
List<BpmCategory> getCategoryListByCode(Collection<String> codes);
|
List<BpmCategory> getCategoryListById(Collection<String> codes);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -83,12 +83,12 @@ public class BpmCategoryServiceImpl extends ServiceImpl<BpmCategoryMapper, BpmCa
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public List<BpmCategory> getCategoryListByCode(Collection<String> codes) {
|
public List<BpmCategory> getCategoryListById(Collection<String> ids) {
|
||||||
if (CollUtil.isEmpty(codes)) {
|
if (CollUtil.isEmpty(ids)) {
|
||||||
return Collections.emptyList();
|
return Collections.emptyList();
|
||||||
}
|
}
|
||||||
LambdaQueryWrapper<BpmCategory> lambdaQueryWrapper = new LambdaQueryWrapper<>();
|
LambdaQueryWrapper<BpmCategory> lambdaQueryWrapper = new LambdaQueryWrapper<>();
|
||||||
lambdaQueryWrapper.in(BpmCategory::getCode,codes);
|
lambdaQueryWrapper.in(BpmCategory::getId,ids);
|
||||||
return this.baseMapper.selectList(lambdaQueryWrapper);
|
return this.baseMapper.selectList(lambdaQueryWrapper);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -1,5 +1,6 @@
|
|||||||
package com.njcn.bpm.service.task;
|
package com.njcn.bpm.service.task;
|
||||||
|
|
||||||
|
import com.njcn.bpm.pojo.dto.BpmProcessInstanceCreateReqDTO;
|
||||||
import org.flowable.engine.delegate.event.FlowableCancelledEvent;
|
import org.flowable.engine.delegate.event.FlowableCancelledEvent;
|
||||||
import org.flowable.engine.history.HistoricProcessInstance;
|
import org.flowable.engine.history.HistoricProcessInstance;
|
||||||
import org.flowable.engine.runtime.ProcessInstance;
|
import org.flowable.engine.runtime.ProcessInstance;
|
||||||
@@ -26,6 +27,18 @@ public interface IBpmProcessInstanceService {
|
|||||||
* @return 流程实例
|
* @return 流程实例
|
||||||
*/
|
*/
|
||||||
ProcessInstance getProcessInstance(String id);
|
ProcessInstance getProcessInstance(String id);
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 创建流程实例(提供给内部)
|
||||||
|
*
|
||||||
|
* @param userId 用户编号
|
||||||
|
* @param createReqDTO 创建信息
|
||||||
|
* @return 实例的编号
|
||||||
|
*/
|
||||||
|
String createProcessInstance(String userId, BpmProcessInstanceCreateReqDTO createReqDTO);
|
||||||
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// /**
|
// /**
|
||||||
// * 获得流程实例列表
|
// * 获得流程实例列表
|
||||||
@@ -89,14 +102,7 @@ public interface IBpmProcessInstanceService {
|
|||||||
// */
|
// */
|
||||||
// String createProcessInstance(Long userId, @Valid BpmProcessInstanceCreateReqVO createReqVO);
|
// String createProcessInstance(Long userId, @Valid BpmProcessInstanceCreateReqVO createReqVO);
|
||||||
//
|
//
|
||||||
// /**
|
|
||||||
// * 创建流程实例(提供给内部)
|
|
||||||
// *
|
|
||||||
// * @param userId 用户编号
|
|
||||||
// * @param createReqDTO 创建信息
|
|
||||||
// * @return 实例的编号
|
|
||||||
// */
|
|
||||||
// String createProcessInstance(Long userId, @Valid BpmProcessInstanceCreateReqDTO createReqDTO);
|
|
||||||
//
|
//
|
||||||
// /**
|
// /**
|
||||||
// * 发起人取消流程实例
|
// * 发起人取消流程实例
|
||||||
|
|||||||
@@ -1,22 +1,27 @@
|
|||||||
package com.njcn.bpm.service.task.impl;
|
package com.njcn.bpm.service.task.impl;
|
||||||
|
|
||||||
import cn.hutool.core.collection.CollUtil;
|
import cn.hutool.core.collection.CollUtil;
|
||||||
import cn.hutool.core.util.ArrayUtil;
|
import com.njcn.bpm.constant.BpmConstants;
|
||||||
import cn.hutool.core.util.StrUtil;
|
import com.njcn.bpm.enums.BpmProcessInstanceStatusEnum;
|
||||||
|
import com.njcn.bpm.enums.BpmResponseEnum;
|
||||||
|
import com.njcn.bpm.pojo.dto.BpmProcessInstanceCreateReqDTO;
|
||||||
|
import com.njcn.bpm.service.IBpmProcessDefinitionService;
|
||||||
import com.njcn.bpm.service.task.IBpmProcessInstanceService;
|
import com.njcn.bpm.service.task.IBpmProcessInstanceService;
|
||||||
|
import com.njcn.bpm.strategy.BpmTaskCandidateStartUserSelectStrategy;
|
||||||
|
import com.njcn.bpm.utils.CollectionUtils;
|
||||||
|
import com.njcn.common.pojo.exception.BusinessException;
|
||||||
|
import com.njcn.user.api.UserFeignClient;
|
||||||
|
import com.njcn.user.pojo.po.User;
|
||||||
import lombok.extern.slf4j.Slf4j;
|
import lombok.extern.slf4j.Slf4j;
|
||||||
import org.flowable.bpmn.model.BpmnModel;
|
import org.flowable.bpmn.model.BpmnModel;
|
||||||
import org.flowable.bpmn.model.UserTask;
|
import org.flowable.bpmn.model.UserTask;
|
||||||
import org.flowable.engine.HistoryService;
|
import org.flowable.engine.HistoryService;
|
||||||
import org.flowable.engine.RuntimeService;
|
import org.flowable.engine.RuntimeService;
|
||||||
import org.flowable.engine.delegate.event.FlowableCancelledEvent;
|
|
||||||
import org.flowable.engine.history.HistoricProcessInstance;
|
|
||||||
import org.flowable.engine.history.HistoricProcessInstanceQuery;
|
|
||||||
import org.flowable.engine.repository.ProcessDefinition;
|
import org.flowable.engine.repository.ProcessDefinition;
|
||||||
import org.flowable.engine.runtime.ProcessInstance;
|
import org.flowable.engine.runtime.ProcessInstance;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
import org.springframework.transaction.annotation.Transactional;
|
|
||||||
import org.springframework.validation.annotation.Validated;
|
import org.springframework.validation.annotation.Validated;
|
||||||
|
import com.njcn.bpm.utils.FlowableUtils;
|
||||||
|
|
||||||
import javax.annotation.Resource;
|
import javax.annotation.Resource;
|
||||||
import javax.validation.Valid;
|
import javax.validation.Valid;
|
||||||
@@ -25,13 +30,13 @@ import java.util.*;
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* 流程实例 Service 实现类
|
* 流程实例 Service 实现类
|
||||||
*
|
* <p>
|
||||||
* ProcessDefinition & ProcessInstance & Execution & Task 的关系:
|
* ProcessDefinition & ProcessInstance & Execution & Task 的关系:
|
||||||
* 1. <a href="https://blog.csdn.net/bobozai86/article/details/105210414" />
|
* 1. <a href="https://blog.csdn.net/bobozai86/article/details/105210414" />
|
||||||
*
|
* <p>
|
||||||
* HistoricProcessInstance & ProcessInstance 的关系:
|
* HistoricProcessInstance & ProcessInstance 的关系:
|
||||||
* 1. <a href=" https://my.oschina.net/843294669/blog/71902" />
|
* 1. <a href=" https://my.oschina.net/843294669/blog/71902" />
|
||||||
*
|
* <p>
|
||||||
* 简单来说,前者 = 历史 + 运行中的流程实例,后者仅是运行中的流程实例
|
* 简单来说,前者 = 历史 + 运行中的流程实例,后者仅是运行中的流程实例
|
||||||
*
|
*
|
||||||
* @author 芋道源码
|
* @author 芋道源码
|
||||||
@@ -43,16 +48,18 @@ public class BpmProcessInstanceServiceImpl implements IBpmProcessInstanceService
|
|||||||
|
|
||||||
@Resource
|
@Resource
|
||||||
private RuntimeService runtimeService;
|
private RuntimeService runtimeService;
|
||||||
|
|
||||||
@Resource
|
@Resource
|
||||||
private HistoryService historyService;
|
private HistoryService historyService;
|
||||||
|
|
||||||
// @Resource
|
@Resource
|
||||||
// private BpmProcessDefinitionService processDefinitionService;
|
private IBpmProcessDefinitionService processDefinitionService;
|
||||||
|
|
||||||
// @Resource
|
// @Resource
|
||||||
// private BpmMessageService messageService;
|
// private BpmMessageService messageService;
|
||||||
//
|
//
|
||||||
// @Resource
|
@Resource
|
||||||
// private AdminUserApi adminUserApi;
|
private UserFeignClient userFeignClient;
|
||||||
//
|
//
|
||||||
// @Resource
|
// @Resource
|
||||||
// private BpmProcessInstanceEventPublisher processInstanceEventPublisher;
|
// private BpmProcessInstanceEventPublisher processInstanceEventPublisher;
|
||||||
@@ -64,6 +71,8 @@ public class BpmProcessInstanceServiceImpl implements IBpmProcessInstanceService
|
|||||||
.processInstanceId(id)
|
.processInstanceId(id)
|
||||||
.singleResult();
|
.singleResult();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// @Override
|
// @Override
|
||||||
// public List<ProcessInstance> getProcessInstances(Set<String> ids) {
|
// public List<ProcessInstance> getProcessInstances(Set<String> ids) {
|
||||||
@@ -128,70 +137,72 @@ public class BpmProcessInstanceServiceImpl implements IBpmProcessInstanceService
|
|||||||
// return createProcessInstance0(userId, definition, createReqVO.getVariables(), null,
|
// return createProcessInstance0(userId, definition, createReqVO.getVariables(), null,
|
||||||
// createReqVO.getStartUserSelectAssignees());
|
// createReqVO.getStartUserSelectAssignees());
|
||||||
// }
|
// }
|
||||||
//
|
|
||||||
// @Override
|
@Override
|
||||||
// public String createProcessInstance(Long userId, @Valid BpmProcessInstanceCreateReqDTO createReqDTO) {
|
public String createProcessInstance(String userId, @Valid BpmProcessInstanceCreateReqDTO createReqDTO) {
|
||||||
// // 获得流程定义
|
// 获得流程定义
|
||||||
// ProcessDefinition definition = processDefinitionService.getActiveProcessDefinition(createReqDTO.getProcessDefinitionKey());
|
ProcessDefinition definition = processDefinitionService.getActiveProcessDefinition(createReqDTO.getProcessDefinitionKey());
|
||||||
// // 发起流程
|
// 发起流程
|
||||||
// return createProcessInstance0(userId, definition, createReqDTO.getVariables(), createReqDTO.getBusinessKey(),
|
return createProcessInstance(userId, definition, createReqDTO.getVariables(), createReqDTO.getBusinessKey(),
|
||||||
// createReqDTO.getStartUserSelectAssignees());
|
createReqDTO.getStartUserSelectAssignees());
|
||||||
// }
|
}
|
||||||
//
|
|
||||||
// private String createProcessInstance0(Long userId, ProcessDefinition definition,
|
private String createProcessInstance(String userId, ProcessDefinition definition,
|
||||||
// Map<String, Object> variables, String businessKey,
|
Map<String, Object> variables, String businessKey,
|
||||||
// Map<String, List<Long>> startUserSelectAssignees) {
|
Map<String, List<String>> startUserSelectAssignees) {
|
||||||
// // 1.1 校验流程定义
|
// 1.1 校验流程定义
|
||||||
// if (definition == null) {
|
if (definition == null) {
|
||||||
// throw exception(PROCESS_DEFINITION_NOT_EXISTS);
|
throw new BusinessException(BpmResponseEnum.PROCESS_DEFINITION_NOT_EXISTS);
|
||||||
// }
|
}
|
||||||
// if (definition.isSuspended()) {
|
if (definition.isSuspended()) {
|
||||||
// throw exception(PROCESS_DEFINITION_IS_SUSPENDED);
|
throw new BusinessException(BpmResponseEnum.PROCESS_DEFINITION_IS_SUSPENDED);
|
||||||
// }
|
}
|
||||||
// // 1.2 校验发起人自选审批人
|
|
||||||
// validateStartUserSelectAssignees(definition, startUserSelectAssignees);
|
// 1.2 校验发起人自选审批人
|
||||||
//
|
validateStartUserSelectAssignees(definition, startUserSelectAssignees);
|
||||||
// // 2. 创建流程实例
|
|
||||||
// if (variables == null) {
|
// 2. 创建流程实例
|
||||||
// variables = new HashMap<>();
|
if (variables == null) {
|
||||||
// }
|
variables = new HashMap<>();
|
||||||
// FlowableUtils.filterProcessInstanceFormVariable(variables); // 过滤一下,避免 ProcessInstance 系统级的变量被占用
|
}
|
||||||
// variables.put(BpmConstants.PROCESS_INSTANCE_VARIABLE_STATUS, // 流程实例状态:审批中
|
FlowableUtils.filterProcessInstanceFormVariable(variables); // 过滤一下,避免 ProcessInstance 系统级的变量被占用
|
||||||
// BpmProcessInstanceStatusEnum.RUNNING.getStatus());
|
variables.put(BpmConstants.PROCESS_INSTANCE_VARIABLE_STATUS, // 流程实例状态:审批中
|
||||||
// if (CollUtil.isNotEmpty(startUserSelectAssignees)) {
|
BpmProcessInstanceStatusEnum.RUNNING.getStatus());
|
||||||
// variables.put(BpmConstants.PROCESS_INSTANCE_VARIABLE_START_USER_SELECT_ASSIGNEES, startUserSelectAssignees);
|
if (CollUtil.isNotEmpty(startUserSelectAssignees)) {
|
||||||
// }
|
variables.put(BpmConstants.PROCESS_INSTANCE_VARIABLE_START_USER_SELECT_ASSIGNEES, startUserSelectAssignees);
|
||||||
// ProcessInstance instance = runtimeService.createProcessInstanceBuilder()
|
}
|
||||||
// .processDefinitionId(definition.getId())
|
ProcessInstance instance = runtimeService.createProcessInstanceBuilder()
|
||||||
// .businessKey(businessKey)
|
.processDefinitionId(definition.getId())
|
||||||
// .name(definition.getName().trim())
|
.businessKey(businessKey)
|
||||||
// .variables(variables)
|
.name(definition.getName().trim())
|
||||||
// .start();
|
.variables(variables)
|
||||||
// return instance.getId();
|
.start();
|
||||||
// }
|
return instance.getId();
|
||||||
//
|
}
|
||||||
// private void validateStartUserSelectAssignees(ProcessDefinition definition, Map<String, List<Long>> startUserSelectAssignees) {
|
|
||||||
// // 1. 获得发起人自选审批人的 UserTask 列表
|
private void validateStartUserSelectAssignees(ProcessDefinition definition, Map<String, List<String>> startUserSelectAssignees) {
|
||||||
// BpmnModel bpmnModel = processDefinitionService.getProcessDefinitionBpmnModel(definition.getId());
|
// 1. 获得发起人自选审批人的 UserTask 列表
|
||||||
// List<UserTask> userTaskList = BpmTaskCandidateStartUserSelectStrategy.getStartUserSelectUserTaskList(bpmnModel);
|
BpmnModel bpmnModel = processDefinitionService.getProcessDefinitionBpmnModel(definition.getId());
|
||||||
// if (CollUtil.isEmpty(userTaskList)) {
|
List<UserTask> userTaskList = BpmTaskCandidateStartUserSelectStrategy.getStartUserSelectUserTaskList(bpmnModel);
|
||||||
// return;
|
if (CollUtil.isEmpty(userTaskList)) {
|
||||||
// }
|
return;
|
||||||
//
|
}
|
||||||
// // 2. 校验发起人自选审批人的 UserTask 是否都配置了
|
|
||||||
// userTaskList.forEach(userTask -> {
|
// 2. 校验发起人自选审批人的 UserTask 是否都配置了
|
||||||
// List<Long> assignees = startUserSelectAssignees != null ? startUserSelectAssignees.get(userTask.getId()) : null;
|
userTaskList.forEach(userTask -> {
|
||||||
// if (CollUtil.isEmpty(assignees)) {
|
List<String> assignees = startUserSelectAssignees != null ? startUserSelectAssignees.get(userTask.getId()) : null;
|
||||||
// throw exception(PROCESS_INSTANCE_START_USER_SELECT_ASSIGNEES_NOT_CONFIG, userTask.getName());
|
if (CollUtil.isEmpty(assignees)) {
|
||||||
// }
|
throw new BusinessException("审批任务(" + userTask.getName() + ")的审批人未配置");
|
||||||
// Map<Long, AdminUserRespDTO> userMap = adminUserApi.getUserMap(assignees);
|
}
|
||||||
// assignees.forEach(assignee -> {
|
List<User> userList = userFeignClient.getUserByIdList(assignees).getData();
|
||||||
// if (userMap.get(assignee) == null) {
|
Map<String, User> userMap = CollectionUtils.convertMap(userList, User::getId);
|
||||||
// throw exception(PROCESS_INSTANCE_START_USER_SELECT_ASSIGNEES_NOT_EXISTS, userTask.getName(), assignee);
|
assignees.forEach(assignee -> {
|
||||||
// }
|
if (userMap.get(assignee) == null) {
|
||||||
// });
|
throw new BusinessException("审批任务(" + userTask.getName() + ")的审批人(" + assignee + ")不存在");
|
||||||
// });
|
}
|
||||||
// }
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
//
|
//
|
||||||
// @Override
|
// @Override
|
||||||
// public void cancelProcessInstanceByStartUser(Long userId, @Valid BpmProcessInstanceCancelReqVO cancelReqVO) {
|
// public void cancelProcessInstanceByStartUser(Long userId, @Valid BpmProcessInstanceCancelReqVO cancelReqVO) {
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
package com.njcn.bpm.utils;
|
package com.njcn.bpm.utils;
|
||||||
|
|
||||||
import com.njcn.bpm.enums.BpmConstants;
|
import com.njcn.bpm.constant.BpmConstants;
|
||||||
import org.flowable.common.engine.api.delegate.Expression;
|
import org.flowable.common.engine.api.delegate.Expression;
|
||||||
import org.flowable.common.engine.api.variable.VariableContainer;
|
import org.flowable.common.engine.api.variable.VariableContainer;
|
||||||
import org.flowable.common.engine.impl.el.ExpressionManager;
|
import org.flowable.common.engine.impl.el.ExpressionManager;
|
||||||
|
|||||||
@@ -15,6 +15,7 @@ public interface ServerInfo {
|
|||||||
String COMMON = "pqs-common";
|
String COMMON = "pqs-common";
|
||||||
String DEVICE = "device-boot";
|
String DEVICE = "device-boot";
|
||||||
String EVENT = "event-boot";
|
String EVENT = "event-boot";
|
||||||
|
String SUPERVISION = "supervision-boot";
|
||||||
String HARMONIC = "harmonic-boot";
|
String HARMONIC = "harmonic-boot";
|
||||||
String REPORT = "report-boot";
|
String REPORT = "report-boot";
|
||||||
String SYSTEM = "system-boot";
|
String SYSTEM = "system-boot";
|
||||||
|
|||||||
@@ -0,0 +1,46 @@
|
|||||||
|
package com.njcn.supervision.enums;
|
||||||
|
|
||||||
|
import lombok.Getter;
|
||||||
|
|
||||||
|
import java.util.Objects;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 流程审批状态
|
||||||
|
*/
|
||||||
|
@Getter
|
||||||
|
public enum FlowStatusEnum {
|
||||||
|
|
||||||
|
AUDIT(1, "审批中"),
|
||||||
|
APPROVE(2, "审批通过"),
|
||||||
|
OPPOSE(3, "审批不通过"),
|
||||||
|
CANCEL(4, "已取消");
|
||||||
|
|
||||||
|
private final Integer code;
|
||||||
|
|
||||||
|
private final String name;
|
||||||
|
|
||||||
|
FlowStatusEnum(Integer code, String name) {
|
||||||
|
this.code = code;
|
||||||
|
this.name = name;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public static String getNameByCode(Integer code) {
|
||||||
|
for (FlowStatusEnum userNatureEnum : FlowStatusEnum.values()) {
|
||||||
|
if (Objects.equals(userNatureEnum.code, code)) {
|
||||||
|
return userNatureEnum.name;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public static Integer getCodeByName(String name) {
|
||||||
|
for (FlowStatusEnum userNatureEnum : FlowStatusEnum.values()) {
|
||||||
|
if (userNatureEnum.name.equalsIgnoreCase(name)) {
|
||||||
|
return userNatureEnum.code;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,28 @@
|
|||||||
|
package com.njcn.supervision.enums;
|
||||||
|
|
||||||
|
import lombok.Getter;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 技术监督用户状态枚举
|
||||||
|
*/
|
||||||
|
@Getter
|
||||||
|
public enum SupervisionUserStatusEnum {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 技术监督用户状态:可研/建设/运行/退运
|
||||||
|
*/
|
||||||
|
RESEARCH(0, "可研"),
|
||||||
|
BUILD(1, "建设"),
|
||||||
|
PRODUCT(2, "运行"),
|
||||||
|
QUIT(3, "退运");
|
||||||
|
|
||||||
|
private final int code;
|
||||||
|
|
||||||
|
private final String message;
|
||||||
|
|
||||||
|
SupervisionUserStatusEnum(int code, String message) {
|
||||||
|
this.code=code;
|
||||||
|
this.message=message;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
@@ -0,0 +1,49 @@
|
|||||||
|
package com.njcn.supervision.enums;
|
||||||
|
|
||||||
|
import lombok.Getter;
|
||||||
|
|
||||||
|
import java.util.Objects;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 用户性质枚举
|
||||||
|
*/
|
||||||
|
@Getter
|
||||||
|
public enum UserNatureEnum {
|
||||||
|
|
||||||
|
BUILD_POWER_GRID(0, "新建电网工程"),
|
||||||
|
EXTEND_POWER_GRID(1, "扩建电网工程"),
|
||||||
|
BUILD_NON_LINEAR_LOAD(2, "新建非线性负荷用户"),
|
||||||
|
EXTEND_NON_LINEAR_LOAD(3, "扩建非线性负荷用户"),
|
||||||
|
BUILD_NEW_ENERGY_POWER_STATION(4, "新建新能源发电站"),
|
||||||
|
EXTEND_NEW_ENERGY_POWER_STATION(5, "扩建新能源发电站"),
|
||||||
|
SENSITIVE_USER(6, "敏感及重要用户");
|
||||||
|
|
||||||
|
private final Integer code;
|
||||||
|
|
||||||
|
private final String name;
|
||||||
|
|
||||||
|
UserNatureEnum(Integer code, String name) {
|
||||||
|
this.code = code;
|
||||||
|
this.name = name;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public static String getNameByCode(Integer code) {
|
||||||
|
for (UserNatureEnum userNatureEnum : UserNatureEnum.values()) {
|
||||||
|
if (Objects.equals(userNatureEnum.code, code)) {
|
||||||
|
return userNatureEnum.name;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public static Integer getCodeByName(String name) {
|
||||||
|
for (UserNatureEnum userNatureEnum : UserNatureEnum.values()) {
|
||||||
|
if (userNatureEnum.name.equalsIgnoreCase(name)) {
|
||||||
|
return userNatureEnum.code;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -7,12 +7,15 @@ import com.njcn.supervision.pojo.po.user.UserReportSensitivePO;
|
|||||||
import com.njcn.supervision.pojo.po.user.UserReportSubstationPO;
|
import com.njcn.supervision.pojo.po.user.UserReportSubstationPO;
|
||||||
import com.njcn.web.pojo.param.BaseParam;
|
import com.njcn.web.pojo.param.BaseParam;
|
||||||
import io.swagger.annotations.ApiModelProperty;
|
import io.swagger.annotations.ApiModelProperty;
|
||||||
|
import io.swagger.v3.oas.annotations.media.Schema;
|
||||||
import lombok.AllArgsConstructor;
|
import lombok.AllArgsConstructor;
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
import lombok.EqualsAndHashCode;
|
import lombok.EqualsAndHashCode;
|
||||||
import lombok.NoArgsConstructor;
|
import lombok.NoArgsConstructor;
|
||||||
|
|
||||||
import java.time.LocalDate;
|
import java.time.LocalDate;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
@@ -58,7 +61,7 @@ public class UserReportParam extends BaseEntity {
|
|||||||
* 用户性质
|
* 用户性质
|
||||||
*/
|
*/
|
||||||
@ApiModelProperty(value = "用户性质")
|
@ApiModelProperty(value = "用户性质")
|
||||||
private String userType;
|
private Integer userType;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 所属地市
|
* 所属地市
|
||||||
@@ -76,7 +79,7 @@ public class UserReportParam extends BaseEntity {
|
|||||||
* 用户状态
|
* 用户状态
|
||||||
*/
|
*/
|
||||||
@ApiModelProperty(value = "用户状态")
|
@ApiModelProperty(value = "用户状态")
|
||||||
private String userStatus;
|
private Integer userStatus;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 变电站
|
* 变电站
|
||||||
@@ -108,6 +111,9 @@ public class UserReportParam extends BaseEntity {
|
|||||||
@ApiModelProperty(value = "预测评估结论")
|
@ApiModelProperty(value = "预测评估结论")
|
||||||
private String evaluationConclusion;
|
private String evaluationConclusion;
|
||||||
|
|
||||||
|
@ApiModelProperty("发起人自选审批人 Map")
|
||||||
|
private Map<String, List<String>> startUserSelectAssignees;
|
||||||
|
|
||||||
|
|
||||||
private UserReportProjectPO userReportProjectPO;
|
private UserReportProjectPO userReportProjectPO;
|
||||||
|
|
||||||
@@ -117,7 +123,9 @@ public class UserReportParam extends BaseEntity {
|
|||||||
|
|
||||||
|
|
||||||
@Data
|
@Data
|
||||||
|
@EqualsAndHashCode(callSuper = true)
|
||||||
public static class UserReportUpdate extends UserReportParam {
|
public static class UserReportUpdate extends UserReportParam {
|
||||||
|
|
||||||
@ApiModelProperty("id")
|
@ApiModelProperty("id")
|
||||||
private String Id;
|
private String Id;
|
||||||
|
|
||||||
|
|||||||
@@ -58,7 +58,7 @@ public class UserReportPO extends BaseEntity {
|
|||||||
* 用户性质
|
* 用户性质
|
||||||
*/
|
*/
|
||||||
@TableField(value = "user_type")
|
@TableField(value = "user_type")
|
||||||
private String userType;
|
private Integer userType;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 所属地市
|
* 所属地市
|
||||||
@@ -76,7 +76,7 @@ public class UserReportPO extends BaseEntity {
|
|||||||
* 用户状态
|
* 用户状态
|
||||||
*/
|
*/
|
||||||
@TableField(value = "user_status")
|
@TableField(value = "user_status")
|
||||||
private String userStatus;
|
private Integer userStatus;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 变电站
|
* 变电站
|
||||||
|
|||||||
@@ -51,7 +51,7 @@ public class UserReportVO {
|
|||||||
* 用户性质
|
* 用户性质
|
||||||
*/
|
*/
|
||||||
@ApiModelProperty(value = "用户性质")
|
@ApiModelProperty(value = "用户性质")
|
||||||
private String userType;
|
private Integer userType;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 所属地市
|
* 所属地市
|
||||||
@@ -69,7 +69,7 @@ public class UserReportVO {
|
|||||||
* 用户状态
|
* 用户状态
|
||||||
*/
|
*/
|
||||||
@ApiModelProperty(value = "用户状态")
|
@ApiModelProperty(value = "用户状态")
|
||||||
private String userStatus;
|
private Integer userStatus;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 变电站
|
* 变电站
|
||||||
|
|||||||
@@ -24,6 +24,12 @@
|
|||||||
<version>${project.version}</version>
|
<version>${project.version}</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
|
<dependency>
|
||||||
|
<groupId>com.njcn</groupId>
|
||||||
|
<artifactId>bpm-api</artifactId>
|
||||||
|
<version>${project.version}</version>
|
||||||
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>com.njcn</groupId>
|
<groupId>com.njcn</groupId>
|
||||||
<artifactId>common-web</artifactId>
|
<artifactId>common-web</artifactId>
|
||||||
|
|||||||
@@ -37,18 +37,14 @@ public class UserReportManageController extends BaseController {
|
|||||||
|
|
||||||
private final UserReportPOService userReportPOService;
|
private final UserReportPOService userReportPOService;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@OperateInfo(info = LogEnum.BUSINESS_COMMON,operateType= OperateType.ADD)
|
@OperateInfo(info = LogEnum.BUSINESS_COMMON,operateType= OperateType.ADD)
|
||||||
@PostMapping("/addUserReport")
|
@PostMapping("/add")
|
||||||
@ApiOperation("新增干扰源用户(未建档干扰源用户管理)")
|
@ApiOperation("新增干扰源用户(未建档干扰源用户管理)")
|
||||||
@ApiImplicitParam(name = "userReportParam", value = "实体参数", required = true)
|
@ApiImplicitParam(name = "userReportParam", value = "实体参数", required = true)
|
||||||
public HttpResult<Boolean> addUserReport(@RequestBody @Validated UserReportParam userReportParam){
|
public HttpResult<String> addUserReport(@RequestBody @Validated UserReportParam userReportParam){
|
||||||
String methodDescribe = getMethodDescribe("addUserReport");
|
String methodDescribe = getMethodDescribe("addUserReport");
|
||||||
boolean res = userReportPOService.addUserReport(userReportParam);
|
String userReportId = userReportPOService.addUserReport(userReportParam);
|
||||||
|
return HttpResultUtil.assembleCommonResponseResult(CommonResponseEnum.SUCCESS, userReportId, methodDescribe);
|
||||||
return HttpResultUtil.assembleCommonResponseResult(CommonResponseEnum.SUCCESS, res, methodDescribe);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
||||||
<mapper namespace="com.njcn.supervision.mapper.user.UserReportPOMapper">
|
<mapper namespace="com.njcn.supervision.mapper.user.UserReportPOMapper">
|
||||||
<resultMap id="BaseResultMap" type="com.njcn.process.pojo.po.UserReportPO">
|
<resultMap id="BaseResultMap" type="UserReportPO">
|
||||||
<!--@mbg.generated-->
|
<!--@mbg.generated-->
|
||||||
<!--@Table user_report-->
|
<!--@Table user_report-->
|
||||||
<id column="id" jdbcType="VARCHAR" property="id" />
|
<id column="id" jdbcType="VARCHAR" property="id" />
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
||||||
<mapper namespace="com.njcn.supervision.mapper.user.UserReportProjectPOMapper">
|
<mapper namespace="com.njcn.supervision.mapper.user.UserReportProjectPOMapper">
|
||||||
<resultMap id="BaseResultMap" type="com.njcn.process.pojo.po.UserReportProjectPO">
|
<resultMap id="BaseResultMap" type="UserReportProjectPO">
|
||||||
<!--@mbg.generated-->
|
<!--@mbg.generated-->
|
||||||
<!--@Table user_report_project-->
|
<!--@Table user_report_project-->
|
||||||
<id column="id" jdbcType="VARCHAR" property="id" />
|
<id column="id" jdbcType="VARCHAR" property="id" />
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
||||||
<mapper namespace="com.njcn.supervision.mapper.user.UserReportSensitivePOMapper">
|
<mapper namespace="com.njcn.supervision.mapper.user.UserReportSensitivePOMapper">
|
||||||
<resultMap id="BaseResultMap" type="com.njcn.process.pojo.po.UserReportSensitivePO">
|
<resultMap id="BaseResultMap" type="UserReportSensitivePO">
|
||||||
<!--@mbg.generated-->
|
<!--@mbg.generated-->
|
||||||
<!--@Table user_report_sensitive-->
|
<!--@Table user_report_sensitive-->
|
||||||
<id column="id" jdbcType="VARCHAR" property="id" />
|
<id column="id" jdbcType="VARCHAR" property="id" />
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
||||||
<mapper namespace="com.njcn.supervision.mapper.user.UserReportSubstationPOMapper">
|
<mapper namespace="com.njcn.supervision.mapper.user.UserReportSubstationPOMapper">
|
||||||
<resultMap id="BaseResultMap" type="com.njcn.process.pojo.po.UserReportSubstationPO">
|
<resultMap id="BaseResultMap" type="UserReportSubstationPO">
|
||||||
<!--@mbg.generated-->
|
<!--@mbg.generated-->
|
||||||
<!--@Table user_report_substation-->
|
<!--@Table user_report_substation-->
|
||||||
<id column="id" jdbcType="VARCHAR" property="id" />
|
<id column="id" jdbcType="VARCHAR" property="id" />
|
||||||
|
|||||||
@@ -18,7 +18,7 @@ import java.util.List;
|
|||||||
public interface UserReportPOService extends IService<UserReportPO> {
|
public interface UserReportPOService extends IService<UserReportPO> {
|
||||||
|
|
||||||
|
|
||||||
boolean addUserReport(UserReportParam userReportParam);
|
String addUserReport(UserReportParam userReportParam);
|
||||||
|
|
||||||
boolean auditUserReport(UserReportParam.UserReportUpdate userReportUpdate);
|
boolean auditUserReport(UserReportParam.UserReportUpdate userReportUpdate);
|
||||||
|
|
||||||
|
|||||||
@@ -2,10 +2,16 @@ package com.njcn.supervision.service.user.impl;
|
|||||||
|
|
||||||
import cn.hutool.core.collection.CollectionUtil;
|
import cn.hutool.core.collection.CollectionUtil;
|
||||||
import cn.hutool.core.util.StrUtil;
|
import cn.hutool.core.util.StrUtil;
|
||||||
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
||||||
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
||||||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||||
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
||||||
|
import com.njcn.bpm.api.BpmProcessFeignClient;
|
||||||
|
import com.njcn.bpm.pojo.dto.BpmProcessInstanceCreateReqDTO;
|
||||||
import com.njcn.common.pojo.enums.common.DataStateEnum;
|
import com.njcn.common.pojo.enums.common.DataStateEnum;
|
||||||
|
import com.njcn.common.pojo.exception.BusinessException;
|
||||||
|
import com.njcn.supervision.enums.FlowStatusEnum;
|
||||||
|
import com.njcn.supervision.enums.UserNatureEnum;
|
||||||
import com.njcn.supervision.mapper.user.UserReportPOMapper;
|
import com.njcn.supervision.mapper.user.UserReportPOMapper;
|
||||||
import com.njcn.supervision.pojo.param.user.UserReportParam;
|
import com.njcn.supervision.pojo.param.user.UserReportParam;
|
||||||
import com.njcn.supervision.pojo.po.user.UserReportPO;
|
import com.njcn.supervision.pojo.po.user.UserReportPO;
|
||||||
@@ -24,14 +30,12 @@ import org.springframework.beans.BeanUtils;
|
|||||||
import org.springframework.beans.BeanWrapper;
|
import org.springframework.beans.BeanWrapper;
|
||||||
import org.springframework.beans.BeanWrapperImpl;
|
import org.springframework.beans.BeanWrapperImpl;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
|
import org.springframework.transaction.annotation.Transactional;
|
||||||
|
|
||||||
import java.util.HashSet;
|
import java.util.*;
|
||||||
import java.util.List;
|
import java.util.stream.Collectors;
|
||||||
import java.util.Objects;
|
|
||||||
import java.util.Set;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
|
||||||
* Description:
|
* Description:
|
||||||
* Date: 2024/4/25 10:07【需求编号】
|
* Date: 2024/4/25 10:07【需求编号】
|
||||||
*
|
*
|
||||||
@@ -42,40 +46,72 @@ import java.util.Set;
|
|||||||
@RequiredArgsConstructor
|
@RequiredArgsConstructor
|
||||||
public class UserReportPOServiceImpl extends ServiceImpl<UserReportPOMapper, UserReportPO> implements UserReportPOService {
|
public class UserReportPOServiceImpl extends ServiceImpl<UserReportPOMapper, UserReportPO> implements UserReportPOService {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 用户信息建档对应的流程定义 KEY
|
||||||
|
*/
|
||||||
|
public static final String PROCESS_KEY = "build_user_info";
|
||||||
|
|
||||||
private final UserReportProjectPOService userReportProjectPOService;
|
private final UserReportProjectPOService userReportProjectPOService;
|
||||||
private final UserReportSubstationPOService userReportSubstationPOService;
|
private final UserReportSubstationPOService userReportSubstationPOService;
|
||||||
private final UserReportSensitivePOService userReportSensitivePOService;
|
private final UserReportSensitivePOService userReportSensitivePOService;
|
||||||
|
private final BpmProcessFeignClient bpmProcessFeignClient;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean addUserReport(UserReportParam userReportParam) {
|
@Transactional(rollbackFor = Exception.class)
|
||||||
|
public String addUserReport(UserReportParam userReportParam) {
|
||||||
|
//判断工程名称是否有重复的
|
||||||
|
checkProjectName(userReportParam, false);
|
||||||
UserReportPO userReportPO = new UserReportPO();
|
UserReportPO userReportPO = new UserReportPO();
|
||||||
BeanUtils.copyProperties(userReportParam, userReportPO);
|
BeanUtils.copyProperties(userReportParam, userReportPO);
|
||||||
userReportPO.setState(1);
|
userReportPO.setState(DataStateEnum.ENABLE.getCode());
|
||||||
boolean save = this.save(userReportPO);
|
this.save(userReportPO);
|
||||||
String id = userReportPO.getId();
|
if (
|
||||||
if(Objects.equals(userReportPO.getUserType(),"1")||
|
CollectionUtil.newArrayList(
|
||||||
Objects.equals(userReportPO.getUserType(),"2")){
|
UserNatureEnum.BUILD_POWER_GRID.getCode(),
|
||||||
|
UserNatureEnum.EXTEND_POWER_GRID.getCode()
|
||||||
|
).contains(userReportPO.getUserType())) {
|
||||||
|
//电网工程类用户额外数据
|
||||||
UserReportProjectPO userReportProjectPO = userReportParam.getUserReportProjectPO();
|
UserReportProjectPO userReportProjectPO = userReportParam.getUserReportProjectPO();
|
||||||
userReportProjectPO.setId(id);
|
userReportProjectPO.setId(userReportPO.getId());
|
||||||
userReportProjectPO.setState(1);
|
userReportProjectPO.setState(DataStateEnum.ENABLE.getCode());
|
||||||
userReportProjectPOService.saveOrUpdate(userReportProjectPO);
|
userReportProjectPOService.saveOrUpdate(userReportProjectPO);
|
||||||
}else if(Objects.equals(userReportPO.getUserType(),"3")||
|
} else if (
|
||||||
Objects.equals(userReportPO.getUserType(),"4")){
|
CollectionUtil.newArrayList(
|
||||||
|
UserNatureEnum.BUILD_NON_LINEAR_LOAD.getCode(),
|
||||||
|
UserNatureEnum.EXTEND_NON_LINEAR_LOAD.getCode(),
|
||||||
|
UserNatureEnum.BUILD_NEW_ENERGY_POWER_STATION.getCode(),
|
||||||
|
UserNatureEnum.EXTEND_NEW_ENERGY_POWER_STATION.getCode()
|
||||||
|
).contains(userReportPO.getUserType())) {
|
||||||
|
//非线性负荷用户 & 新能源发电站用户
|
||||||
UserReportSubstationPO userReportSubstationPO = userReportParam.getUserReportSubstationPO();
|
UserReportSubstationPO userReportSubstationPO = userReportParam.getUserReportSubstationPO();
|
||||||
userReportSubstationPO.setId(id);
|
userReportSubstationPO.setId(userReportPO.getId());
|
||||||
userReportSubstationPO.setState(1);
|
userReportSubstationPO.setState(DataStateEnum.ENABLE.getCode());
|
||||||
userReportSubstationPOService.saveOrUpdate(userReportSubstationPO);
|
userReportSubstationPOService.saveOrUpdate(userReportSubstationPO);
|
||||||
}else if(Objects.equals(userReportPO.getUserType(),"5")){
|
} else if (UserNatureEnum.SENSITIVE_USER.getCode().equals(userReportPO.getUserType())) {
|
||||||
|
// 敏感及重要用户
|
||||||
UserReportSensitivePO userReportSensitivePO = userReportParam.getUserReportSensitivePO();
|
UserReportSensitivePO userReportSensitivePO = userReportParam.getUserReportSensitivePO();
|
||||||
userReportSensitivePO.setId(id);
|
userReportSensitivePO.setId(userReportPO.getId());
|
||||||
userReportSensitivePO.setState(1);
|
userReportSensitivePO.setState(DataStateEnum.ENABLE.getCode());
|
||||||
userReportSensitivePOService.saveOrUpdate(userReportSensitivePO);
|
userReportSensitivePOService.saveOrUpdate(userReportSensitivePO);
|
||||||
}
|
}
|
||||||
|
// 发起 BPM 流程
|
||||||
|
Map<String, Object> processInstanceVariables = new HashMap<>();
|
||||||
|
BpmProcessInstanceCreateReqDTO bpmProcessInstanceCreateReqDTO = new BpmProcessInstanceCreateReqDTO();
|
||||||
|
bpmProcessInstanceCreateReqDTO.setProcessDefinitionKey(PROCESS_KEY);
|
||||||
|
bpmProcessInstanceCreateReqDTO.setBusinessKey(userReportPO.getId());
|
||||||
|
bpmProcessInstanceCreateReqDTO.setStartUserSelectAssignees(userReportParam.getStartUserSelectAssignees());
|
||||||
|
bpmProcessInstanceCreateReqDTO.setVariables(processInstanceVariables);
|
||||||
|
String processInstanceId = bpmProcessFeignClient.createProcessInstance(userReportPO.getCreateBy(),bpmProcessInstanceCreateReqDTO).getData();
|
||||||
|
// 将工作流的编号,更新到流程单中
|
||||||
|
userReportPO.setProcessInstanceId(processInstanceId);
|
||||||
|
this.baseMapper.updateById(userReportPO);
|
||||||
|
|
||||||
return save;
|
return userReportPO.getId();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean auditUserReport(UserReportParam.UserReportUpdate userReportUpdate) {
|
public boolean auditUserReport(UserReportParam.UserReportUpdate userReportUpdate) {
|
||||||
String id = userReportUpdate.getId();
|
String id = userReportUpdate.getId();
|
||||||
@@ -134,6 +170,7 @@ public class UserReportPOServiceImpl extends ServiceImpl<UserReportPOMapper, Use
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取所有字段为null的属性名
|
* 获取所有字段为null的属性名
|
||||||
|
*
|
||||||
* @param source
|
* @param source
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
@@ -141,7 +178,7 @@ public class UserReportPOServiceImpl extends ServiceImpl<UserReportPOMapper, Use
|
|||||||
final BeanWrapper src = new BeanWrapperImpl(source);
|
final BeanWrapper src = new BeanWrapperImpl(source);
|
||||||
java.beans.PropertyDescriptor[] pds = src.getPropertyDescriptors();
|
java.beans.PropertyDescriptor[] pds = src.getPropertyDescriptors();
|
||||||
|
|
||||||
Set<String> emptyNames = new HashSet<String> ( );
|
Set<String> emptyNames = new HashSet<>();
|
||||||
for (java.beans.PropertyDescriptor pd : pds) {
|
for (java.beans.PropertyDescriptor pd : pds) {
|
||||||
Object srcValue = src.getPropertyValue(pd.getName());
|
Object srcValue = src.getPropertyValue(pd.getName());
|
||||||
if (srcValue == null) {
|
if (srcValue == null) {
|
||||||
@@ -153,4 +190,35 @@ public class UserReportPOServiceImpl extends ServiceImpl<UserReportPOMapper, Use
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 判断工程名称是否重复,如果重复则提示用户XXX已经创建该工程
|
||||||
|
*
|
||||||
|
* @param userReportParam 用户申请数据
|
||||||
|
* @param isExcludeSelf 是否排除自己,一般新增不排除,更新时需要排除自己
|
||||||
|
*/
|
||||||
|
private void checkProjectName(UserReportParam userReportParam, boolean isExcludeSelf) {
|
||||||
|
LambdaQueryWrapper<UserReportPO> userReportPOLambdaQueryWrapper = new LambdaQueryWrapper<>();
|
||||||
|
userReportPOLambdaQueryWrapper
|
||||||
|
.eq(UserReportPO::getProjectName, userReportParam.getProjectName())
|
||||||
|
.eq(UserReportPO::getState, DataStateEnum.ENABLE.getCode());
|
||||||
|
//更新的时候,需排除当前记录
|
||||||
|
if (isExcludeSelf) {
|
||||||
|
if (userReportParam instanceof UserReportParam.UserReportUpdate) {
|
||||||
|
userReportPOLambdaQueryWrapper.ne(UserReportPO::getId, ((UserReportParam.UserReportUpdate) userReportParam).getId());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
List<UserReportPO> userReportPOList = this.baseMapper.selectList(userReportPOLambdaQueryWrapper);
|
||||||
|
if (CollectionUtil.isNotEmpty(userReportPOList)) {
|
||||||
|
//过滤已取消的申请
|
||||||
|
userReportPOList = userReportPOList.stream()
|
||||||
|
.filter(userReportPO -> !userReportPO.getStatus().equals(FlowStatusEnum.CANCEL.getCode()))
|
||||||
|
.collect(Collectors.toList());
|
||||||
|
//如果还存在,则说明有人申请过了
|
||||||
|
if (CollectionUtil.isNotEmpty(userReportPOList)) {
|
||||||
|
throw new BusinessException(userReportParam.getProjectName().concat(",该工程已被").concat(userReportPOList.get(0).getReporter()).concat("申请"));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user