SceneUpgradeToV4Service.java 9.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246
  1. package com.fdkankan.scene.service.impl;
  2. import cn.hutool.core.exceptions.ExceptionUtil;
  3. import cn.hutool.core.util.StrUtil;
  4. import com.alibaba.fastjson.JSON;
  5. import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
  6. import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
  7. import com.fdkankan.common.constant.ConstantFilePath;
  8. import com.fdkankan.common.constant.ErrorCode;
  9. import com.fdkankan.common.constant.SceneResolution;
  10. import com.fdkankan.common.response.ResultData;
  11. import com.fdkankan.fyun.oss.UploadToOssUtil;
  12. import com.fdkankan.rabbitmq.util.RabbitMqProducer;
  13. import com.fdkankan.redis.constant.RedisKey;
  14. import com.fdkankan.redis.constant.RedisLockKey;
  15. import com.fdkankan.redis.util.RedisLockUtil;
  16. import com.fdkankan.redis.util.RedisUtil;
  17. import com.fdkankan.scene.bean.SceneUpgradeProgressBean;
  18. import com.fdkankan.scene.bean.UpgradeBean;
  19. import com.fdkankan.scene.entity.ScenePlus;
  20. import com.fdkankan.scene.entity.ScenePlusExt;
  21. import com.fdkankan.scene.entity.ScenePro;
  22. import com.fdkankan.scene.entity.SceneProEdit;
  23. import com.fdkankan.scene.entity.SceneProEditExt;
  24. import com.fdkankan.scene.entity.SceneProEditV3;
  25. import com.fdkankan.scene.entity.SceneProExt;
  26. import com.fdkankan.scene.entity.SceneProV3;
  27. import com.fdkankan.scene.entity.SceneRepairLog;
  28. import com.fdkankan.scene.mapper.ISceneUpgradeMapper;
  29. import com.fdkankan.scene.service.IScenePlusExtService;
  30. import com.fdkankan.scene.service.IScenePlusService;
  31. import com.fdkankan.scene.service.ISceneProEditExtService;
  32. import com.fdkankan.scene.service.ISceneProEditService;
  33. import com.fdkankan.scene.service.ISceneProEditV3Service;
  34. import com.fdkankan.scene.service.ISceneProExtService;
  35. import com.fdkankan.scene.service.ISceneProService;
  36. import com.fdkankan.scene.service.ISceneProV3Service;
  37. import com.fdkankan.scene.service.ISceneRepairLogService;
  38. import com.fdkankan.scene.service.ISceneUpgradeToV4Service;
  39. import com.fdkankan.scene.vo.SceneInfoVO;
  40. import com.fdkankan.scene.vo.UpgradeToV4ParamVO;
  41. import java.util.Calendar;
  42. import java.util.HashMap;
  43. import java.util.Map;
  44. import java.util.Objects;
  45. import lombok.extern.slf4j.Slf4j;
  46. import org.springframework.beans.factory.annotation.Autowired;
  47. import org.springframework.beans.factory.annotation.Value;
  48. import org.springframework.stereotype.Service;
  49. /**
  50. * <p>
  51. * TODO
  52. * </p>
  53. *
  54. * @author dengsixing
  55. * @since 2022/4/21
  56. **/
  57. @Slf4j
  58. @Service
  59. public class SceneUpgradeToV4Service implements ISceneUpgradeToV4Service {
  60. @Value("${queue.scene.upgrade-to-v4}")
  61. private String upgradeToV4;
  62. @Value("${oss.bucket:4dkankan}")
  63. private String bucket;
  64. @Autowired
  65. private ISceneProV3Service sceneProV3Service;
  66. @Autowired
  67. private ISceneProEditV3Service sceneProEditV3Service;
  68. @Autowired
  69. private ISceneUpgradeMapper sceneUpgradeMapper;
  70. @Autowired
  71. private RedisLockUtil redisLockUtil;
  72. @Autowired
  73. private ISceneRepairLogService sceneRepairLogService;
  74. @Autowired
  75. private RabbitMqProducer rabbitMqProducer;
  76. @Autowired
  77. private RedisUtil redisUtil;
  78. @Autowired
  79. private ISceneProService sceneProService;
  80. @Autowired
  81. private ISceneProExtService sceneProExtService;
  82. @Autowired
  83. private IScenePlusService scenePlusService;
  84. @Autowired
  85. private IScenePlusExtService scenePlusExtService;
  86. @Autowired
  87. private ISceneProEditService sceneProEditService;
  88. @Autowired
  89. private ISceneProEditExtService sceneProEditExtService;
  90. @Autowired
  91. private UploadToOssUtil uploadToOssUtil;
  92. @Override
  93. public ResultData upgradeToV4(UpgradeToV4ParamVO param) {
  94. SceneProV3 sceneProV3 = JSON.parseObject(param.getScenePro(), SceneProV3.class);
  95. SceneProEditV3 sceneProEditV3 = JSON.parseObject(param.getSceneProEdit(), SceneProEditV3.class);
  96. //加锁
  97. String lockKey = String.format(RedisLockKey.LOCK_SCENE_UPGRADE_V4, sceneProV3.getNum());
  98. boolean lock = redisLockUtil.lock(lockKey,RedisKey.EXPIRE_TIME_2_HOUR);
  99. if(!lock){
  100. return ResultData.error(ErrorCode.FAILURE_CODE_7019);
  101. }
  102. //查询升级日志,如果已经升级成功,不允许重复升级
  103. SceneRepairLog sceneRepairLog = null;
  104. try {
  105. sceneRepairLog = sceneRepairLogService.getOne(
  106. new LambdaQueryWrapper<SceneRepairLog>()
  107. .eq(SceneRepairLog::getNum, sceneProV3.getNum())
  108. .orderByDesc(SceneRepairLog::getId)
  109. .last("limit 1"));
  110. if(Objects.nonNull(sceneRepairLog)){
  111. if(sceneRepairLog.getState() == 0){
  112. return ResultData.error(ErrorCode.FAILURE_CODE_7019);
  113. }
  114. if(!param.isReUpgrade()){
  115. if(sceneRepairLog.getState() == 1){
  116. return ResultData.error(ErrorCode.FAILURE_CODE_7020);
  117. }
  118. }
  119. }
  120. //写入升级日志
  121. this.upgradeLog(null, sceneProV3.getNum(), 0, null);
  122. //写入sceneProV3
  123. sceneProV3Service.saveOrUpdate(sceneProV3);
  124. //写入sceneProEditV3
  125. sceneProEditV3Service.saveOrUpdate(sceneProEditV3);
  126. //写入sceneProEdit、写入sceneProEditExt
  127. sceneUpgradeMapper.deleteSceneProEdit(sceneProEditV3.getId());
  128. sceneUpgradeMapper.transferSceneProEdit(sceneProEditV3.getId());
  129. sceneUpgradeMapper.deleteSceneProEditExt(sceneProEditV3.getId());
  130. sceneUpgradeMapper.transferSceneProEditExt(sceneProEditV3.getId());
  131. //同步到scenePro、sceneProExt
  132. sceneUpgradeMapper.deleteScenePro(sceneProV3.getId());
  133. sceneUpgradeMapper.transferScenePro(sceneProV3.getId());
  134. sceneUpgradeMapper.deleteSceneProExt(sceneProV3.getId());
  135. sceneUpgradeMapper.transferSceneProExt(sceneProV3.getId());
  136. //国际版需要兼容切片图
  137. ScenePro scenePro = sceneProService.getById(sceneProV3.getId());
  138. SceneProExt sceneProExt = sceneProExtService.findBySceneProId(scenePro.getId());
  139. if(scenePro.getSceneScheme() == 3){
  140. sceneProExt.setSceneResolution(SceneResolution.TILES.code());
  141. sceneProExtService.updateById(sceneProExt);
  142. }
  143. //同步到scenePlus、scenePlus
  144. sceneUpgradeMapper.deleteScenePlus(sceneProV3.getId());
  145. sceneUpgradeMapper.transferScenePlus(sceneProV3.getId());
  146. sceneUpgradeMapper.deleteScenePlusExt(sceneProV3.getId());
  147. sceneUpgradeMapper.transferScenePlusExt(sceneProV3.getId());
  148. //写入进度条
  149. Map<String, Integer> progress = new HashMap<>();
  150. progress.put("status", 0);
  151. progress.put("progress", 0);
  152. redisUtil.set(RedisKey.scene_upgrade_progress_num, JSON.toJSONString(progress));
  153. //发送mq
  154. rabbitMqProducer.sendByWorkQueue(upgradeToV4,
  155. UpgradeBean.builder()
  156. .sceneProId(sceneProV3.getId())
  157. .reUpgrade(param.isReUpgrade())
  158. .build());
  159. }catch (Exception e){
  160. log.error("场景升级失败", e);
  161. this.upgradeLog(sceneRepairLog, sceneProV3.getNum(), 2, ExceptionUtil.stacktraceToString(e, 3000));
  162. return ResultData.error(ErrorCode.FAILURE_CODE_7021);
  163. }
  164. return ResultData.ok();
  165. }
  166. private void upgradeLog(SceneRepairLog sceneRepairLog, String num, int status, String reason){
  167. //写入升级日志
  168. if(Objects.isNull(sceneRepairLog)){
  169. sceneRepairLog = new SceneRepairLog();
  170. sceneRepairLog.setNum(num);
  171. }
  172. sceneRepairLog.setState(status);
  173. sceneRepairLog.setReason(reason);
  174. sceneRepairLog.setCreateTime(Calendar.getInstance().getTime());
  175. sceneRepairLogService.saveOrUpdate(sceneRepairLog);
  176. }
  177. @Override
  178. public ResultData getUpgradeToV4Progress(String num) {
  179. String key = String.format(RedisKey.scene_upgrade_progress_num, num);
  180. String progress = redisUtil.get(key);
  181. SceneUpgradeProgressBean progressBean = null;
  182. if(StrUtil.isNotEmpty(progress)){
  183. progressBean = JSON.parseObject(progress, SceneUpgradeProgressBean.class);
  184. }else{
  185. progressBean = SceneUpgradeProgressBean.builder().num(num).status(0).progress(0).build();
  186. }
  187. return ResultData.ok(progressBean);
  188. }
  189. @Override
  190. public ResultData getSceneViewInfo(String num) {
  191. ScenePlus scenePlus = scenePlusService.getScenePlusByNum(num);
  192. String key = String.format(RedisKey.SCENE_JSON, num);
  193. String sceneJson = redisUtil.get(key);
  194. SceneInfoVO sceneInfoVO = null;
  195. //先查询redis
  196. if(StrUtil.isNotEmpty(sceneJson)) {
  197. sceneInfoVO = JSON.parseObject(sceneJson, SceneInfoVO.class);
  198. sceneInfoVO.setScenePassword(null);
  199. if(Objects.isNull(sceneInfoVO.getFloorPlanAngle())){
  200. sceneInfoVO.setFloorPlanAngle(0f);
  201. }
  202. if(Objects.isNull(sceneInfoVO.getFloorPlanCompass())){
  203. sceneInfoVO.setFloorPlanCompass(0f);
  204. }
  205. return ResultData.ok(sceneInfoVO);
  206. }
  207. //如果redis没找到,从scene.json中获取
  208. String objectName = String.format(ConstantFilePath.SCENE_VIEW_DATA_DATA_SCENEJSON, num);
  209. String objectContent = uploadToOssUtil.getObjectContent(bucket, objectName);
  210. if(StrUtil.isEmpty(objectContent))
  211. return ResultData.ok();
  212. sceneInfoVO = JSON.parseObject(objectContent, SceneInfoVO.class);
  213. sceneInfoVO.setScenePassword(null);
  214. if(Objects.isNull(sceneInfoVO.getFloorPlanAngle())){
  215. sceneInfoVO.setFloorPlanAngle(0f);
  216. }
  217. if(Objects.isNull(sceneInfoVO.getFloorPlanCompass())){
  218. sceneInfoVO.setFloorPlanCompass(0f);
  219. }
  220. return ResultData.ok(sceneInfoVO);
  221. }
  222. }