From 664184af3e070dee665ee736caffa0297804975f Mon Sep 17 00:00:00 2001
From: KKSU <15274802129@163.com>
Date: Tue, 18 Mar 2025 11:46:02 +0800
Subject: [PATCH] perf(mall): 移除会员利润计算中的异步执行

---
 src/main/java/cc/mrbird/febs/vip/service/impl/VipCommonServiceImpl.java |   81 +++++++++++++++++++++++++++++++---------
 1 files changed, 62 insertions(+), 19 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/vip/service/impl/VipCommonServiceImpl.java b/src/main/java/cc/mrbird/febs/vip/service/impl/VipCommonServiceImpl.java
index b2ba6e9..4714f0b 100644
--- a/src/main/java/cc/mrbird/febs/vip/service/impl/VipCommonServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/vip/service/impl/VipCommonServiceImpl.java
@@ -1,15 +1,13 @@
 package cc.mrbird.febs.vip.service.impl;
 
 import cc.mrbird.febs.common.enumerates.FlowTypeEnum;
-import cc.mrbird.febs.common.enumerates.MoneyFlowTypeEnum;
 import cc.mrbird.febs.common.enumerates.ScoreFlowTypeEnum;
-import cc.mrbird.febs.mall.entity.MallMember;
-import cc.mrbird.febs.mall.entity.MallOrderInfo;
-import cc.mrbird.febs.mall.entity.MallOrderItem;
+import cc.mrbird.febs.mall.entity.*;
 import cc.mrbird.febs.mall.mapper.MallMemberMapper;
 import cc.mrbird.febs.mall.mapper.MallOrderInfoMapper;
+import cc.mrbird.febs.mall.mapper.MallOrderItemMapper;
+import cc.mrbird.febs.mall.service.IApiMallGoodsService;
 import cc.mrbird.febs.mall.service.IApiMallMemberWalletService;
-import cc.mrbird.febs.mall.service.IApiMallOrderInfoService;
 import cc.mrbird.febs.mall.service.IMallMoneyFlowService;
 import cc.mrbird.febs.rabbit.producter.AgentProducer;
 import cc.mrbird.febs.vip.entity.MallVipBenefits;
@@ -19,6 +17,7 @@
 import cc.mrbird.febs.vip.service.IVipCommonService;
 import cn.hutool.core.collection.CollUtil;
 import cn.hutool.core.date.DateUtil;
+import cn.hutool.core.util.ObjectUtil;
 import cn.hutool.core.util.StrUtil;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import lombok.RequiredArgsConstructor;
@@ -27,8 +26,8 @@
 import org.springframework.transaction.annotation.Transactional;
 
 import java.math.BigDecimal;
-import java.util.Date;
-import java.util.List;
+import java.math.RoundingMode;
+import java.util.*;
 import java.util.stream.Collectors;
 
 @Slf4j
@@ -43,11 +42,18 @@
     private final MallMemberMapper mallMemberMapper;
     private final MallVipConfigMapper mallVipConfigMapper;
     private final AgentProducer agentProducer;
+    private final IApiMallGoodsService mallGoodsService;
+    private final MallOrderItemMapper mallOrderItemMapper;
 
     @Override
     @Transactional(rollbackFor = Exception.class)
     public void getScore(Long orderId) {
-        MallOrderInfo mallOrderInfo = mallOrderInfoMapper.selectOrderDetailsById(orderId);
+//        MallOrderInfo mallOrderInfo = mallOrderInfoMapper.selectOrderDetailsById(orderId);
+
+        MallOrderInfo mallOrderInfo = mallOrderInfoMapper.selectById(orderId);
+        List<MallOrderItem> mallOrderItemList = mallOrderItemMapper.selectListByOrderId(mallOrderInfo.getId());
+        mallOrderInfo.setItems(mallOrderItemList);
+
         if (mallOrderInfo == null) {
             return;
         }
@@ -55,6 +61,7 @@
         Long memberId = mallOrderInfo.getMemberId();
         MallVipBenefits mallVipBenefits = mallVipConfigService.hasVipBenefits(memberId);
 
+        MallMember member = mallMemberMapper.selectById(memberId);
         BigDecimal multiple = BigDecimal.ONE;
         String name = "";
         if (mallVipBenefits != null) {
@@ -63,23 +70,59 @@
         }
 
         List<String> skuNames = mallOrderInfo.getItems().stream().map(MallOrderItem::getSkuName).collect(Collectors.toList());
-        double sum = mallOrderInfo.getItems().stream().map(MallOrderItem::getAmount).mapToDouble(BigDecimal::doubleValue).sum();
+//        double sum = mallOrderInfo.getItems().stream().map(MallOrderItem::getAmount).mapToDouble(BigDecimal::doubleValue).sum();
+        BigDecimal sum = mallOrderInfo.getItems().stream().map(MallOrderItem::getAmount).reduce(BigDecimal.ZERO, BigDecimal::add);
 
-        int score = multiple.multiply(BigDecimal.valueOf(sum)).intValue();
+        int score = multiple.multiply(sum).intValue();
 
+        log.info("会员:{},购买商品:{},购买金额:{},会员等级:{},会员等级名称:{},会员等级积分倍数:{},会员获得积分:{}",
+                member.getName(),
+                skuNames,
+                sum,
+                member.getLevel(),
+                name,
+                multiple,
+                score);
         mallMoneyFlowService.addMoneyFlow(memberId, new BigDecimal(score), ScoreFlowTypeEnum.BUY.getValue(), mallOrderInfo.getOrderNo(), FlowTypeEnum.PRIZE_SCORE.getValue(), CollUtil.join(skuNames, ","), 2);
         mallMemberWalletService.add(new BigDecimal(score), memberId, "prizeScore");
 
-        agentProducer.sendVipLevelUp(orderId);
-        if (StrUtil.isNotBlank(mallOrderInfo.getTakeCode())) {
-            MallMember mallMember = mallMemberMapper.selectInfoByInviteId(mallOrderInfo.getTakeCode());
-            if (mallMember == null) {
-                return;
-            }
+        List<Long> itemGoodsIds = mallOrderInfo.getItems().stream().map(MallOrderItem::getGoodsId).distinct().collect(Collectors.toList());
+        List<MallGoods> goodsList = mallGoodsService.listByIds(itemGoodsIds);
+        Map<Long, MallGoods> goodsMap = goodsList.stream()
+                .filter(
+                        goods -> ObjectUtil.isNotEmpty(goods.getStaticMulti())
+                )
+                .collect(Collectors.toMap(MallGoods::getId, MallGoods -> MallGoods));
 
-            mallMoneyFlowService.addMoneyFlow(mallMember.getId(), new BigDecimal(score), ScoreFlowTypeEnum.RECOMMEND.getValue(), mallOrderInfo.getOrderNo(), FlowTypeEnum.PRIZE_SCORE.getValue(), CollUtil.join(skuNames, ","), 2);
-            mallMemberWalletService.add(new BigDecimal(score), mallMember.getId(), "prizeScore");
-        }
+        Map<Long, BigDecimal> recommendScoreMap = new HashMap<>();
+        mallOrderInfo.getItems().forEach(item -> {
+            if (StrUtil.isNotBlank(item.getMemberInviteId()) && !member.getInviteId().equals(item.getMemberInviteId())) {
+                MallGoods mallGoods = goodsMap.get(item.getGoodsId());
+                if (ObjectUtil.isEmpty(mallGoods)) {
+                    return;
+                }
+
+                BigDecimal multi = mallGoods.getStaticMulti().divide(BigDecimal.valueOf(100), 2, RoundingMode.HALF_UP);
+                MallMember mallMember = mallMemberMapper.selectInfoByInviteId(item.getMemberInviteId());
+                if (mallMember == null) {
+                    return;
+                }
+
+                BigDecimal recommendScore = recommendScoreMap.get(mallMember.getId());
+                recommendScore = recommendScore == null ? BigDecimal.ZERO : recommendScore;
+                recommendScore = recommendScore.add(item.getAmount().multiply(multi));
+
+                recommendScoreMap.put(mallMember.getId(), recommendScore);
+            }
+        });
+
+        recommendScoreMap.forEach((key, value) -> {
+            if (value != null) {
+                mallMoneyFlowService.addMoneyFlow(key, value, ScoreFlowTypeEnum.RECOMMEND.getValue(), mallOrderInfo.getOrderNo(), FlowTypeEnum.PRIZE_SCORE.getValue(), CollUtil.join(skuNames, ","), 2);
+                mallMemberWalletService.add(value, key, "prizeScore");
+            }
+        });
+
     }
 
     @Override

--
Gitblit v1.9.1