From f6137d2b84e7249548b2efd8d32db6e814eef3d2 Mon Sep 17 00:00:00 2001
From: Cui Zhi Feng <cuizf@fengyuntec.com>
Date: 星期五, 13 九月 2024 18:58:20 +0800
Subject: [PATCH] 打印价格计算 双倍bug

---
 src/main/java/com/mzl/flower/service/point/PointGoodsService.java |   14 +++++++++++++-
 1 files changed, 13 insertions(+), 1 deletions(-)

diff --git a/src/main/java/com/mzl/flower/service/point/PointGoodsService.java b/src/main/java/com/mzl/flower/service/point/PointGoodsService.java
index e719c85..69c144b 100644
--- a/src/main/java/com/mzl/flower/service/point/PointGoodsService.java
+++ b/src/main/java/com/mzl/flower/service/point/PointGoodsService.java
@@ -19,6 +19,7 @@
 import com.mzl.flower.mapper.point.PointGoodsRecordMapper;
 import com.mzl.flower.service.BaseService;
 import com.mzl.flower.service.payment.RedisLockService;
+import com.mzl.flower.utils.DateUtils;
 import com.mzl.flower.utils.UUIDGenerator;
 import org.springframework.beans.BeanUtils;
 import org.springframework.beans.factory.annotation.Autowired;
@@ -26,6 +27,7 @@
 import org.springframework.transaction.annotation.Transactional;
 
 import java.time.LocalDate;
+import java.time.LocalDateTime;
 import java.util.List;
 
 @Service
@@ -114,6 +116,12 @@
                     continue;
                 }
 
+                if(Constants.POINT_GOODS_STATUS.A.name().equals(status)){
+                    if(p.getStock() == null || p.getStock() <= 0){
+                        throw new ValidationException("商品" + p.getName() + "库存为0不能上架");
+                    }
+                }
+
                 p.setStatus(status);
                 p.update(SecurityUtils.getUserId());
                 pointGoodsMapper.updateById(p);
@@ -157,6 +165,9 @@
             record.setCover(p.getCover());
             record.setRedeemCode(UUIDGenerator.getUUID());
             record.setStatus(Constants.POINT_GOODS_RECORD_STATUS.A.name());//未使用
+            LocalDate expireDate = LocalDate.now().plusYears(1);
+            String expireDateStr = DateUtils.toString(expireDate,"yyyy-MM-dd");
+            record.setExpireTime(DateUtils.dateToLocalDateTime(expireDateStr,false));
             record.create(SecurityUtils.getUserId());
             pointGoodsRecordMapper.insert(record);
 
@@ -209,6 +220,7 @@
         record.setOrderId(orderId);
         pointGoodsRecordMapper.updateById(record);
     }
+
     public void revertExchangeGoods(Long recordId) {
         PointGoodsRecord record = pointGoodsRecordMapper.selectById(recordId);
         if(record == null){
@@ -217,7 +229,7 @@
         if(!Constants.POINT_GOODS_RECORD_STATUS.U.name().equals(record.getStatus())){
             throw new ValidationException("兑换券未使用或过期");
         }
-        if(!SecurityUtils.getUserId().equals(record.getUserId())){
+        if(SecurityUtils.getUserId() != null && !SecurityUtils.getUserId().equals(record.getUserId())){
             throw new ValidationException("兑换券不属于当前用户");
         }
         record.setStatus(Constants.POINT_GOODS_RECORD_STATUS.A.name());

--
Gitblit v1.9.3