From 8e6989a4472063a2edb5e63c16610ccf8450a562 Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Tue, 01 Aug 2023 23:07:15 +0800
Subject: [PATCH] 商品、订单

---
 src/main/java/cc/mrbird/febs/dapp/service/impl/DappSystemServiceImpl.java |  202 ++++++++++++++++++++++---------------------------
 1 files changed, 91 insertions(+), 111 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/dapp/service/impl/DappSystemServiceImpl.java b/src/main/java/cc/mrbird/febs/dapp/service/impl/DappSystemServiceImpl.java
index fb82e8a..4315ec3 100644
--- a/src/main/java/cc/mrbird/febs/dapp/service/impl/DappSystemServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/dapp/service/impl/DappSystemServiceImpl.java
@@ -2,6 +2,7 @@
 
 import cc.mrbird.febs.common.contants.AppContants;
 import cc.mrbird.febs.common.exception.FebsException;
+import cc.mrbird.febs.common.tree.MemberNode;
 import cc.mrbird.febs.common.utils.LoginUserUtil;
 import cc.mrbird.febs.common.utils.RedisUtils;
 import cc.mrbird.febs.common.utils.SpringContextUtil;
@@ -15,10 +16,9 @@
 import cc.mrbird.febs.dapp.mapper.*;
 import cc.mrbird.febs.dapp.service.DappSystemService;
 import cc.mrbird.febs.dapp.service.DappWalletService;
+import cc.mrbird.febs.dapp.service.IMatrixTreeNodeService;
 import cc.mrbird.febs.dapp.vo.AKLineLimitVo;
 import cc.mrbird.febs.rabbit.producer.ChainProducer;
-import cc.mrbird.febs.tree.MatrixTree;
-import cc.mrbird.febs.tree.MemberNode;
 import cc.mrbird.febs.tree.TreeConstants;
 import cn.hutool.core.collection.CollUtil;
 import cn.hutool.core.date.DateTime;
@@ -73,6 +73,9 @@
     private final DappWalletMineDao dappWalletMineDao;
     private final DappAKlineMapper dappAKlineMapper;
 
+    private final MallOrderInfoMapper mallOrderInfoMapper;
+    private final MallAchieveRecordMapper mallAchieveRecordMapper;
+
 
 
     @Override
@@ -82,111 +85,6 @@
         SystemDto system = new SystemDto();
         system.setBuyAmount(new BigDecimal("100"));
         return system;
-    }
-
-    @Override
-    @Transactional(rollbackFor = Exception.class)
-    public synchronized void achieveTree(Long memberId) {
-        DappMemberEntity member = dappMemberDao.selectById(memberId);
-
-        int batchNo = 0;
-        DappAchieveTreeEntity newestTreeNode = dappAchieveTreeDao.selectNewestTreeNode();
-        if (newestTreeNode != null) {
-            if (newestTreeNode.getValidState() == 2) {
-                batchNo = newestTreeNode.getBatchNo() + 1;
-            } else {
-                batchNo = newestTreeNode.getBatchNo();
-            }
-        }
-
-        // 在大树中,插入当前节点
-        DappAchieveTreeEntity achieveTree = new DappAchieveTreeEntity();
-        achieveTree.setMidNode(memberId);
-        achieveTree.setValidState(1);
-        achieveTree.setBatchNo(batchNo);
-        dappAchieveTreeDao.insert(achieveTree);
-
-        // 在内存树(大树)中插入当前节点,并返回父节点
-        MemberNode node = new MemberNode(member.getId(), member.getAddress(), member.getInviteId(), member.getRefererId());
-
-        MatrixTree tree = MatrixTree.getInstance();
-        MemberNode exist = tree.getNode(member.getId());
-        if (exist != null) {
-            return;
-        }
-
-        MemberNode parentNode = tree.addNode(node);
-
-        // 创建该节点的矩阵
-        DappAchieveMemberTreeEntity achieveMemberTree = new DappAchieveMemberTreeEntity();
-        achieveMemberTree.setTreeNode(memberId);
-        achieveMemberTree.setTopNode(memberId);
-        achieveMemberTree.setDeep(1);
-        achieveMemberTree.setHasMoney(1);
-        if (parentNode != null) {
-            achieveMemberTree.setParentNode(parentNode.getMemberId());
-        }
-        dappAchieveMemberTreeDao.insert(achieveMemberTree);
-
-        // 激活用户状态
-        member.setActiveStatus(1);
-        dappMemberDao.updateById(member);
-
-        putIntoProfit(memberId, 2);
-        if (parentNode == null) {
-            return;
-        }
-
-        // 修改父节点在数据库中的左/右节点数据
-        DappAchieveTreeEntity treeMidNode = dappAchieveTreeDao.selectByMidNode(parentNode.getMemberId());
-        boolean isLeft = false;
-        if (parentNode.getLeft() != null && memberId.equals(parentNode.getLeft().getMemberId())) {
-            treeMidNode.setLeftNode(memberId);
-            isLeft = true;
-        } else {
-            treeMidNode.setRightNode(memberId);
-        }
-        dappAchieveTreeDao.updateById(treeMidNode);
-
-        // 更新矩阵中的数据
-        List<DappAchieveMemberTreeEntity> matrixNodes = dappAchieveMemberTreeDao.selectNotBottomNodeInMatrix(parentNode.getMemberId());
-        for (DappAchieveMemberTreeEntity matrixNode : matrixNodes) {
-            if (isLeft) {
-                matrixNode.setLeftNode(memberId);
-            } else {
-                matrixNode.setRightNode(memberId);
-            }
-
-            dappAchieveMemberTreeDao.updateById(matrixNode);
-
-            DappAchieveMemberTreeEntity newMatrixNode = new DappAchieveMemberTreeEntity();
-            newMatrixNode.setTreeNode(memberId);
-            newMatrixNode.setTopNode(matrixNode.getTopNode());
-            newMatrixNode.setParentNode(parentNode.getMemberId());
-            newMatrixNode.setHasMoney(1);
-            newMatrixNode.setDeep(matrixNode.getDeep() + 1);
-            dappAchieveMemberTreeDao.insert(newMatrixNode);
-
-            if (matrixNode.getDeep() == 2) {
-                finishMatrixTree(matrixNode.getTopNode());
-            }
-        }
-    }
-
-    // 完成矩阵树,并重置矩阵且重入
-    public void finishMatrixTree(Long memberId) {
-        List<DappAchieveMemberTreeEntity> matrixTree = dappAchieveMemberTreeDao.selectMatrixTreeByTopNode(memberId, 1);
-        // 如果达到标准,则重置该矩阵树
-        if (matrixTree.size() == 7) {
-            dappAchieveMemberTreeDao.resetMatrixTree(memberId);
-            dappAchieveMemberTreeDao.reentryMoney(memberId);
-
-            putIntoProfit(memberId, 1);
-            DappAchieveMemberTreeEntity bottomNode = dappAchieveMemberTreeDao.selectNodeByDeep(memberId, 3);
-            if (bottomNode != null) {
-                finishMatrixTree(bottomNode.getTopNode());
-            }
-        }
     }
 
     @Override
@@ -1679,11 +1577,15 @@
          * 发起USDT转账
          */
         log.info("amount:{},address:{}",amount,address);
-//        String hash = ChainService.getInstance(ChainEnum.BSC_USDT_W_POOL.name()).transfer(address, amount);
+
         String hash = ChainService.getInstance(ChainEnum.BSC_USDT_W_POOL_CONTRACT.name()).transferUSDT(address, amount);
         if(StrUtil.isEmpty(hash)){
+//            hash = ChainService.getInstance(ChainEnum.BSC_USDT_W_POOL.name()).transfer(address, amount);
             return;
         }
+//        if(StrUtil.isEmpty(hash)){
+//            return;
+//        }
         log.info("{},{}",id,hash);
         dappFundFlowEntity.setFromHash(hash);
         dappFundFlowEntity.setStatus(2);
@@ -1694,7 +1596,7 @@
      * 紧急提现方法
      */
     public static void main(String[] args) {
-        BigDecimal amount = new BigDecimal("1");
+        BigDecimal amount = new BigDecimal("0.01");
         String address = "0xB3cF9669F398f444DfCAebbAd2A49bF32ba41fE3";
 
         String hash = ChainService.getInstance(ChainEnum.BSC_USDT_W_POOL_CONTRACT.name()).transferUSDT(address, amount);
@@ -1748,7 +1650,7 @@
                 PoolEnum.COIN_A_CNT.getType(),
                 PoolEnum.COIN_A_CNT.getCode());
         BigDecimal coinACnt = new BigDecimal(coinACntDic.getValue());
-        coinACnt = coinACnt.subtract(totalCnt);
+        coinACnt = coinACnt.subtract(totalCnt.multiply(new BigDecimal(0.8)));
         coinACntDic.setValue(coinACnt.toString());
         dataDictionaryCustomMapper.updateById(coinACntDic);
 
@@ -2300,7 +2202,7 @@
         );
         //A币金本位底池-usdt数量
         BigDecimal coinAUsdtPriceDicCnt = new BigDecimal(coinAUsdtPriceDic.getValue());
-        coinAUsdtPriceDicCnt = coinAUsdtPriceDicCnt.add(amount);
+        coinAUsdtPriceDicCnt = coinAUsdtPriceDicCnt.add(amount.multiply(new BigDecimal(0.8)));
         coinAUsdtPriceDic.setValue(coinAUsdtPriceDicCnt.toString());
         dataDictionaryCustomMapper.updateById(coinAUsdtPriceDic);
 
@@ -2530,6 +2432,84 @@
 
     }
 
+    @Override
+    public void speedPayOrderMsg(Long orderId) {
+        MallOrderInfo mallOrderInfo = mallOrderInfoMapper.selectById(orderId);
+        if(ObjectUtil.isEmpty(mallOrderInfo)){
+            return;
+        }
+        if(MallOrderInfo.STATUS_PAY != mallOrderInfo.getStatus()){
+            return;
+        }
+        Long memberId = mallOrderInfo.getMemberId();
+        /**
+         * 赠送消费金额1.5倍增值积分
+         */
+        BigDecimal amount = mallOrderInfo.getAmount();
+        DataDictionaryCustom donateScorePercentDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
+                DataDictionaryEnum.DONATE_SCORE_PERCENT.getType(),
+                DataDictionaryEnum.DONATE_SCORE_PERCENT.getCode()
+        );
+        BigDecimal donateScorePercent = new BigDecimal(donateScorePercentDic.getValue());
+        BigDecimal donateScore = amount.multiply(donateScorePercent);
+        dappWalletMineDao.updateBalance(donateScore,donateScore,memberId);
+        DappFundFlowEntity donateScoreFlow = new DappFundFlowEntity(
+                memberId,
+                donateScore,
+                FundFlowEnum.DONATE_SCORE.getCode(),
+                2,
+                BigDecimal.ZERO,
+                null,
+                orderId);
+        dappFundFlowDao.insert(donateScoreFlow);
+        /**
+         * 新增一条业绩
+         */
+        MallAchieveRecord mallAchieveRecord = new MallAchieveRecord(
+                memberId,amount,amount,DateUtil.date(),orderId,1,mallOrderInfo.getPayTime()
+        );
+        mallAchieveRecordMapper.insert(mallAchieveRecord);
+
+    }
+
+
+    private final IMatrixTreeNodeService matrixTreeNodeService;
+
+    @Override
+    public void speedAutoLevelUpMsg(Long memberId) {log.info("###代理自动升级###");
+        DappMemberEntity member = dappMemberDao.selectById(memberId);
+        if (MemberLevelEnum.V7.getType().equals(member.getAccountType())) {
+            return;
+        }
+
+        MemberNode parentNode = matrixTreeNodeService.addTreeNode(memberId);
+        if (parentNode == null) {
+            log.info("父级节点未找到:{}", memberId);
+            return;
+        }
+
+        List<DataDictionaryCustom> dicList = dataDictionaryCustomMapper.selectDicByType(AppContants.AGENT_LEVEL);
+        DataDictionaryCustom dic = null;
+        for (DataDictionaryCustom dataDictionaryCustom : dicList) {
+            if (Integer.parseInt(dataDictionaryCustom.getValue()) == parentNode.CHILD.size()) {
+                dic = dataDictionaryCustom;
+                break;
+            }
+        }
+
+        if (dic == null) {
+            return;
+        }
+
+        MallMember parentMember = memberMapper.selectById(parentNode.getMemberId());
+        parentMember.setChildNodeCnt(parentNode.CHILD.size());
+        int levelCode = MemberLevelEnum.getLevelCode(parentMember.getLevel());
+        if (Integer.parseInt(dic.getValue()) >= levelCode) {
+            parentMember.setLevel(dic.getCode());
+        }
+        memberMapper.updateById(parentMember);
+    }
+
     /**
      * 测试转账
      * @param args

--
Gitblit v1.9.1