SceneUpgradeToV4Service.java 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  1. package com.fdkankan.scene.service.impl;
  2. import cn.hutool.core.util.StrUtil;
  3. import com.alibaba.fastjson.JSON;
  4. import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
  5. import com.fdkankan.common.constant.ErrorCode;
  6. import com.fdkankan.common.response.ResultData;
  7. import com.fdkankan.rabbitmq.util.RabbitMqProducer;
  8. import com.fdkankan.redis.constant.RedisKey;
  9. import com.fdkankan.redis.constant.RedisLockKey;
  10. import com.fdkankan.redis.util.RedisLockUtil;
  11. import com.fdkankan.redis.util.RedisUtil;
  12. import com.fdkankan.scene.bean.SceneUpgradeProgressBean;
  13. import com.fdkankan.scene.entity.SceneProEditV3;
  14. import com.fdkankan.scene.entity.SceneProV3;
  15. import com.fdkankan.scene.entity.SceneRepairLog;
  16. import com.fdkankan.scene.mapper.ISceneUpgradeMapper;
  17. import com.fdkankan.scene.service.ISceneProEditV3Service;
  18. import com.fdkankan.scene.service.ISceneProV3Service;
  19. import com.fdkankan.scene.service.ISceneRepairLogService;
  20. import com.fdkankan.scene.service.ISceneUpgradeToV4Service;
  21. import com.fdkankan.scene.vo.UpgradeToV4ParamVO;
  22. import java.util.HashMap;
  23. import java.util.Map;
  24. import java.util.Objects;
  25. import lombok.extern.slf4j.Slf4j;
  26. import org.springframework.beans.factory.annotation.Autowired;
  27. import org.springframework.beans.factory.annotation.Value;
  28. import org.springframework.stereotype.Service;
  29. /**
  30. * <p>
  31. * TODO
  32. * </p>
  33. *
  34. * @author dengsixing
  35. * @since 2022/4/21
  36. **/
  37. @Slf4j
  38. @Service
  39. public class SceneUpgradeToV4Service implements ISceneUpgradeToV4Service {
  40. @Value("${queue.scene.upgrade-to-v4}")
  41. private String upgradeToV4;
  42. @Autowired
  43. private ISceneProV3Service sceneProV3Service;
  44. @Autowired
  45. private ISceneProEditV3Service sceneProEditV3Service;
  46. @Autowired
  47. private ISceneUpgradeMapper sceneUpgradeMapper;
  48. @Autowired
  49. private RedisLockUtil redisLockUtil;
  50. @Autowired
  51. private ISceneRepairLogService sceneRepairLogService;
  52. @Autowired
  53. private RabbitMqProducer rabbitMqProducer;
  54. @Autowired
  55. private RedisUtil redisUtil;
  56. @Override
  57. public ResultData upgradeToV4(UpgradeToV4ParamVO param) {
  58. SceneProV3 sceneProV3 = JSON.parseObject(param.getScenePro(), SceneProV3.class);
  59. SceneProEditV3 sceneProEditV3 = JSON.parseObject(param.getSceneProEdit(), SceneProEditV3.class);
  60. //加锁
  61. String lockKey = String.format(RedisLockKey.LOCK_SCENE_UPGRADE_V4, sceneProV3.getNum());
  62. boolean lock = redisLockUtil.lock(lockKey,RedisKey.EXPIRE_TIME_2_HOUR);
  63. if(!lock){
  64. return ResultData.error(ErrorCode.FAILURE_CODE_7019);
  65. }
  66. try {
  67. //查询升级日志,如果已经升级成功,不允许重复升级
  68. SceneRepairLog sceneRepairLog = sceneRepairLogService.getOne(
  69. new LambdaQueryWrapper<SceneRepairLog>()
  70. .eq(SceneRepairLog::getNum, sceneProV3.getNum()));
  71. if(Objects.nonNull(sceneRepairLog)){
  72. if(sceneRepairLog.getState() == 0)
  73. return ResultData.error(ErrorCode.FAILURE_CODE_7019);
  74. if(sceneRepairLog.getState() == 1)
  75. return ResultData.error(ErrorCode.FAILURE_CODE_7020);
  76. }
  77. //写入sceneProV3
  78. sceneProV3Service.saveOrUpdate(sceneProV3);
  79. //写入sceneProEditV3
  80. sceneProEditV3Service.saveOrUpdate(sceneProEditV3);
  81. //写入写入sceneProEdit、写入sceneProEditExt
  82. sceneUpgradeMapper.transferSceneProEdit(sceneProEditV3.getId());
  83. sceneUpgradeMapper.transferSceneProEditExt(sceneProEditV3.getId());
  84. //同步到scenePro、sceneProExt
  85. sceneUpgradeMapper.transferScenePro(sceneProV3.getId());
  86. sceneUpgradeMapper.transferSceneProExt(sceneProV3.getId());
  87. //同步到scenePlus、scenePlus
  88. sceneUpgradeMapper.transferScenePlus(sceneProV3.getId());
  89. sceneUpgradeMapper.transferScenePlusExt(sceneProV3.getId());
  90. //todo 发送mq
  91. rabbitMqProducer.sendByWorkQueue(upgradeToV4, sceneProV3.getId());
  92. // TODO: 2022/4/22 写入进度条
  93. Map<String, Integer> progress = new HashMap<>();
  94. progress.put("status", 0);
  95. progress.put("progress", 0);
  96. redisUtil.set(RedisKey.scene_upgrade_progress_num, JSON.toJSONString(progress));
  97. }catch (Exception e){
  98. return ResultData.error(ErrorCode.FAILURE_CODE_7021);
  99. }finally {
  100. //解锁
  101. redisLockUtil.unlockLua(lockKey);
  102. }
  103. return ResultData.ok();
  104. }
  105. @Override
  106. public ResultData getUpgradeToV4Progress(String num) {
  107. String key = String.format(RedisKey.scene_upgrade_progress_num, num);
  108. String progress = redisUtil.get(key);
  109. SceneUpgradeProgressBean progressBean = null;
  110. if(StrUtil.isNotEmpty(progress)){
  111. progressBean = JSON.parseObject(progress, SceneUpgradeProgressBean.class);
  112. }else{
  113. progressBean = SceneUpgradeProgressBean.builder().num(num).status(0).progress(0).build();
  114. }
  115. return ResultData.ok(progressBean);
  116. }
  117. }