XinxizhongxinServiceImpl.java 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162
  1. package com.fdkankan.external.service.impl;
  2. import cn.hutool.core.collection.CollUtil;
  3. import cn.hutool.core.date.DateTime;
  4. import cn.hutool.core.io.FileUtil;
  5. import cn.hutool.core.lang.UUID;
  6. import cn.hutool.core.util.StrUtil;
  7. import com.alibaba.excel.EasyExcel;
  8. import com.fdkankan.common.constant.CommonOperStatus;
  9. import com.fdkankan.common.constant.CommonSuccessStatus;
  10. import com.fdkankan.common.constant.ErrorCode;
  11. import com.fdkankan.common.exception.BusinessException;
  12. import com.fdkankan.common.util.DateExtUtil;
  13. import com.fdkankan.external.bean.ScenePushBean;
  14. import com.fdkankan.external.entity.Department;
  15. import com.fdkankan.external.entity.Scene;
  16. import com.fdkankan.external.entity.ZgxxzxPushLog;
  17. import com.fdkankan.external.httpclient.XxzxClient;
  18. import com.fdkankan.external.request.TaskPageRequest;
  19. import com.fdkankan.external.response.PageInfo;
  20. import com.fdkankan.external.service.*;
  21. import com.fdkankan.web.response.ResultData;
  22. import com.mybatisflex.core.paginate.Page;
  23. import com.mybatisflex.core.query.QueryWrapper;
  24. import lombok.extern.slf4j.Slf4j;
  25. import org.springframework.beans.factory.annotation.Autowired;
  26. import org.springframework.stereotype.Service;
  27. import org.springframework.web.multipart.MultipartFile;
  28. import javax.annotation.Resource;
  29. import java.io.File;
  30. import java.io.IOException;
  31. import java.util.*;
  32. import java.util.stream.Collectors;
  33. @Slf4j
  34. @Service
  35. public class XinxizhongxinServiceImpl implements XinxizhongxinService {
  36. @Autowired
  37. private IScenePlusService scenePlusService;
  38. @Autowired
  39. private ISceneService sceneService;
  40. @Autowired
  41. private IZgxxzxPushLogService zgxxzxPushLogService;
  42. @Autowired
  43. private ISceneOfflinePackagePushService sceneOfflinePackagePushService;
  44. @Autowired
  45. private IDepartmentService departmentService;
  46. @Resource
  47. private XxzxClient xxzxClient;
  48. @Override
  49. public void importExcel(MultipartFile file) throws IOException {
  50. String uuid = UUID.randomUUID().toString();
  51. String s = FileUtil.extName(file.getOriginalFilename());
  52. File tempFile = FileUtil.createTempFile(uuid, "." + s, new File("/home/backend/4dkankan_v4/external/tmp"), true);
  53. FileUtil.mkParentDirs(tempFile);
  54. file.transferTo(tempFile);
  55. // 这里 需要指定读用哪个class去读,然后读取第一个sheet 同步读取会自动finish
  56. List<ZgxxzxPushLog> list = EasyExcel.read(tempFile).head(ZgxxzxPushLog.class).sheet().doReadSync();
  57. if (CollUtil.isEmpty(list)) {
  58. throw new BusinessException(ErrorCode.SYSTEM_ERROR.code(), "excel数据有误");
  59. }
  60. List<String> numList = list.stream().map(v -> v.getNum()).collect(Collectors.toList());
  61. List<Scene> sceneList = sceneService.list(QueryWrapper.create().in(Scene::getSceneCode, numList).eq(Scene::getStatus, 2));
  62. Map<String, Scene> dbNumMap = sceneList.stream().collect(Collectors.toMap(v -> v.getSceneCode(), v -> v));
  63. Set<String> errorNumList = numList.stream().filter(num -> !dbNumMap.keySet().contains(num)).collect(Collectors.toSet());
  64. if (CollUtil.isNotEmpty(errorNumList)) {
  65. StringBuffer sb = new StringBuffer("以下场景不存在或错误:");
  66. errorNumList.stream().forEach(v -> sb.append(v).append("、"));
  67. throw new BusinessException(ErrorCode.SYSTEM_ERROR.code(), sb.toString());
  68. }
  69. list.stream().forEach(v -> {
  70. Scene scene = dbNumMap.get(v.getNum());
  71. v.setTitle(scene.getTitle());
  72. v.setStatus(CommonOperStatus.WAITING.code());
  73. v.setTaskId(UUID.fastUUID().toString());
  74. });
  75. zgxxzxPushLogService.saveBatch(list);
  76. }
  77. @Override
  78. public PageInfo<ZgxxzxPushLog> taskList(TaskPageRequest request) {
  79. QueryWrapper queryWrapper = QueryWrapper.create().orderBy(ZgxxzxPushLog::getId, false);
  80. if (StrUtil.isNotEmpty(request.getNum())) {
  81. queryWrapper.like(ZgxxzxPushLog::getNum, request.getNum());
  82. }
  83. if (StrUtil.isNotEmpty(request.getTitle())) {
  84. queryWrapper.like(ZgxxzxPushLog::getTitle, request.getTitle());
  85. }
  86. if (request.getStatus() == 0) {
  87. queryWrapper.in(ZgxxzxPushLog::getStatus, 0, 2);
  88. }
  89. if (request.getStatus() == 1) {
  90. queryWrapper.in(ZgxxzxPushLog::getStatus, -1, 1);
  91. }
  92. Page<ZgxxzxPushLog> page = zgxxzxPushLogService.page(new Page<>(request.getPageNum(), request.getPageSize()), queryWrapper);
  93. return PageInfo.PageInfo(page);
  94. }
  95. @Override
  96. public void pushScene() {
  97. List<ZgxxzxPushLog> list = zgxxzxPushLogService.list(
  98. QueryWrapper.create().eq(ZgxxzxPushLog::getStatus, CommonOperStatus.WAITING.code())
  99. .orderBy(ZgxxzxPushLog::getId, true));
  100. if (CollUtil.isEmpty(list)) {
  101. return;
  102. }
  103. Department zgwwxxzx = departmentService.getByCode("zgwwxxzx");
  104. if (zgwwxxzx == null) {
  105. return;
  106. }
  107. for (ZgxxzxPushLog zgxxzxPushLog : list) {
  108. ScenePushBean pushBean = ScenePushBean.builder()
  109. .taskId(zgxxzxPushLog.getTaskId())
  110. .num(zgxxzxPushLog.getNum()).zipType("laser")
  111. .version(Calendar.getInstance().getTimeInMillis())
  112. .destUrl(zgwwxxzx.getDestUrl()).build();
  113. zgxxzxPushLog.setStatus(2);
  114. try {
  115. zgxxzxPushLogService.updateById(zgxxzxPushLog);
  116. sceneOfflinePackagePushService.scenePushHandler(pushBean);
  117. } catch (Exception e) {
  118. log.error("场景推送失败,num:{}", zgxxzxPushLog.getNum(), e);
  119. zgxxzxPushLog.setStatus(CommonOperStatus.FAILD.code());
  120. zgxxzxPushLogService.updateById(zgxxzxPushLog);
  121. }
  122. }
  123. }
  124. @Override
  125. public void syncPushResult() {
  126. List<ZgxxzxPushLog> list = zgxxzxPushLogService.list(
  127. QueryWrapper.create().eq(ZgxxzxPushLog::getStatus, 2)
  128. .orderBy(ZgxxzxPushLog::getId, true));
  129. if (CollUtil.isEmpty(list)) {
  130. return;
  131. }
  132. Department zgwwxxzx = departmentService.getByCode("zgwwxxzx");
  133. for (ZgxxzxPushLog zgxxzxPushLog : list) {
  134. ResultData<Integer> resultData = xxzxClient.getDeployStatus(zgwwxxzx.getDestUrl() + "/historyrical/scene/getDeployStatus?taskId=" + zgxxzxPushLog.getTaskId());
  135. Integer status = resultData.getData();
  136. if(status == CommonSuccessStatus.WAITING.code()){
  137. DateTime dateTime = DateExtUtil.offsetDay(new Date(), -7);
  138. if(zgxxzxPushLog.getCreateTime().before(dateTime)){//7天都还没部署成功的,值为失败
  139. zgxxzxPushLog.setStatus(CommonSuccessStatus.FAIL.code());
  140. }else{
  141. continue;
  142. }
  143. }else{
  144. zgxxzxPushLog.setStatus(status);
  145. }
  146. zgxxzxPushLog.setUpdateTime(null);
  147. }
  148. zgxxzxPushLogService.updateBatch(list);
  149. }
  150. }