From 1ba8a38bb8e951f66e354e0b242cc87080a3ad42 Mon Sep 17 00:00:00 2001
From: KKSU <15274802129@163.com>
Date: Sat, 22 Jun 2024 22:16:21 +0800
Subject: [PATCH] 后台矩阵列表

---
 src/main/java/cc/mrbird/febs/dapp/service/impl/BscUsdtContractEvent.java |    6 ++
 src/main/java/cc/mrbird/febs/rabbit/consumer/ChainConsumer.java          |   47 +++++++++++++++
 src/main/java/cc/mrbird/febs/job/MatrixResetJob.java                     |   75 +++++++++++-------------
 src/main/java/cc/mrbird/febs/rabbit/QueueConstants.java                  |    2 
 src/main/java/cc/mrbird/febs/rabbit/QueueEnum.java                       |    2 
 src/main/java/cc/mrbird/febs/rabbit/producer/ChainProducer.java          |    5 +
 src/main/java/cc/mrbird/febs/rabbit/RabbitConfiguration.java             |   21 +++++++
 7 files changed, 117 insertions(+), 41 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/dapp/service/impl/BscUsdtContractEvent.java b/src/main/java/cc/mrbird/febs/dapp/service/impl/BscUsdtContractEvent.java
index 6738011..472e0c6 100644
--- a/src/main/java/cc/mrbird/febs/dapp/service/impl/BscUsdtContractEvent.java
+++ b/src/main/java/cc/mrbird/febs/dapp/service/impl/BscUsdtContractEvent.java
@@ -210,6 +210,12 @@
 //                    }
                     //复投
 //                    chainProducer.sendAchieveTreeMsg(fundFlow.getMemberId());
+                    if(ObjectUtil.isNotEmpty(fromMember.getRefererId())){
+                        DappMemberEntity dappMemberEntity = dappMemberDao.selectMemberInfoByInviteId(fromMember.getRefererId());
+                        if(ObjectUtil.isNotEmpty(dappMemberEntity)){
+                            chainProducer.sendNodeMsgLong(dappMemberEntity.getId());
+                        }
+                    }
                     chainProducer.sendNodeMsg(fundFlow.getId());
                     //发送推荐规则奖励
                     chainProducer.sendInvitePerkMsg(fundFlow.getId());
diff --git a/src/main/java/cc/mrbird/febs/job/MatrixResetJob.java b/src/main/java/cc/mrbird/febs/job/MatrixResetJob.java
index 7ce4569..1b7cfeb 100644
--- a/src/main/java/cc/mrbird/febs/job/MatrixResetJob.java
+++ b/src/main/java/cc/mrbird/febs/job/MatrixResetJob.java
@@ -1,18 +1,11 @@
 package cc.mrbird.febs.job;
 
-import cc.mrbird.febs.dapp.entity.DbMemberNode;
 import cc.mrbird.febs.dapp.mapper.DbMemberNodeMapper;
 import cc.mrbird.febs.dapp.service.DappSystemService;
-import cn.hutool.core.collection.CollUtil;
-import cn.hutool.core.util.ObjectUtil;
-import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
-import org.springframework.scheduling.annotation.Scheduled;
 import org.springframework.stereotype.Component;
-
-import java.util.List;
 
 /**
  * @author wzy
@@ -28,38 +21,38 @@
     @Autowired
     private DbMemberNodeMapper dbMemberNodeMapper;
 
-    @Scheduled(cron = "0 0 0 * * ?")
-    public void resetMatrix() {
-        /**
-         * 获取所有左右节点都有值,轮数为 1,未复投work_state = 1 的节点
-         *      判断右节点有值
-         *          有继续向判断右节点
-         *              有,原纪录复投逻辑
-         */
-        QueryWrapper<DbMemberNode> objectQueryWrapper = new QueryWrapper<>();
-        objectQueryWrapper.eq("count_fund", 1);
-        objectQueryWrapper.eq("work_state", 1);
-        List<DbMemberNode> dbMemberNodes = dbMemberNodeMapper.selectList(objectQueryWrapper);
-        if(CollUtil.isEmpty(dbMemberNodes)){
-            return;
-        }
-        for(DbMemberNode dbMemberNode : dbMemberNodes){
-            if(ObjectUtil.isEmpty(dbMemberNode.getRightNode())){
-                continue;
-            }
-            //子节点
-            Long rightNode = dbMemberNode.getRightNode();
-            DbMemberNode dbMemberNode1 = dbMemberNodeMapper.selectById(rightNode);
-            if(ObjectUtil.isEmpty(dbMemberNode1)){
-                continue;
-            }
-
-            if(ObjectUtil.isEmpty(dbMemberNode1.getRightNode())){
-                continue;
-            }
-
-            //有,则上级节点出局复投,轮数加1,复投逻辑
-            dappSystemService.memberNodeNext(dbMemberNode);
-        }
-    }
+//    @Scheduled(cron = "0 0 0 * * ?")
+//    public void resetMatrix() {
+//        /**
+//         * 获取所有左右节点都有值,轮数为 1,未复投work_state = 1 的节点
+//         *      判断右节点有值
+//         *          有继续向判断右节点
+//         *              有,原纪录复投逻辑
+//         */
+//        QueryWrapper<DbMemberNode> objectQueryWrapper = new QueryWrapper<>();
+//        objectQueryWrapper.eq("count_fund", 1);
+//        objectQueryWrapper.eq("work_state", 1);
+//        List<DbMemberNode> dbMemberNodes = dbMemberNodeMapper.selectList(objectQueryWrapper);
+//        if(CollUtil.isEmpty(dbMemberNodes)){
+//            return;
+//        }
+//        for(DbMemberNode dbMemberNode : dbMemberNodes){
+//            if(ObjectUtil.isEmpty(dbMemberNode.getRightNode())){
+//                continue;
+//            }
+//            //子节点
+//            Long rightNode = dbMemberNode.getRightNode();
+//            DbMemberNode dbMemberNode1 = dbMemberNodeMapper.selectById(rightNode);
+//            if(ObjectUtil.isEmpty(dbMemberNode1)){
+//                continue;
+//            }
+//
+//            if(ObjectUtil.isEmpty(dbMemberNode1.getRightNode())){
+//                continue;
+//            }
+//
+//            //有,则上级节点出局复投,轮数加1,复投逻辑
+//            dappSystemService.memberNodeNext(dbMemberNode);
+//        }
+//    }
 }
diff --git a/src/main/java/cc/mrbird/febs/rabbit/QueueConstants.java b/src/main/java/cc/mrbird/febs/rabbit/QueueConstants.java
index 857046c..93a155b 100644
--- a/src/main/java/cc/mrbird/febs/rabbit/QueueConstants.java
+++ b/src/main/java/cc/mrbird/febs/rabbit/QueueConstants.java
@@ -6,6 +6,8 @@
  **/
 public class QueueConstants {
     //发送推荐规则奖励
+    public static final String TFC_NODE_AGAIN_LONG = "queue_tfc_node_again_long";
+    //发送推荐规则奖励
     public static final String TFC_NODE_AGAIN = "queue_tfc_node_again";
     //发送推荐规则奖励
     public static final String TFC_NODE_PERK_QUEEN = "queue_tfc_node_perk";
diff --git a/src/main/java/cc/mrbird/febs/rabbit/QueueEnum.java b/src/main/java/cc/mrbird/febs/rabbit/QueueEnum.java
index 3cf556d..689caef 100644
--- a/src/main/java/cc/mrbird/febs/rabbit/QueueEnum.java
+++ b/src/main/java/cc/mrbird/febs/rabbit/QueueEnum.java
@@ -6,6 +6,8 @@
 public enum QueueEnum {
 
     //发送推荐规则奖励
+    TFC_NODE_AGAIN_LONG("exchange_tfc_node_again_long", "route_key_tfc_node_again_long", QueueConstants.TFC_NODE_AGAIN_LONG),
+    //发送推荐规则奖励
     TFC_NODE_AGAIN("exchange_tfc_node_again", "route_key_tfc_node_again", QueueConstants.TFC_NODE_AGAIN),
     //发送推荐规则奖励
     TFC_NODE_PERK("exchange_tfc_node_perk", "route_key_tfc_node_perk", QueueConstants.TFC_NODE_PERK_QUEEN),
diff --git a/src/main/java/cc/mrbird/febs/rabbit/RabbitConfiguration.java b/src/main/java/cc/mrbird/febs/rabbit/RabbitConfiguration.java
index 898fadf..7cdc0cc 100644
--- a/src/main/java/cc/mrbird/febs/rabbit/RabbitConfiguration.java
+++ b/src/main/java/cc/mrbird/febs/rabbit/RabbitConfiguration.java
@@ -158,4 +158,25 @@
         return BindingBuilder.bind(nodeAgainQueue()).to(nodeAgainExchange()).with(QueueEnum.TFC_NODE_AGAIN.getRoute());
     }
     // === 发送复投 end ===
+
+
+
+
+
+    // === 发送复投 start ===
+    @Bean
+    public DirectExchange nodeAgainExchangeLong() {
+        return new DirectExchange(QueueEnum.TFC_NODE_AGAIN_LONG.getExchange());
+    }
+
+    @Bean
+    public Queue nodeAgainQueueLong() {
+        return new Queue(QueueEnum.TFC_NODE_AGAIN_LONG.getQueue());
+    }
+
+    @Bean
+    public Binding nodeAgainBindLong() {
+        return BindingBuilder.bind(nodeAgainQueueLong()).to(nodeAgainExchangeLong()).with(QueueEnum.TFC_NODE_AGAIN_LONG.getRoute());
+    }
+    // === 发送复投 end ===
 }
diff --git a/src/main/java/cc/mrbird/febs/rabbit/consumer/ChainConsumer.java b/src/main/java/cc/mrbird/febs/rabbit/consumer/ChainConsumer.java
index 1602b8e..3e08118 100644
--- a/src/main/java/cc/mrbird/febs/rabbit/consumer/ChainConsumer.java
+++ b/src/main/java/cc/mrbird/febs/rabbit/consumer/ChainConsumer.java
@@ -1,12 +1,19 @@
 package cc.mrbird.febs.rabbit.consumer;
 
+import cc.mrbird.febs.dapp.entity.DbMemberNode;
+import cc.mrbird.febs.dapp.mapper.DbMemberNodeMapper;
 import cc.mrbird.febs.dapp.service.DappSystemService;
 import cc.mrbird.febs.rabbit.QueueConstants;
+import cn.hutool.core.collection.CollUtil;
+import cn.hutool.core.util.ObjectUtil;
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.amqp.rabbit.annotation.RabbitListener;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
 import org.springframework.stereotype.Component;
+
+import java.util.List;
 
 /**
  * @author wzy
@@ -19,6 +26,8 @@
 
     @Autowired
     private DappSystemService dappSystemService;
+    @Autowired
+    private DbMemberNodeMapper dbMemberNodeMapper;
 
     @RabbitListener(queues = QueueConstants.ACHIEVE_TREE)
     public void achieveTree(String id) {
@@ -62,4 +71,42 @@
         log.info("复投:{}", id);
         dappSystemService.achieveTreeV2(id);
     }
+
+    @RabbitListener(queues = QueueConstants.TFC_NODE_AGAIN_LONG)
+    public void nodeMsgLong(Long id) {
+        log.info("复投:{}", id);
+
+        /**
+         * 获取所有左右节点都有值,轮数为 1,未复投work_state = 1 的节点
+         *      判断右节点有值
+         *          有继续向判断右节点
+         *              有,原纪录复投逻辑
+         */
+        QueryWrapper<DbMemberNode> objectQueryWrapper = new QueryWrapper<>();
+        objectQueryWrapper.eq("count_fund", 1);
+        objectQueryWrapper.eq("work_state", 1);
+        objectQueryWrapper.eq("member_id", id);
+        List<DbMemberNode> dbMemberNodes = dbMemberNodeMapper.selectList(objectQueryWrapper);
+        if(CollUtil.isEmpty(dbMemberNodes)){
+            return;
+        }
+        for(DbMemberNode dbMemberNode : dbMemberNodes){
+            if(ObjectUtil.isEmpty(dbMemberNode.getRightNode())){
+                continue;
+            }
+            //子节点
+            Long rightNode = dbMemberNode.getRightNode();
+            DbMemberNode dbMemberNode1 = dbMemberNodeMapper.selectById(rightNode);
+            if(ObjectUtil.isEmpty(dbMemberNode1)){
+                continue;
+            }
+
+            if(ObjectUtil.isEmpty(dbMemberNode1.getRightNode())){
+                continue;
+            }
+
+            //有,则上级节点出局复投,轮数加1,复投逻辑
+            dappSystemService.memberNodeNext(dbMemberNode);
+        }
+    }
 }
diff --git a/src/main/java/cc/mrbird/febs/rabbit/producer/ChainProducer.java b/src/main/java/cc/mrbird/febs/rabbit/producer/ChainProducer.java
index 17fe0fa..2801643 100644
--- a/src/main/java/cc/mrbird/febs/rabbit/producer/ChainProducer.java
+++ b/src/main/java/cc/mrbird/febs/rabbit/producer/ChainProducer.java
@@ -81,4 +81,9 @@
         CorrelationData correlationData = new CorrelationData(UUID.randomUUID().toString());
         rabbitTemplate.convertAndSend(QueueEnum.TFC_NODE_AGAIN.getExchange(), QueueEnum.TFC_NODE_AGAIN.getRoute(), id, correlationData);
     }
+    public void sendNodeMsgLong(Long id) {
+        log.info("发送复投原本数据:{}", id);
+        CorrelationData correlationData = new CorrelationData(UUID.randomUUID().toString());
+        rabbitTemplate.convertAndSend(QueueEnum.TFC_NODE_AGAIN_LONG.getExchange(), QueueEnum.TFC_NODE_AGAIN_LONG.getRoute(), id, correlationData);
+    }
 }

--
Gitblit v1.9.1