From cfd0118ef446a66f91999afc7b1e46ca607adf50 Mon Sep 17 00:00:00 2001
From: jiangqs <jiangqs>
Date: 星期四, 13 七月 2023 20:32:35 +0800
Subject: [PATCH] 定时任务 统计

---
 ruoyi-modules/ruoyi-goods/src/main/java/com/ruoyi/goods/service/impl/activity/ActivityServiceImpl.java |  109 ++++++++++++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 101 insertions(+), 8 deletions(-)

diff --git a/ruoyi-modules/ruoyi-goods/src/main/java/com/ruoyi/goods/service/impl/activity/ActivityServiceImpl.java b/ruoyi-modules/ruoyi-goods/src/main/java/com/ruoyi/goods/service/impl/activity/ActivityServiceImpl.java
index 77d46a1..584441d 100644
--- a/ruoyi-modules/ruoyi-goods/src/main/java/com/ruoyi/goods/service/impl/activity/ActivityServiceImpl.java
+++ b/ruoyi-modules/ruoyi-goods/src/main/java/com/ruoyi/goods/service/impl/activity/ActivityServiceImpl.java
@@ -24,10 +24,7 @@
 import com.ruoyi.system.api.constant.AppErrorConstant;
 import com.ruoyi.system.api.constant.DelayTaskEnum;
 import com.ruoyi.system.api.constant.SecurityConstant;
-import com.ruoyi.system.api.domain.dto.ActivityGoodsGetDto;
-import com.ruoyi.system.api.domain.dto.MerPageDto;
-import com.ruoyi.system.api.domain.dto.MgtBaseBathDto;
-import com.ruoyi.system.api.domain.dto.MgtUserIdByKeywordDto;
+import com.ruoyi.system.api.domain.dto.*;
 import com.ruoyi.system.api.domain.poji.activity.ActivityGoods;
 import com.ruoyi.system.api.domain.poji.config.DelayTask;
 import com.ruoyi.system.api.domain.vo.ActivityGoodsGetVo;
@@ -37,6 +34,9 @@
 import com.ruoyi.system.api.service.RemoteConfigService;
 import com.ruoyi.system.api.service.RemoteMemberService;
 import com.ruoyi.system.api.service.RemoteShopService;
+import org.redisson.api.RLock;
+import org.redisson.api.RedissonClient;
+import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 
 import javax.annotation.Resource;
@@ -84,6 +84,8 @@
     @Resource
     private RedisService redisService;
 
+    @Autowired
+    private RedissonClient redissonClient;
 
     /**
      * @param mgtActivityEditDto
@@ -130,13 +132,12 @@
         // 根据当前时间和活动时间判断活动状态
         if (nowTime.compareTo(activityStartTime) < 0) {
             activity.setActivityStatus(0);
-        } else if (nowTime.compareTo(activityStartTime) >= 0 && nowTime.compareTo(activityEndTime) <= 0) {
-            activity.setActivityStatus(1);
-        } else if (nowTime.compareTo(activityEndTime) > 0) {
-            activity.setActivityStatus(2);
+        } else {
+            throw new ServiceException(AppErrorConstant.ACTIVITY_TIME_ERROR);
         }
         // 设置活动信息
         activity.setActivityName(mgtActivityEditDto.getActivityName());
+        activity.setActivityIntroduce(mgtActivityEditDto.getActivityIntroduce());
         activity.setActivityStartTime(activityStartTime);
         activity.setActivityEndTime(activityEndTime);
         activity.setGroupBuyNumber(mgtActivityEditDto.getGroupBuyNumber());
@@ -164,6 +165,7 @@
                         activityGoods.setActivityPrice(dto.getActivityPrice());
                         activityGoods.setActivitySubscription(dto.getActivitySubscription());
                         activityGoods.setActivityNumber(dto.getActivityNumber());
+                        activityGoods.setSalesNumber(0);
                         activityGoods.setActivityDeadline(activity.getActivityEndTime());
                         activityGoods.setSellOutFlag(0);
                         activityGoods.setPurchaseLimitationFlag(activity.getPurchaseLimitationFlag());
@@ -173,6 +175,38 @@
             ).collect(Collectors.toList());
             if (!activityGoodsList.isEmpty()) {
                 activityGoodsService.saveBatch(activityGoodsList);
+            }
+        }
+        //如果活动在1小时内生成自动开始任务的延时任务
+        Date checkTime = DateUtils.addMinutes(new Date(),61);
+        if(checkTime.compareTo(activityStartTime)>0){
+            String activityId = activity.getActivityId();
+            long currentTimeMillis = System.currentTimeMillis();
+            long startTimeDifference = currentTimeMillis - activityStartTime.getTime();
+            long endTimeDifference = currentTimeMillis - activityEndTime.getTime();
+            // 查询延时任务
+            DelayTask startDelayTask = remoteConfigService.getDelayTask(DelayTaskEnum.ACTIVITY_START_TASK.getCode() + "-" + activityId).getData();
+            // 如果延时任务为空,创建延时任务控制活动定时开始和结束
+            if (startDelayTask == null) {
+                redisService.setCacheObject(DelayTaskEnum.ACTIVITY_START_TASK.getCode() + "-" + activityId, activityStartTime, startTimeDifference, TimeUnit.MILLISECONDS);
+                startDelayTask = new DelayTask();
+                startDelayTask.setDelFlag(0);
+                startDelayTask.setCreateTime(new Date());
+                startDelayTask.setEndTime(activityStartTime);
+                startDelayTask.setRedisKey(DelayTaskEnum.ACTIVITY_START_TASK.getCode() + "-" + activityId);
+                remoteConfigService.addDelayTask(startDelayTask);
+            }
+            // 查询延时任务
+            DelayTask endDelayTask = remoteConfigService.getDelayTask(DelayTaskEnum.ACTIVITY_START_TASK.getCode() + "-" + activityId).getData();
+            // 如果延时任务为空,创建延时任务控制活动定时开始和结束
+            if (endDelayTask == null) {
+                redisService.setCacheObject(DelayTaskEnum.ACTIVITY_END_TASK.getCode() + "-" + activityId, activityEndTime, endTimeDifference, TimeUnit.MILLISECONDS);
+                endDelayTask = new DelayTask();
+                endDelayTask.setDelFlag(0);
+                endDelayTask.setCreateTime(new Date());
+                endDelayTask.setEndTime(activityEndTime);
+                endDelayTask.setRedisKey(DelayTaskEnum.ACTIVITY_END_TASK.getCode() + "-" + activityId);
+                remoteConfigService.addDelayTask(endDelayTask);
             }
         }
     }
@@ -469,4 +503,63 @@
             this.saveOrUpdate(activity);
         }
     }
+
+    /**
+     * @description  活动商品库存变化
+     * @author  jqs
+     * @date    2023/7/13 13:53
+     * @param
+     * @return  void
+     */
+    @Override
+    public void changeActivityTotal(ActivityTotalChangeDto activityTotalChangeDto){
+
+        RLock lock = redissonClient.getLock("activity_clock_"+activityTotalChangeDto.getActivityId());
+        try {
+            lock.lock(30, TimeUnit.SECONDS);
+            //判断活动商品是否售罄,是则停止活动
+            /*Integer noSellOut = activityMapper.checkSellOut(activityTotalChangeDto.getActivityId());
+            if(noSellOut==0){
+                endActivity(activityTotalChangeDto.getActivityId());
+            }*/
+            //更新活动统计
+            ActivityTotal activityTotal = activityTotalService.getById(activityTotalChangeDto.getActivityId());
+            if(activityTotalChangeDto.getChangeType()==1){
+                activityTotal.setOrderTotal(activityTotal.getOrderTotal()+activityTotalChangeDto.getChangeNum());
+                activityTotal.setPersonTotal(activityTotal.getPersonTotal()+activityTotalChangeDto.getPersonNum());
+                activityTotal.setOrderMoneyTotal(activityTotal.getOrderMoneyTotal().add(activityTotalChangeDto.getMoney()));
+            }else{
+                activityTotal.setOrderTotal(activityTotal.getOrderTotal()-activityTotalChangeDto.getChangeNum());
+                activityTotal.setPersonTotal(activityTotal.getPersonTotal()-activityTotalChangeDto.getPersonNum());
+                activityTotal.setRefundTotal(activityTotal.getRefundTotal()+activityTotalChangeDto.getRefundNum());
+                activityTotal.setOrderMoneyTotal(activityTotal.getOrderMoneyTotal().subtract(activityTotalChangeDto.getMoney()));
+            }
+            activityTotalService.saveOrUpdate(activityTotal);
+        } finally {
+            lock.unlock();
+        }
+    }
+
+    /**
+     * @description  活动商品库存变化
+     * @author  jqs
+     * @date    2023/7/13 13:53
+     * @param
+     * @return  void
+     */
+    @Override
+    public void changeActivityStock(AGStockChangeDto agStockChangeDto){
+        RLock lock = redissonClient.getLock("stock_clock_"+agStockChangeDto.getActivityId()+"_"+agStockChangeDto.getGoodsId());
+        try {
+            lock.lock(30, TimeUnit.SECONDS);
+            if(agStockChangeDto.getChangeType()==1){
+                activityMapper.addActivityGoodsStock(agStockChangeDto);
+            }else{
+                //更新库存
+                activityMapper.subActivityGoodsStock(agStockChangeDto);
+            }
+        } finally {
+            lock.unlock();
+        }
+    }
 }

--
Gitblit v1.7.1