From e425e5d101e1d48e40674a2a801efb8dd060e8a5 Mon Sep 17 00:00:00 2001
From: gongzuming <gongzuming>
Date: 星期五, 20 九月 2024 13:44:35 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master-v2'

---
 src/main/java/com/mzl/flower/service/point/PointGoodsService.java |   18 ++++++++++++++----
 1 files changed, 14 insertions(+), 4 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..e56ab9f 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);
@@ -135,7 +143,7 @@
             if(!Constants.POINT_GOODS_STATUS.A.name().equals(p.getStatus())){
                 throw new ValidationException("商品未上架");
             }
-            if(p.getStock()< dto.getNum()){
+            if(p.getStock() <=0 || p.getStock()< dto.getNum()){
                 throw new ValidationException("商品库存不足");
             }
             CustomerPoint cp = customerPointMapper.selectOne(new LambdaQueryWrapper<CustomerPoint>()
@@ -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);
 
@@ -179,8 +190,6 @@
             //更新库存
             p.setStock(p.getStock()- dto.getNum());
             pointGoodsMapper.updateById(p);
-        }catch (Exception e){
-            throw new ValidationException("兑换失败");
         }finally {
             lockService.releaseObjectLock(key,"");
         }
@@ -209,6 +218,7 @@
         record.setOrderId(orderId);
         pointGoodsRecordMapper.updateById(record);
     }
+
     public void revertExchangeGoods(Long recordId) {
         PointGoodsRecord record = pointGoodsRecordMapper.selectById(recordId);
         if(record == null){
@@ -217,7 +227,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