From e11362ca4849da567a77d8b5e5be510df9fb0741 Mon Sep 17 00:00:00 2001
From: hjl <1657978663@qq.com>
Date: 星期一, 17 六月 2024 11:51:51 +0800
Subject: [PATCH] fix: 学习端bug

---
 ruoyi-service/ruoyi-goods/src/main/java/com/ruoyi/goods/service/impl/TGoodsServiceImpl.java |   29 ++++++++++++++++++-----------
 1 files changed, 18 insertions(+), 11 deletions(-)

diff --git a/ruoyi-service/ruoyi-goods/src/main/java/com/ruoyi/goods/service/impl/TGoodsServiceImpl.java b/ruoyi-service/ruoyi-goods/src/main/java/com/ruoyi/goods/service/impl/TGoodsServiceImpl.java
index 4eae5a5..cca412f 100644
--- a/ruoyi-service/ruoyi-goods/src/main/java/com/ruoyi/goods/service/impl/TGoodsServiceImpl.java
+++ b/ruoyi-service/ruoyi-goods/src/main/java/com/ruoyi/goods/service/impl/TGoodsServiceImpl.java
@@ -4,6 +4,7 @@
 import com.ruoyi.common.core.constant.Constants;
 import com.ruoyi.common.core.constant.RedisConstants;
 import com.ruoyi.common.core.domain.R;
+import com.ruoyi.common.core.exception.GlobalException;
 import com.ruoyi.common.security.service.TokenService;
 import com.ruoyi.goods.domain.Recipient;
 import com.ruoyi.goods.domain.TGoods;
@@ -16,7 +17,7 @@
 import com.ruoyi.goods.vo.TGoodsVO;
 import com.ruoyi.study.api.domain.TUser;
 import com.ruoyi.study.api.feignClient.StudyClient;
-import com.ruoyi.system.api.model.LoginUserParent;
+import com.ruoyi.study.api.vo.UserPersonalCenterVO;
 import org.redisson.api.RSemaphore;
 import org.redisson.api.RedissonClient;
 import org.springframework.stereotype.Service;
@@ -75,22 +76,26 @@
             return R.exchangeError("商品不存在,请稍后重试!");
         }
         // 校验用户积分是否足够兑换
-        TUser user = studyClient.userInfo().getData();
-        LoginUserParent loginUser1 = tokenService.getLoginUser1();
-        if (user == null){
-            user = studyClient.getUserById(loginUser1.getUserid()).getData();
+        UserPersonalCenterVO userPersonalCenter = studyClient.userInfo().getData();
+        if (null == userPersonalCenter) {
+            throw new GlobalException("用户信息获取失败!");
         }
+        TUser user = userPersonalCenter.getUser();
         int needIntegral = good.getIntegral() * number;
         if (user.getIntegral() < needIntegral) {
             return R.exchangeError("兑换失败,当前剩余积分不足!");
         }
         // 检查用户兑换数量是否超过单用户最大兑换数量
-        List<TOrder> orderList = orderService.lambdaQuery().eq(TOrder::getUserId, user.getId()).eq(TOrder::getGoodsId, goodId).list();
+        List<TOrder> orderList = orderService.lambdaQuery().eq(TOrder::getUserId, user.getId())
+                .eq(TOrder::getGoodsId, goodId).list();
         // 该商品订单为空、订单数量未超过商品的单个用户兑换上限数量时,可以进行兑换
-        int totalNumber = orderList.stream().map(TOrder::getCount).collect(Collectors.toList()).stream().mapToInt(Integer::intValue).sum();
-        boolean canExchange = orderList.isEmpty() || null == good.getUserCount() || (totalNumber + number) <= good.getUserCount();
+        int totalNumber = orderList.stream().map(TOrder::getCount).collect(Collectors.toList())
+                .stream().mapToInt(Integer::intValue).sum();
+        boolean canExchange = orderList.isEmpty() || null == good.getUserCount() ||
+                (totalNumber + number) <= good.getUserCount();
         if (!canExchange) {
-            return R.exchangeError("兑换失败,当前兑换数量已超过最大兑换数量,剩余兑换数量为: " + (good.getUserCount() - totalNumber) + "!");
+            return R.exchangeError("兑换失败,当前兑换数量已超过最大兑换数量,剩余兑换数量为: " +
+                    (good.getUserCount() - totalNumber) + "!");
         }
         // redisson分布式锁,防止超卖
         String key = String.format(RedisConstants.GOOD_STOCK, good.getId());
@@ -111,7 +116,8 @@
         // 扣除用户积分
         result = result && studyClient.exchangeIntegral(needIntegral, Constants.BURDEN).getData();
         // 扣除库存
-        result = result && this.lambdaUpdate().set(TGoods::getSurplus, good.getSurplus() - number).eq(TGoods::getId, good.getId()).update();
+        result = result && this.lambdaUpdate().set(TGoods::getSurplus, good.getSurplus() - number)
+                .eq(TGoods::getId, good.getId()).update();
         if (!result) {
             semaphore.release(number);
             return R.exchangeError("商品兑换失败!");
@@ -129,7 +135,7 @@
             return R.exchangeError("商品不存在,请稍后重试!");
         }
         // 校验用户积分是否足够兑换
-        if (tokenService.getLoginUser1() == null){
+        if (tokenService.getLoginUser1() == null) {
             return R.tokenError("登录失效");
         }
         TUser user = studyClient.getUserById(tokenService.getLoginUser1().getUserid()).getData();
@@ -188,6 +194,7 @@
         order.setDisabled(Boolean.FALSE);
         return order;
     }
+
     private TOrder orderInfo1(GoodExchangeDTO goodExchange, Recipient recipient, Integer number, Integer goodId, int needIntegral) {
         TOrder order = new TOrder();
         order.setOrderNumber(goodExchange.getOrderNumber());

--
Gitblit v1.7.1