From be7a5df652f0722ae897df560b2afdb06d8c268f Mon Sep 17 00:00:00 2001
From: Hentua <wangdoubleone@gmail.com>
Date: Thu, 25 Jan 2024 22:12:48 +0800
Subject: [PATCH] 确认收货会员升级

---
 src/main/java/cc/mrbird/febs/rabbit/enumerates/RabbitQueueEnum.java             |    4 +
 src/main/java/cc/mrbird/febs/common/configure/RabbitConfigure.java              |   16 +++++
 src/main/java/cc/mrbird/febs/mall/quartz/OrderSettlementJob.java                |    8 ++
 src/main/java/cc/mrbird/febs/rabbit/consumer/AgentConsumer.java                 |   10 +++
 src/main/java/cc/mrbird/febs/vip/entity/MallVipConfig.java                      |    3 
 src/main/java/cc/mrbird/febs/vip/service/impl/VipCommonServiceImpl.java         |   99 +++++++++++++++++++++++++++++++++
 src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java |    2 
 src/main/java/cc/mrbird/febs/rabbit/constants/QueueConstants.java               |    1 
 src/main/java/cc/mrbird/febs/rabbit/producter/AgentProducer.java                |    7 ++
 src/main/java/cc/mrbird/febs/vip/service/IVipCommonService.java                 |    2 
 src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java    |    8 ++
 11 files changed, 157 insertions(+), 3 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/common/configure/RabbitConfigure.java b/src/main/java/cc/mrbird/febs/common/configure/RabbitConfigure.java
index 3dc6481..5c4f242 100644
--- a/src/main/java/cc/mrbird/febs/common/configure/RabbitConfigure.java
+++ b/src/main/java/cc/mrbird/febs/common/configure/RabbitConfigure.java
@@ -154,4 +154,20 @@
         return BindingBuilder.bind(getScoreMsgQueue()).to(getScoreMsgExchange()).with(RabbitQueueEnum.GET_SCORE_MSG.getRoute());
     }
 
+
+    @Bean
+    public DirectExchange vipLevelUp() {
+        return new DirectExchange(RabbitQueueEnum.VIP_LEVEL_UP.getExchange());
+    }
+
+    @Bean
+    public Queue vipLevelUpQueue() {
+        return new Queue(QueueConstants.VIP_LEVEL_UP);
+    }
+
+    @Bean
+    public Binding vipLevelUpBind() {
+        return BindingBuilder.bind(vipLevelUpQueue()).to(vipLevelUp()).with(RabbitQueueEnum.VIP_LEVEL_UP.getRoute());
+    }
+
 }
diff --git a/src/main/java/cc/mrbird/febs/mall/quartz/OrderSettlementJob.java b/src/main/java/cc/mrbird/febs/mall/quartz/OrderSettlementJob.java
index d532430..7b9b5c7 100644
--- a/src/main/java/cc/mrbird/febs/mall/quartz/OrderSettlementJob.java
+++ b/src/main/java/cc/mrbird/febs/mall/quartz/OrderSettlementJob.java
@@ -11,6 +11,7 @@
 import cc.mrbird.febs.mall.service.IMallAchieveService;
 import cc.mrbird.febs.mall.service.IMallMoneyFlowService;
 import cc.mrbird.febs.mall.service.IMemberProfitService;
+import cc.mrbird.febs.rabbit.producter.AgentProducer;
 import cn.hutool.core.collection.CollUtil;
 import cn.hutool.core.date.DateTime;
 import cn.hutool.core.date.DateUtil;
@@ -68,6 +69,9 @@
 
     @Autowired
     private IMallAchieveService mallAchieveService;
+
+    @Autowired
+    private AgentProducer agentProducer;
 
     /**
      * 普通商品结算
@@ -144,6 +148,10 @@
 //                }
 //            }
             mallOrderInfoMapper.updateOrderConfirmStatus(DateUtil.date(),DateUtil.offsetDay(new Date(), -value));
+
+            orderInfos.forEach(item -> {
+                agentProducer.sendVipLevelUp(item.getId());
+            });
         }
     }
     /**
diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java
index 53f5611..bf4b5ca 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java
@@ -130,7 +130,6 @@
         mallMember.setName(registerDto.getName());
         mallMember.setAccountStatus(MallMember.ACCOUNT_STATUS_ENABLE);
         mallMember.setAccountType(MallMember.ACCOUNT_TYPE_NORMAL);
-        mallMember.setLevel(AgentLevelEnum.ZERO_LEVEL.name());
         mallMember.setSex("男");
         mallMember.setBindPhone(registerDto.getAccount());
 
@@ -722,6 +721,13 @@
         if (apiXcxSaveInfoDto.getBirthday() != null) {
             mallMember.setBirthday(apiXcxSaveInfoDto.getBirthday());
         }
+
+        List<MallVipConfig> configs = mallVipConfigMapper.selectVipConfigList();
+        if (CollUtil.isNotEmpty(configs)) {
+            MallVipConfig mallVipConfig = configs.get(0);
+            mallMember.setLevel(mallVipConfig.getCode());
+        }
+
         mallMember.setSex(1 == apiXcxSaveInfoDto.getGender() ? "女" : "男");
         this.baseMapper.updateById(mallMember);
         return new FebsResponse().success();
diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java
index a612d58..ca2324c 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java
@@ -580,6 +580,8 @@
         orderInfo.setReceivingTime(new Date());
         this.baseMapper.updateById(orderInfo);
 
+        agentProducer.sendVipLevelUp(orderInfo.getId());
+
         //生成一条团长提成记录
 //        Long orderInfoId = orderInfo.getId();
 //        List<MallOrderItem> mallOrderItemList = mallOrderItemMapper.selectListByOrderId(orderInfoId);
diff --git a/src/main/java/cc/mrbird/febs/rabbit/constants/QueueConstants.java b/src/main/java/cc/mrbird/febs/rabbit/constants/QueueConstants.java
index 2470a96..1de63b7 100644
--- a/src/main/java/cc/mrbird/febs/rabbit/constants/QueueConstants.java
+++ b/src/main/java/cc/mrbird/febs/rabbit/constants/QueueConstants.java
@@ -14,4 +14,5 @@
     public static final String ORDER_COUPON = "queue_order_coupon";
 
     public static final String GET_SCORE_MSG = "queue_get_score_msg";
+    public static final String VIP_LEVEL_UP = "queue_vip_level_up";
 }
diff --git a/src/main/java/cc/mrbird/febs/rabbit/consumer/AgentConsumer.java b/src/main/java/cc/mrbird/febs/rabbit/consumer/AgentConsumer.java
index 972bd28..366ac20 100644
--- a/src/main/java/cc/mrbird/febs/rabbit/consumer/AgentConsumer.java
+++ b/src/main/java/cc/mrbird/febs/rabbit/consumer/AgentConsumer.java
@@ -96,4 +96,14 @@
             log.error("获取积分消息异常", e);
         }
     }
+
+    @RabbitListener(queues = QueueConstants.VIP_LEVEL_UP)
+    public void vipLevelUp(Long orderId) {
+        log.info("收到会员升级消息:{}", orderId);
+        try {
+            vipCommonService.levelUp(orderId);
+        } catch (Exception e) {
+            log.error("会员升级消息异常", e);
+        }
+    }
 }
diff --git a/src/main/java/cc/mrbird/febs/rabbit/enumerates/RabbitQueueEnum.java b/src/main/java/cc/mrbird/febs/rabbit/enumerates/RabbitQueueEnum.java
index 8d11cf6..f567b9c 100644
--- a/src/main/java/cc/mrbird/febs/rabbit/enumerates/RabbitQueueEnum.java
+++ b/src/main/java/cc/mrbird/febs/rabbit/enumerates/RabbitQueueEnum.java
@@ -17,7 +17,9 @@
 
     ORDER_COUPON("exchange_order_coupon", "route_key_order_coupon", QueueConstants.ORDER_COUPON),
 
-    GET_SCORE_MSG("exchange_get_score_msg", "route_key_get_score_msg", QueueConstants.GET_SCORE_MSG);
+    GET_SCORE_MSG("exchange_get_score_msg", "route_key_get_score_msg", QueueConstants.GET_SCORE_MSG),
+
+    VIP_LEVEL_UP("exchange_vip_level_up", "route_key_vip_level_up", QueueConstants.VIP_LEVEL_UP);
 
     private String exchange;
 
diff --git a/src/main/java/cc/mrbird/febs/rabbit/producter/AgentProducer.java b/src/main/java/cc/mrbird/febs/rabbit/producter/AgentProducer.java
index d18c404..501fdbb 100644
--- a/src/main/java/cc/mrbird/febs/rabbit/producter/AgentProducer.java
+++ b/src/main/java/cc/mrbird/febs/rabbit/producter/AgentProducer.java
@@ -90,4 +90,11 @@
         CorrelationData correlationData = new CorrelationData(UUID.randomUUID().toString());
         rabbitTemplate.convertAndSend(RabbitQueueEnum.GET_SCORE_MSG.getExchange(), RabbitQueueEnum.GET_SCORE_MSG.getRoute(), orderId, correlationData);
     }
+
+    public void sendVipLevelUp(Long orderId) {
+        log.info("发送会员升级消息:{}", orderId);
+
+        CorrelationData correlationData = new CorrelationData(UUID.randomUUID().toString());
+        rabbitTemplate.convertAndSend(RabbitQueueEnum.VIP_LEVEL_UP.getExchange(), RabbitQueueEnum.VIP_LEVEL_UP.getRoute(), orderId, correlationData);
+    }
 }
diff --git a/src/main/java/cc/mrbird/febs/vip/entity/MallVipConfig.java b/src/main/java/cc/mrbird/febs/vip/entity/MallVipConfig.java
index c2d59b3..c9670a3 100644
--- a/src/main/java/cc/mrbird/febs/vip/entity/MallVipConfig.java
+++ b/src/main/java/cc/mrbird/febs/vip/entity/MallVipConfig.java
@@ -7,6 +7,7 @@
 import io.swagger.annotations.ApiModelProperty;
 import lombok.Data;
 
+import java.math.BigDecimal;
 import java.util.List;
 
 @Data
@@ -56,7 +57,7 @@
     /**
      * 消费金额
      */
-    private Double amount;
+    private BigDecimal amount;
 
     /**
      * 指定月数
diff --git a/src/main/java/cc/mrbird/febs/vip/service/IVipCommonService.java b/src/main/java/cc/mrbird/febs/vip/service/IVipCommonService.java
index 9cf7861..e07a285 100644
--- a/src/main/java/cc/mrbird/febs/vip/service/IVipCommonService.java
+++ b/src/main/java/cc/mrbird/febs/vip/service/IVipCommonService.java
@@ -3,4 +3,6 @@
 public interface IVipCommonService {
 
     void getScore(Long orderId);
+
+    void levelUp(Long orderId);
 }
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 2f1d1b1..c62a9f9 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
@@ -3,21 +3,30 @@
 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.mapper.MallMemberMapper;
 import cc.mrbird.febs.mall.mapper.MallOrderInfoMapper;
 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.vip.entity.MallVipBenefits;
+import cc.mrbird.febs.vip.entity.MallVipConfig;
+import cc.mrbird.febs.vip.mapper.MallVipConfigMapper;
 import cc.mrbird.febs.vip.service.IMallVipConfigService;
 import cc.mrbird.febs.vip.service.IVipCommonService;
+import cn.hutool.core.collection.CollUtil;
+import cn.hutool.core.date.DateUtil;
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import lombok.RequiredArgsConstructor;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 
 import java.math.BigDecimal;
+import java.util.Date;
+import java.util.List;
 
 @Slf4j
 @Service
@@ -28,6 +37,8 @@
     private final IMallVipConfigService mallVipConfigService;
     private final IMallMoneyFlowService mallMoneyFlowService;
     private final IApiMallMemberWalletService mallMemberWalletService;
+    private final MallMemberMapper mallMemberMapper;
+    private final MallVipConfigMapper mallVipConfigMapper;
 
     @Override
     @Transactional(rollbackFor = Exception.class)
@@ -54,4 +65,92 @@
         mallMoneyFlowService.addMoneyFlow(memberId, new BigDecimal(score), ScoreFlowTypeEnum.BUY.getValue(), mallOrderInfo.getOrderNo(), FlowTypeEnum.PRIZE_SCORE.getValue(), name, 2);
         mallMemberWalletService.add(new BigDecimal(score), memberId, "prize_score");
     }
+
+    @Override
+    public void levelUp(Long orderId) {
+        MallOrderInfo mallOrderInfo = mallOrderInfoMapper.selectOrderDetailsById(orderId);
+        if (mallOrderInfo == null) {
+            return;
+        }
+
+        MallMember member = mallMemberMapper.selectById(mallOrderInfo.getMemberId());
+        if (member == null) {
+            log.info("会员不存在");
+            return;
+        }
+
+        MallVipConfig config = mallVipConfigMapper.selectVipConfigByCode(member.getLevel());
+        if (config == null) {
+            log.info("会员等级配置不存在");
+            return;
+        }
+
+        LambdaQueryWrapper<MallVipConfig> configQuery = new LambdaQueryWrapper<>();
+        configQuery.gt(MallVipConfig::getLevel, config.getLevel())
+                .orderByAsc(MallVipConfig::getLevel)
+                .last("limit 1");
+        MallVipConfig nextLevel = mallVipConfigMapper.selectOne(configQuery);
+
+        // 指定商品
+        if (nextLevel.getType() == 1) {
+            boolean hasMatch = mallOrderInfo.getItems().stream().anyMatch(item -> {
+                return item.getGoodsId().equals(nextLevel.getTargetId());
+            });
+
+            if (!hasMatch) {
+                log.info("未购买指定商品");
+                return;
+            }
+
+            MallMember update = new MallMember();
+            update.setId(member.getId());
+            update.setLevel(nextLevel.getCode());
+            mallMemberMapper.updateById(update);
+            return;
+        }
+
+        //
+        if (nextLevel.getType() == 2) {
+            Date endTime = DateUtil.endOfDay(new Date());
+            Date startTime = getStartTime(nextLevel.getValidType());
+
+            LambdaQueryWrapper<MallOrderInfo> query = new LambdaQueryWrapper<>();
+            query.ge(MallOrderInfo::getReceivingTime, startTime)
+                   .le(MallOrderInfo::getReceivingTime, endTime)
+                   .eq(MallOrderInfo::getStatus, 4)
+                    .eq(MallOrderInfo::getMemberId, member.getId());
+            List<MallOrderInfo> orderList = mallOrderInfoMapper.selectList(query);
+            if (CollUtil.isEmpty(orderList)) {
+                return;
+            }
+
+            double totalAmount = orderList.stream().mapToDouble(item -> {
+                return item.getAmount().doubleValue();
+            }).sum();
+
+            if (nextLevel.getAmount().compareTo(BigDecimal.valueOf(totalAmount)) > 0) {
+                log.info("未达到指定金额:{}, {}", nextLevel.getAmount(), totalAmount);
+                return;
+            }
+
+            MallMember update = new MallMember();
+            update.setId(member.getId());
+            update.setLevel(nextLevel.getCode());
+            mallMemberMapper.updateById(update);
+        }
+    }
+
+    private Date getStartTime(String type) {
+        Date date = new Date();
+        switch (type) {
+            case "day" :
+                return DateUtil.beginOfDay(date);
+            case "month":
+                return DateUtil.beginOfMonth(date);
+            case "year":
+                return DateUtil.beginOfYear(date);
+            default:
+                return date;
+        }
+    }
 }

--
Gitblit v1.9.1