From 9cf47e10044ecb29669dec48d8b649b4fb46898f Mon Sep 17 00:00:00 2001
From: Hentua <wangdoubleone@gmail.com>
Date: Sun, 04 Jun 2023 00:51:54 +0800
Subject: [PATCH] fix

---
 src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java |   32 ++++++++++++++++++++++++++------
 1 files changed, 26 insertions(+), 6 deletions(-)

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 ca6b5b4..287d863 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
@@ -3,6 +3,7 @@
 import cc.mrbird.febs.common.entity.FebsResponse;
 import cc.mrbird.febs.common.enumerates.*;
 import cc.mrbird.febs.common.exception.FebsException;
+import cc.mrbird.febs.common.exception.GeneratorException;
 import cc.mrbird.febs.common.utils.AppContants;
 import cc.mrbird.febs.common.utils.LoginUserUtil;
 import cc.mrbird.febs.common.utils.MallUtils;
@@ -23,8 +24,11 @@
 import cc.mrbird.febs.pay.service.UnipayService;
 import cc.mrbird.febs.rabbit.producter.AgentProducer;
 import cn.hutool.core.collection.CollUtil;
+import cn.hutool.core.date.DateField;
+import cn.hutool.core.date.DateTime;
 import cn.hutool.core.date.DateUnit;
 import cn.hutool.core.date.DateUtil;
+import cn.hutool.core.thread.ThreadUtil;
 import cn.hutool.core.util.ObjectUtil;
 import cn.hutool.core.util.StrUtil;
 import cn.hutool.crypto.SecureUtil;
@@ -141,6 +145,14 @@
 
                 if (MallGoods.ISSALE_STATUS_DISABLED.equals(mallGoods.getIsSale())) {
                     throw new FebsException(mallGoods.getGoodsName() + "已下架");
+                }
+
+                if (mallGoods.getRulesTimes() != null && mallGoods.getRulesCnt() != null) {
+                    DateTime startDate = DateUtil.offset(new Date(), DateField.DAY_OF_YEAR, -mallGoods.getRulesTimes());
+                    List<MallOrderInfo> orderInfos = this.baseMapper.selectScoreOrderListInDate(DateUtil.beginOfDay(startDate), DateUtil.endOfDay(new Date()), mallGoods.getId());
+                    if (CollUtil.isNotEmpty(orderInfos) && orderInfos.size() >= mallGoods.getRulesCnt()) {
+                        throw new FebsException("超出领取最大限制");
+                    }
                 }
 
                 BigDecimal amount = mallGoods.getScore().multiply(BigDecimal.valueOf(item.getCnt()));
@@ -347,9 +359,11 @@
                     }
 
                     // 判断会员层级
-                    if (item.getIsNormal() == 2 && goodsLevel > item.getGoodsLevel()) {
+                    if (item.getIsNormal() == 2 && goodsLevel < item.getGoodsLevel()) {
                         goodsLevel = item.getGoodsLevel();
                     }
+
+                    mallAchieveService.add(item.getId());
                 }
 
                 // 根据用户购买的商品设置其等级
@@ -368,12 +382,18 @@
                 }
 
                 mallMoneyFlowService.addMoneyFlow(member.getId(), score, MoneyFlowTypeEnum.BUY_TC.getValue(), orderInfo.getOrderNo(), FlowTypeEnum.SCORE.getValue());
-                mallMoneyFlowService.addMoneyFlow(member.getId(), orderInfo.getAmount().negate(), MoneyFlowTypeEnum.PAY.getValue(), orderInfo.getOrderNo(), FlowTypeEnum.BALANCE.getValue());
+                mallMoneyFlowService.addMoneyFlow(member.getId(), orderInfo.getAmount().subtract(orderInfo.getScoreAmount()).negate(), MoneyFlowTypeEnum.PAY.getValue(), orderInfo.getOrderNo(), FlowTypeEnum.BALANCE.getValue());
 
-                //发送代理自动升级消息
-                agentProducer.sendAutoLevelUpMsg(member.getId());
-                //发送直推返利消息
-                agentProducer.sendOrderReturn(orderInfo.getId());
+                ThreadUtil.execute(() -> {
+                    ThreadUtil.sleep(5000);
+
+                    //发送代理自动升级消息
+                    agentProducer.sendAutoLevelUpMsg(member.getId());
+                    //发送直推返利消息
+                    agentProducer.sendOrderReturn(orderInfo.getId());
+                    // 发送分红消息
+                    agentProducer.sendOrderBonus(orderInfo.getId());
+                });
                 break;
             case "4":
                 if (orderInfo.getOrderType() != 2) {

--
Gitblit v1.9.1