From ba17eded418c7eb1a14cdcd16a4d60619da8db73 Mon Sep 17 00:00:00 2001
From: Helius <wangdoubleone@gmail.com>
Date: Fri, 23 Sep 2022 19:28:11 +0800
Subject: [PATCH] fix

---
 src/main/java/cc/mrbird/febs/mall/quartz/OrderOvertimeJob.java |   45 ++++++++++++++++++++++++++++++++++++++-------
 1 files changed, 38 insertions(+), 7 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/mall/quartz/OrderOvertimeJob.java b/src/main/java/cc/mrbird/febs/mall/quartz/OrderOvertimeJob.java
index 25b37a7..4064e7c 100644
--- a/src/main/java/cc/mrbird/febs/mall/quartz/OrderOvertimeJob.java
+++ b/src/main/java/cc/mrbird/febs/mall/quartz/OrderOvertimeJob.java
@@ -1,14 +1,17 @@
 package cc.mrbird.febs.mall.quartz;
 
 import cc.mrbird.febs.common.enumerates.OrderStatusEnum;
+import cc.mrbird.febs.mall.entity.MallGoods;
+import cc.mrbird.febs.mall.entity.MallGoodsSku;
 import cc.mrbird.febs.mall.entity.MallOrderInfo;
-import cc.mrbird.febs.mall.mapper.MallMemberMapper;
-import cc.mrbird.febs.mall.mapper.MallOrderInfoMapper;
+import cc.mrbird.febs.mall.entity.MallOrderItem;
+import cc.mrbird.febs.mall.mapper.*;
 import cn.hutool.core.collection.CollUtil;
 import cn.hutool.core.date.DateUnit;
 import cn.hutool.core.date.DateUtil;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
 import org.springframework.scheduling.annotation.Scheduled;
 import org.springframework.stereotype.Component;
 
@@ -21,6 +24,7 @@
  **/
 @Slf4j
 @Component
+@ConditionalOnProperty(prefix = "system", name = "job", havingValue = "true")
 public class OrderOvertimeJob {
 
     @Autowired
@@ -28,6 +32,15 @@
 
     @Autowired
     private MallMemberMapper mallMemberMapper;
+
+    @Autowired
+    private MallOrderItemMapper mallOrderItemMapper;
+
+    @Autowired
+    private MallGoodsMapper mallGoodsMapper;
+
+    @Autowired
+    private MallGoodsSkuMapper mallGoodsSkuMapper;
 
     @Scheduled(cron = "0 0/5 * * * ? ")
     public void overtimeJob() {
@@ -41,6 +54,24 @@
                     orderInfo.setStatus(OrderStatusEnum.CANCEL.getValue());
                     orderInfo.setCancelType(MallOrderInfo.CANCEL_OVERTIME_NO_PAY);
                     orderInfoMapper.updateById(orderInfo);
+
+                    List<MallOrderItem> mallOrderItemList = mallOrderItemMapper.selectListByOrderId(orderInfo.getId());
+                    if (CollUtil.isNotEmpty(mallOrderItemList)) {
+                        for (MallOrderItem mallOrderItem : mallOrderItemList) {
+                            Long goodsId = mallOrderItem.getGoodsId();
+                            Long skuId = mallOrderItem.getSkuId();
+                            Integer cnt = mallOrderItem.getCnt();
+                            MallGoods mallGoods = mallGoodsMapper.selectById(goodsId);
+                            mallGoods.setVolume(mallGoods.getVolume() - cnt);
+                            mallGoods.setStock(mallGoods.getStock() + cnt);
+                            mallGoodsMapper.updateById(mallGoods);
+
+                            MallGoodsSku mallGoodsSku = mallGoodsSkuMapper.selectById(skuId);
+                            mallGoodsSku.setSkuVolume(mallGoodsSku.getSkuVolume() - cnt);
+                            mallGoodsSku.setStock(mallGoodsSku.getStock() + cnt);
+                            mallGoodsSkuMapper.updateById(mallGoodsSku);
+                        }
+                    }
                 }
             }
         }
@@ -48,9 +79,9 @@
     }
 
 //    @Scheduled(cron = "0/5 * * * * ? ")
-    public void wakeup() {
-        log.info("本地保持唤醒状态");
-        Long id = 5L;
-        mallMemberMapper.selectById(id);
-    }
+//    public void wakeup() {
+//        log.info("本地保持唤醒状态");
+//        Long id = 5L;
+//        mallMemberMapper.selectById(id);
+//    }
 }

--
Gitblit v1.9.1