成立单独的冀北技术监督项目

This commit is contained in:
2024-05-10 15:28:46 +08:00
parent 0581380f19
commit 5cd377606d
31 changed files with 568 additions and 177 deletions

View File

@@ -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>

View File

@@ -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);
}

View File

@@ -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);
}
};
}
}

View File

@@ -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];
}
}

View File

@@ -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","部署流程失败,原因:流程表单未配置,请点击【修改流程】按钮进行配置"),

View File

@@ -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
*
* keytaskKey 任务编码
* value审批人的数组
* 例如:{ taskKey1 :[1, 2] },则表示 taskKey1 这个任务,提前设定了,由 userId 为 1,2 的用户进行审批
*/
private Map<String, List<String>> startUserSelectAssignees;
}

View File

@@ -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;
/** /**

View File

@@ -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实例

View File

@@ -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>

View File

@@ -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;

View File

@@ -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);
}
} }

View File

@@ -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);

View File

@@ -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);
} }

View File

@@ -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);
// //
// /** // /**
// * 发起人取消流程实例 // * 发起人取消流程实例

View File

@@ -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) {

View File

@@ -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;

View File

@@ -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";

View File

@@ -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;
}
}

View File

@@ -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;
}
}

View File

@@ -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;
}
}

View File

@@ -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;

View File

@@ -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;
/** /**
* 变电站 * 变电站

View File

@@ -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;
/** /**
* 变电站 * 变电站

View File

@@ -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>

View File

@@ -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);
} }

View File

@@ -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" />

View File

@@ -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" />

View File

@@ -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" />

View File

@@ -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" />

View File

@@ -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);

View File

@@ -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,59 +46,91 @@ 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();
UserReportPO byId = this.getById(id); UserReportPO byId = this.getById(id);
BeanUtils.copyProperties(userReportUpdate,byId); BeanUtils.copyProperties(userReportUpdate, byId);
this.updateById(byId); this.updateById(byId);
if(Objects.equals(userReportUpdate.getUserType(),"1")|| if (Objects.equals(userReportUpdate.getUserType(), "1") ||
Objects.equals(userReportUpdate.getUserType(),"2")){ Objects.equals(userReportUpdate.getUserType(), "2")) {
UserReportProjectPO userReportProjectPO = userReportProjectPOService.getById(id); UserReportProjectPO userReportProjectPO = userReportProjectPOService.getById(id);
BeanUtils.copyProperties(userReportUpdate.getUserReportProjectPO(),userReportProjectPO,getNullPropertyNames(userReportUpdate.getUserReportProjectPO())); BeanUtils.copyProperties(userReportUpdate.getUserReportProjectPO(), userReportProjectPO, getNullPropertyNames(userReportUpdate.getUserReportProjectPO()));
userReportProjectPOService.updateById(userReportProjectPO); userReportProjectPOService.updateById(userReportProjectPO);
}else if(Objects.equals(userReportUpdate.getUserType(),"3")|| } else if (Objects.equals(userReportUpdate.getUserType(), "3") ||
Objects.equals(userReportUpdate.getUserType(),"4")){ Objects.equals(userReportUpdate.getUserType(), "4")) {
UserReportSubstationPO userReportSubstationPO = userReportSubstationPOService.getById(id); UserReportSubstationPO userReportSubstationPO = userReportSubstationPOService.getById(id);
BeanUtils.copyProperties(userReportUpdate.getUserReportSubstationPO(),userReportSubstationPO,getNullPropertyNames(userReportUpdate.getUserReportSubstationPO())); BeanUtils.copyProperties(userReportUpdate.getUserReportSubstationPO(), userReportSubstationPO, getNullPropertyNames(userReportUpdate.getUserReportSubstationPO()));
userReportSubstationPOService.updateById(userReportSubstationPO); userReportSubstationPOService.updateById(userReportSubstationPO);
}else if(Objects.equals(userReportUpdate.getUserType(),"5")){ } else if (Objects.equals(userReportUpdate.getUserType(), "5")) {
UserReportSensitivePO userReportSensitivePO = userReportSensitivePOService.getById(id); UserReportSensitivePO userReportSensitivePO = userReportSensitivePOService.getById(id);
BeanUtils.copyProperties(userReportUpdate.getUserReportSensitivePO(),userReportSensitivePO,getNullPropertyNames(userReportUpdate.getUserReportSensitivePO())); BeanUtils.copyProperties(userReportUpdate.getUserReportSensitivePO(), userReportSensitivePO, getNullPropertyNames(userReportUpdate.getUserReportSensitivePO()));
userReportSensitivePOService.updateById(userReportSensitivePO); userReportSensitivePOService.updateById(userReportSensitivePO);
} }
@@ -111,10 +147,10 @@ public class UserReportPOServiceImpl extends ServiceImpl<UserReportPOMapper, Use
QueryWrapper<UserReportVO> userReportVOQueryWrapper = new QueryWrapper<>(); QueryWrapper<UserReportVO> userReportVOQueryWrapper = new QueryWrapper<>();
userReportVOQueryWrapper.in("supervision_user_report.create_by", CollectionUtil.newArrayList(userIndex)) userReportVOQueryWrapper.in("supervision_user_report.create_by", CollectionUtil.newArrayList(userIndex))
.eq("supervision_user_report.state", DataStateEnum.ENABLE.getCode()); .eq("supervision_user_report.state", DataStateEnum.ENABLE.getCode());
if(Objects.nonNull(userReportQueryParam)){ if (Objects.nonNull(userReportQueryParam)) {
if(StrUtil.isNotBlank(userReportQueryParam.getCity())){ if (StrUtil.isNotBlank(userReportQueryParam.getCity())) {
//查询所有区域下的数据 //查询所有区域下的数据
userReportVOQueryWrapper.in("supervision_user_report.city",userReportQueryParam.getCity()); userReportVOQueryWrapper.in("supervision_user_report.city", userReportQueryParam.getCity());
} }
} }
userReportVOQueryWrapper.orderByDesc("supervision_user_report.create_time"); userReportVOQueryWrapper.orderByDesc("supervision_user_report.create_time");
@@ -123,10 +159,10 @@ public class UserReportPOServiceImpl extends ServiceImpl<UserReportPOMapper, Use
@Override @Override
public Boolean removeUserReport(List<String> ids) { public Boolean removeUserReport(List<String> ids) {
this.lambdaUpdate().set(UserReportPO::getState,0).in(UserReportPO::getId,ids).update(); this.lambdaUpdate().set(UserReportPO::getState, 0).in(UserReportPO::getId, ids).update();
userReportProjectPOService.lambdaUpdate().set(UserReportProjectPO::getState,0).in(UserReportProjectPO::getId,ids).update(); userReportProjectPOService.lambdaUpdate().set(UserReportProjectPO::getState, 0).in(UserReportProjectPO::getId, ids).update();
userReportSubstationPOService.lambdaUpdate().set(UserReportSubstationPO::getState,0).in(UserReportSubstationPO::getId,ids).update(); userReportSubstationPOService.lambdaUpdate().set(UserReportSubstationPO::getState, 0).in(UserReportSubstationPO::getId, ids).update();
userReportSensitivePOService.lambdaUpdate().set(UserReportSensitivePO::getState,0).in(UserReportSensitivePO::getId,ids).update(); userReportSensitivePOService.lambdaUpdate().set(UserReportSensitivePO::getState, 0).in(UserReportSensitivePO::getId, ids).update();
return true; return true;
} }
@@ -134,23 +170,55 @@ public class UserReportPOServiceImpl extends ServiceImpl<UserReportPOMapper, Use
/** /**
* 获取所有字段为null的属性名 * 获取所有字段为null的属性名
*
* @param source * @param source
* @return * @return
*/ */
public String[] getNullPropertyNames (Object source) { public String[] getNullPropertyNames(Object source) {
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) {
emptyNames.add (pd.getName ( )); emptyNames.add(pd.getName());
} }
} }
String[] result = new String[emptyNames.size ( )]; String[] result = new String[emptyNames.size()];
return emptyNames.toArray (result); return emptyNames.toArray(result);
} }
/**
* 判断工程名称是否重复如果重复则提示用户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("申请"));
}
}
}
} }