From 1bcd5a3c6447a0a00dc450b8b7780dadbb8e0e56 Mon Sep 17 00:00:00 2001
From: gongzuming <gongzuming>
Date: 星期四, 19 九月 2024 18:59:18 +0800
Subject: [PATCH] 优化

---
 src/main/java/com/mzl/flower/service/point/PointGoodsService.java |   10 ++++++++--
 1 files changed, 8 insertions(+), 2 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 d0ee148..8639525 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
@@ -141,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>()
@@ -163,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);
 
@@ -215,6 +220,7 @@
         record.setOrderId(orderId);
         pointGoodsRecordMapper.updateById(record);
     }
+
     public void revertExchangeGoods(Long recordId) {
         PointGoodsRecord record = pointGoodsRecordMapper.selectById(recordId);
         if(record == null){
@@ -223,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