|
|
|
@ -37,8 +37,12 @@ import org.springblade.system.feign.ISysClient;
|
|
|
|
|
import org.springblade.system.user.cache.UserCache; |
|
|
|
|
import org.springblade.system.user.entity.User; |
|
|
|
|
import org.springframework.beans.BeanUtils; |
|
|
|
|
import org.springframework.jdbc.datasource.DataSourceTransactionManager; |
|
|
|
|
import org.springframework.stereotype.Service; |
|
|
|
|
import org.springframework.transaction.TransactionDefinition; |
|
|
|
|
import org.springframework.transaction.TransactionStatus; |
|
|
|
|
import org.springframework.transaction.annotation.Transactional; |
|
|
|
|
import org.springframework.transaction.support.DefaultTransactionDefinition; |
|
|
|
|
|
|
|
|
|
import java.time.Instant; |
|
|
|
|
import java.time.LocalDate; |
|
|
|
@ -46,6 +50,9 @@ import java.time.LocalDateTime;
|
|
|
|
|
import java.time.ZoneId; |
|
|
|
|
import java.time.format.DateTimeFormatter; |
|
|
|
|
import java.util.*; |
|
|
|
|
import java.util.concurrent.CompletableFuture; |
|
|
|
|
import java.util.concurrent.ExecutionException; |
|
|
|
|
import java.util.concurrent.ThreadPoolExecutor; |
|
|
|
|
import java.util.stream.Collectors; |
|
|
|
|
import java.util.stream.Stream; |
|
|
|
|
|
|
|
|
@ -71,25 +78,25 @@ public class MaintenanceServiceImpl implements MaintenanceService {
|
|
|
|
|
private final IFlowClient flowClient; |
|
|
|
|
private final ISysClient sysClient; |
|
|
|
|
|
|
|
|
|
private final ThreadPoolExecutor executor; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private final DataSourceTransactionManager dataSourceTransactionManager; |
|
|
|
|
|
|
|
|
|
/** |
|
|
|
|
* 日常维护生成任务 |
|
|
|
|
* |
|
|
|
|
* @param ids |
|
|
|
|
*/ |
|
|
|
|
@Override |
|
|
|
|
@Transactional(rollbackFor = Exception.class) |
|
|
|
|
public void createTask(List<String> ids) { |
|
|
|
|
try { |
|
|
|
|
//获取日常维护计划
|
|
|
|
|
LambdaQueryWrapper<OperMaintenancePlanEntity> planEntityLambdaQueryWrapper = new LambdaQueryWrapper<>(); |
|
|
|
|
planEntityLambdaQueryWrapper.in(BaseEntity::getId, ids); |
|
|
|
|
List<OperMaintenancePlanEntity> planEntities = maintenancePlanService |
|
|
|
|
.list(planEntityLambdaQueryWrapper); |
|
|
|
|
List<OperMaintenancePlanEntity> planEntities = maintenancePlanService.list(planEntityLambdaQueryWrapper); |
|
|
|
|
//筛选当月没生成任务的计划
|
|
|
|
|
List<OperMaintenancePlanEntity> finalPlanEntities = planEntities.stream().filter(planEntity -> |
|
|
|
|
ObjectUtil.isEmpty(planEntity.getCreateTaskTime()) |
|
|
|
|
|| !DateUtil.judgeSameDay( |
|
|
|
|
DateUtil.DateToLocalDateTime(planEntity.getCreateTaskTime()), LocalDate.now()) |
|
|
|
|
).collect(Collectors.toList()); |
|
|
|
|
List<OperMaintenancePlanEntity> finalPlanEntities = planEntities.stream().filter(planEntity -> ObjectUtil.isEmpty(planEntity.getCreateTaskTime()) || !DateUtil.judgeSameDay(DateUtil.DateToLocalDateTime(planEntity.getCreateTaskTime()), LocalDate.now())).collect(Collectors.toList()); |
|
|
|
|
if (CollectionUtil.isEmpty(finalPlanEntities)) { |
|
|
|
|
throw new ServiceException("所选计划当天已生成任务"); |
|
|
|
|
} |
|
|
|
@ -97,8 +104,7 @@ public class MaintenanceServiceImpl implements MaintenanceService {
|
|
|
|
|
// 通过计划生成任务
|
|
|
|
|
this.createTaskByPlan(finalPlanEntity); |
|
|
|
|
//更新任务派发时间
|
|
|
|
|
LambdaUpdateWrapper<OperMaintenancePlanEntity> planEntityLambdaUpdateWrapper = |
|
|
|
|
new LambdaUpdateWrapper<>(); |
|
|
|
|
LambdaUpdateWrapper<OperMaintenancePlanEntity> planEntityLambdaUpdateWrapper = new LambdaUpdateWrapper<>(); |
|
|
|
|
planEntityLambdaUpdateWrapper.set(OperMaintenancePlanEntity::getCreateTaskTime, new Date()); |
|
|
|
|
planEntityLambdaUpdateWrapper.eq(OperMaintenancePlanEntity::getId, finalPlanEntity.getId()); |
|
|
|
|
boolean update = maintenancePlanService.update(planEntityLambdaUpdateWrapper); |
|
|
|
@ -107,6 +113,9 @@ public class MaintenanceServiceImpl implements MaintenanceService {
|
|
|
|
|
throw new ServiceException("更新任务派发失败"); |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
} catch (Exception e) { |
|
|
|
|
e.printStackTrace(); |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
/** |
|
|
|
@ -117,6 +126,7 @@ public class MaintenanceServiceImpl implements MaintenanceService {
|
|
|
|
|
@Override |
|
|
|
|
@Transactional(rollbackFor = RuntimeException.class) |
|
|
|
|
public void findPending(ProcessWorkFlowResponse response) { |
|
|
|
|
try { |
|
|
|
|
log.info("获取businessKey: {}", response.getBusinessKey()); |
|
|
|
|
log.info("获取taskId: {} ", response.getTaskId()); |
|
|
|
|
log.info("获取下一个审批人是: {} ", response.getNextStepOperator()); |
|
|
|
@ -129,8 +139,8 @@ public class MaintenanceServiceImpl implements MaintenanceService {
|
|
|
|
|
OperMaintenanceTaskEntityVo standardTicketInfoVo = null; |
|
|
|
|
try { |
|
|
|
|
JSONObject jsonObject = JSONObject.parseObject(formData); |
|
|
|
|
standardTicketInfoVo = JSONObject.parseObject(jsonObject.getString("operMaintenanceTaskEntityVo"), |
|
|
|
|
new TypeReference<OperMaintenanceTaskEntityVo>(){}); |
|
|
|
|
standardTicketInfoVo = JSONObject.parseObject(jsonObject.getString("operMaintenanceTaskEntityVo"), new TypeReference<OperMaintenanceTaskEntityVo>() { |
|
|
|
|
}); |
|
|
|
|
// standardTicketInfoVo = (OperMaintenanceTaskEntityVo) jsonObject.get("operMaintenanceTaskEntityVo");
|
|
|
|
|
// standardTicketInfoVo = JSONObject.toJavaObject(jsonObject, OperMaintenanceTaskEntityVo.class);
|
|
|
|
|
} catch (Exception e) { |
|
|
|
@ -196,10 +206,7 @@ public class MaintenanceServiceImpl implements MaintenanceService {
|
|
|
|
|
businessMessageDTO.setTaskId(dbOperMaintenanceTaskEntity.getId()); |
|
|
|
|
businessMessageDTO.setTenantId("200000"); |
|
|
|
|
//您有一张工作票待审批,工作内容:*****,审批环节:*****;
|
|
|
|
|
String countent = |
|
|
|
|
"您有一条日常维护任务待审批,工作内容:".concat(dbOperMaintenanceTaskEntity.getTitle()) |
|
|
|
|
.concat(",审批环节:") |
|
|
|
|
.concat(response.getTaskName()); |
|
|
|
|
String countent = "您有一条日常维护任务待审批,工作内容:".concat(dbOperMaintenanceTaskEntity.getTitle()).concat(",审批环节:").concat(response.getTaskName()); |
|
|
|
|
businessMessageDTO.setContent(countent); |
|
|
|
|
businessMessageDTO.setDeptId(dbOperMaintenanceTaskEntity.getCreateDept()); |
|
|
|
|
R<String> deptName = sysClient.getDeptName(dbOperMaintenanceTaskEntity.getCreateDept()); |
|
|
|
@ -219,6 +226,9 @@ public class MaintenanceServiceImpl implements MaintenanceService {
|
|
|
|
|
} |
|
|
|
|
log.info("推送成功~"); |
|
|
|
|
} |
|
|
|
|
} catch (Exception e) { |
|
|
|
|
e.printStackTrace(); |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -281,6 +291,9 @@ public class MaintenanceServiceImpl implements MaintenanceService {
|
|
|
|
|
* @param finalPlanEntity |
|
|
|
|
*/ |
|
|
|
|
private void fillTask(OperMaintenanceTaskEntity taskEntity, OperMaintenancePlanEntity finalPlanEntity) { |
|
|
|
|
DefaultTransactionDefinition defaultTransactionDefinition = new DefaultTransactionDefinition(); |
|
|
|
|
defaultTransactionDefinition.setPropagationBehavior(TransactionDefinition.PROPAGATION_REQUIRES_NEW); |
|
|
|
|
TransactionStatus transaction = dataSourceTransactionManager.getTransaction(defaultTransactionDefinition); |
|
|
|
|
taskEntity.setId(null); |
|
|
|
|
taskEntity.setCreateTime(new Date()); |
|
|
|
|
taskEntity.setUpdateTime(new Date()); |
|
|
|
@ -299,8 +312,7 @@ public class MaintenanceServiceImpl implements MaintenanceService {
|
|
|
|
|
if (ObjectUtil.isNotEmpty(finalPlanEntity.getMaintenanceModel()) && finalPlanEntity.getMaintenanceModel() == 2) { |
|
|
|
|
//查询值班信息
|
|
|
|
|
LambdaQueryWrapper<ImsDutyMainEntity> entityLambdaQueryWrapper = new LambdaQueryWrapper<>(); |
|
|
|
|
entityLambdaQueryWrapper.eq(ImsDutyMainEntity::getDutyDate, |
|
|
|
|
DateTimeFormatter.ofPattern(PATTERN_DATE).format(disposeTime)); |
|
|
|
|
entityLambdaQueryWrapper.eq(ImsDutyMainEntity::getDutyDate, DateTimeFormatter.ofPattern(PATTERN_DATE).format(disposeTime)); |
|
|
|
|
entityLambdaQueryWrapper.eq(ImsDutyMainEntity::getClassId, finalPlanEntity.getImsDutyClassId()); |
|
|
|
|
ImsDutyMainEntity entity = mainService.getOne(entityLambdaQueryWrapper); |
|
|
|
|
if (ObjectUtil.isNotEmpty(entity) && StringUtils.isNotEmpty(entity.getDutyPersonIds())) { |
|
|
|
@ -312,16 +324,40 @@ public class MaintenanceServiceImpl implements MaintenanceService {
|
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
taskService.save(taskEntity); |
|
|
|
|
dataSourceTransactionManager.commit(transaction); |
|
|
|
|
|
|
|
|
|
OperMaintenanceTaskEntity[] finalTaskEntity = {taskEntity}; |
|
|
|
|
|
|
|
|
|
CompletableFuture<String> processInstanceIdCompletableFuture = CompletableFuture.supplyAsync(() -> { |
|
|
|
|
//生成工作流实例
|
|
|
|
|
String processInstanceId = this.startProcess(finalPlanEntity.getProcDefId(), taskEntity); |
|
|
|
|
taskEntity.setProcessInstanceId(processInstanceId); |
|
|
|
|
taskService.updateById(taskEntity); |
|
|
|
|
String processInstanceId = this.startProcess(finalPlanEntity.getProcDefId(), finalTaskEntity[0]); |
|
|
|
|
return processInstanceId; |
|
|
|
|
}, executor); |
|
|
|
|
|
|
|
|
|
//启动流程
|
|
|
|
|
CompletableFuture<OperMaintenanceTaskEntity> operMaintenanceTaskEntityCompletableFuture = processInstanceIdCompletableFuture.thenApplyAsync((processInstanceId) -> { |
|
|
|
|
finalTaskEntity[0].setProcessInstanceId(processInstanceId); |
|
|
|
|
taskService.updateById(finalTaskEntity[0]); |
|
|
|
|
finalPlanEntity.setCreateTaskTime(new Date()); |
|
|
|
|
maintenancePlanService.updateById(finalPlanEntity); |
|
|
|
|
finalTaskEntity[0] = taskService.getById(finalTaskEntity[0].getId()); |
|
|
|
|
return finalTaskEntity[0]; |
|
|
|
|
}, executor); |
|
|
|
|
|
|
|
|
|
taskEntity = taskService.getById(taskEntity.getId()); |
|
|
|
|
|
|
|
|
|
CompletableFuture<Void> thennedAcceptAsync = operMaintenanceTaskEntityCompletableFuture.thenAcceptAsync((task) -> { |
|
|
|
|
//推送消息
|
|
|
|
|
this.pushTaskMessage(taskEntity); |
|
|
|
|
this.pushTaskMessage(task); |
|
|
|
|
}, executor); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//启动队列
|
|
|
|
|
try { |
|
|
|
|
CompletableFuture.allOf(processInstanceIdCompletableFuture, operMaintenanceTaskEntityCompletableFuture, |
|
|
|
|
thennedAcceptAsync).get(); |
|
|
|
|
} catch (Exception e) { |
|
|
|
|
e.printStackTrace(); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
@ -343,10 +379,7 @@ public class MaintenanceServiceImpl implements MaintenanceService {
|
|
|
|
|
params.put("initUserIds", taskUsers); |
|
|
|
|
params.put("operMaintenanceTaskEntityVo", operMaintenanceTaskEntityVo); |
|
|
|
|
|
|
|
|
|
return flowClient.startProcessInstanceContainNameByKey(processDefinitionKey, |
|
|
|
|
String.valueOf(taskEntity.getId()), taskEntity.getTitle(), params) |
|
|
|
|
.getData() |
|
|
|
|
.getProcessInstanceId(); |
|
|
|
|
return flowClient.startProcessInstanceContainNameByKey(processDefinitionKey, String.valueOf(taskEntity.getId()), taskEntity.getTitle(), params).getData().getProcessInstanceId(); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|