From 97946d338b1bca979b27e3fe747967da90bcc283 Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Fri, 19 May 2023 18:05:58 +0800
Subject: [PATCH] twoCoin项目修改

---
 src/main/java/cc/mrbird/febs/dapp/service/impl/DappWalletServiceImpl.java |  204 +++++++++++++++++++++++++++++++-------------------
 1 files changed, 125 insertions(+), 79 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/dapp/service/impl/DappWalletServiceImpl.java b/src/main/java/cc/mrbird/febs/dapp/service/impl/DappWalletServiceImpl.java
index f69726f..209ac93 100644
--- a/src/main/java/cc/mrbird/febs/dapp/service/impl/DappWalletServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/dapp/service/impl/DappWalletServiceImpl.java
@@ -13,10 +13,12 @@
 import cc.mrbird.febs.dapp.dto.*;
 import cc.mrbird.febs.dapp.entity.*;
 import cc.mrbird.febs.dapp.enumerate.DataDictionaryEnum;
+import cc.mrbird.febs.dapp.enumerate.NodeCodeEnum;
 import cc.mrbird.febs.dapp.mapper.*;
 import cc.mrbird.febs.dapp.service.DappWalletService;
 import cc.mrbird.febs.dapp.utils.BoxUtil;
 import cc.mrbird.febs.dapp.vo.ActiveNftListVo;
+import cc.mrbird.febs.dapp.vo.DappMemberNodeVo;
 import cc.mrbird.febs.dapp.vo.WalletInfoVo;
 import cc.mrbird.febs.rabbit.producer.ChainProducer;
 import cn.hutool.core.collection.CollUtil;
@@ -63,6 +65,9 @@
     private final DappSystemDao dappSystemDao;
     private final DappSystemProfitDao dappSystemProfitDao;
 
+    private final DappNodeOrderMapper dappNodeOrderMapper;
+    private final DappMemberNodeMapper dappMemberNodeMapper;
+
     @Override
     public WalletInfoVo walletInfo() {
         DappMemberEntity member = LoginUserUtil.getAppUser();
@@ -92,49 +97,15 @@
         walletInfo.setLevelProfit(levelProfit);
         BigDecimal luckyProfit = dappFundFlowDao.selectSumAmountByMemberIdAndTypeAndStatus(memberInfo.getId(),7,2);
         walletInfo.setLuckyProfit(luckyProfit);
-//        //获取当前是第几轮队列
-//        String redisKey = "QUEUE_COUNT";
-//        String memberOutCount = redisUtils.getString(redisKey);
-//        DataDictionaryCustom queueCountSet = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(DataDictionaryEnum.QUEUE_COUNT.getType(), DataDictionaryEnum.QUEUE_COUNT.getCode());
-//        String queueCount = queueCountSet.getValue();
-//        if(StrUtil.isBlank(memberOutCount)){
-//            redisUtils.set(redisKey,queueCount,0L);
-//            memberOutCount = queueCount;
-//        }
-//        //出局条件的人数
-//        /**
-//         * 初始大小 5+4*0
-//         * 1  1,2,3,4,5  1出局 5+4*0
-//         * 2  2,3,4,5,1(复投),7,8,9,10  2出局 5+4*1
-//         * 3  3,4,5,1(复投),7,8,9,10,2(复投),12,13,14,15 3出局 5+4*2
-//         * 4  4,5,1(复投),7,8,9,10,2(复投),12,13,14,15,3(复投),17,18,19,20  4出局 5+4*3
-//         */
-//        Integer memberCount = Integer.parseInt(memberOutCount) * 4 + 5;
-//        //判断当前是否符合出局条件
-//        QueryWrapper<DappSystemProfit> objectQueryWrapper = new QueryWrapper<>();
-//        objectQueryWrapper.eq("state",DappSystemProfit.STATE_IN);
-//        //实际投资人数
-//        Integer selectCount = dappSystemProfitDao.selectCount(objectQueryWrapper);
-//        BigDecimal memberRunPercent = BigDecimal.ZERO;
-//        List<DappSystemProfit> dappSystemProfits = dappSystemProfitDao.selectDappSysstemProfitByState(DappSystemProfit.STATE_IN);
-//        if(CollUtil.isEmpty(dappSystemProfits)){
-//            walletInfo.setRunPercent(memberRunPercent);
-//        }
-//
-//        for(int i=0;i<dappSystemProfits.size();i++){
-//            DappSystemProfit systemProfit = dappSystemProfits.get(i);
-//            if(memberInfo.getId() == systemProfit.getMemberId()){
-//                BigDecimal size = new  BigDecimal(dappSystemProfits.size());
-//                memberRunPercent = size.subtract(new BigDecimal(i+1));
-//            }
-//        }
-//        BigDecimal runPercent = memberRunPercent.divide(new BigDecimal(memberCount), 2, BigDecimal.ROUND_DOWN).multiply(new BigDecimal(100));
-//        walletInfo.setRunPercent(runPercent);
         if(DataDictionaryEnum.BIG_BOSS.getCode().equals(memberInfo.getAccountType())){
             walletInfo.setRunPercent(new BigDecimal(100));
         }else{
             walletInfo.setRunPercent(new BigDecimal(90));
         }
+
+        //获取会员节点信息
+        List<DappMemberNodeVo> dappMemberNodeVos = dappMemberNodeMapper.selectListByMemberId(member.getId());
+        walletInfo.setDappMemberNodeVos(dappMemberNodeVos);
         return walletInfo;
     }
 
@@ -186,7 +157,6 @@
     @Override
     public Long transfer(TransferDto transferDto) {
         DappMemberEntity member = LoginUserUtil.getAppUser();
-//        DappMemberEntity member = dappMemberDao.selectById(transferDto.getMemberId());
 
         String upgrade = redisUtils.getString("APP_UPGRADE");
         if ("upgrade".equals(upgrade)) {
@@ -199,7 +169,9 @@
                 throw new FebsException("Do not repeat purchase");
             }
         }
-
+        /**
+         * buyType=1,余额购买
+         */
         if (transferDto.getBuyType() == 1) {
             DappWalletCoinEntity walletCoin = dappWalletCoinDao.selectByMemberId(member.getId());
             if (transferDto.getAmount().compareTo(walletCoin.getAvailableAmount()) > 0) {
@@ -211,23 +183,57 @@
             DappFundFlowEntity fundFlow = new DappFundFlowEntity(member.getId(), transferDto.getAmount().negate(), 1, 2, transferDto.getFee(), transferDto.getTxHash());
             dappFundFlowDao.insert(fundFlow);
 
-            chainProducer.sendAchieveTreeMsg(member.getId());
+//            chainProducer.sendAchieveTreeMsg(member.getId());
         } else {
+            /**
+             * buyType=2,钱包购买
+             */
             int type = 1;
             // 1-认购 2-充值tfc
             if (transferDto.getType() == 2) {
                 type = 6;
             }
+            /**
+             * 第一次请求,生成一条资金流水ID,并且返回。
+             */
             if (transferDto.getId() == null) {
-                DappFundFlowEntity fundFlowOld = dappFundFlowDao.selectBymemberIdAndType(member.getId(),type);
+                /**
+                 * 验证节点的价格是否和入参价格一致
+                 */
+                String nodeCode = transferDto.getNodeCode();
+                DappNodeOrderEntity dappNodeOrderEntity = dappNodeOrderMapper.selectNodeOrderByNodeCodeForupdate(nodeCode);
+                BigDecimal price = dappNodeOrderEntity.getPrice();
+                BigDecimal amount = transferDto.getAmount();
+                if(price.compareTo(amount) != 0){
+                    throw new FebsException("刷新后重试");
+//                    throw new FebsException("Refresh and try again");
+                }
+                Integer surplusCnt = dappNodeOrderEntity.getSurplusCnt();
+                if(0 >= surplusCnt){
+                    throw new FebsException("该节点剩余数量为0。");
+                }
+
+
+                /**
+                 * 超级节点只允许购买一次
+                 */
+                if(NodeCodeEnum.SUPER_NODE.getCode().equals(nodeCode)){
+                    DappMemberNodeEntity superNode = dappMemberNodeMapper.selectNodeByMemberIdAndNodeCode(
+                            member.getId(), NodeCodeEnum.SUPER_NODE.getCode());
+                    if(ObjectUtil.isNotEmpty(superNode)){
+                        throw new FebsException("超级节点只能购买一次");
+                    }
+                }
+
+                DappFundFlowEntity fundFlowOld = dappFundFlowDao.selectBymemberIdAndType(member.getId(),type,DappFundFlowEntity.WITHDRAW_STATUS_ING);
                 if(ObjectUtil.isNotEmpty(fundFlowOld)){
                     //网络问题导致第二次提交前,未成功就关闭了页面
                     if (fundFlowOld.getStatus() == 1 && StrUtil.isEmpty(fundFlowOld.getFromHash())) {
-                        dappFundFlowDao.deleteById(transferDto.getId());
+                        dappFundFlowDao.deleteById(fundFlowOld.getId());
+                        throw new FebsException("Refresh and try again");
                     }
-                    throw new FebsException("Refresh and try again");
                 }
-                DappFundFlowEntity fundFlow = new DappFundFlowEntity(member.getId(), transferDto.getAmount(), type, 1, transferDto.getFee(), transferDto.getTxHash());
+                DappFundFlowEntity fundFlow = new DappFundFlowEntity(member.getId(), transferDto.getAmount(), type, 1, transferDto.getFee(), transferDto.getTxHash(),transferDto.getNodeCode());
                 dappFundFlowDao.insert(fundFlow);
                 return fundFlow.getId();
             }
@@ -235,51 +241,91 @@
             if ("success".equals(transferDto.getFlag())) {
                 DappFundFlowEntity flow = dappFundFlowDao.selectById(transferDto.getId());
                 if(DappFundFlowEntity.WITHDRAW_STATUS_AGREE == flow.getStatus()){
-                    throw new FebsException("Do not repeat purchase");
+                    throw new FebsException("请勿重复提交");
+//                    throw new FebsException("Do not repeat purchase");
                 }
-                //是否已经加入动能
-                DappSystemProfit dappSystemProfitIng = dappSystemProfitDao.selectByMemberIdAndState(member.getId(), DappSystemProfit.STATE_IN);
-                if(ObjectUtil.isNotEmpty(dappSystemProfitIng)){
-                    throw new FebsException("Do not repeat purchase");
-                }
+                /**
+                 * 生成会员节点表记录
+                 */
+                String nodeCode = transferDto.getNodeCode();
+                DappNodeOrderEntity dappNodeOrderEntity = dappNodeOrderMapper.selectNodeOrderByNodeCodeForupdate(nodeCode);
+                DappMemberNodeEntity dappMemberNodeEntityNew = new DappMemberNodeEntity(
+                        member.getId(),
+                        dappNodeOrderEntity.getId(),
+                        dappNodeOrderEntity.getNodeCode(),
+                        transferDto.getAmount()
+                );
+                dappMemberNodeMapper.insert(dappMemberNodeEntityNew);
 
-                //插入一条会员入列记录,即加入动能队列
-                DappSystemProfit dappSystemProfit = new DappSystemProfit(member.getId(), flow.getAmount());
-                dappSystemProfitDao.insert(dappSystemProfit);
+                Integer surplusCnt = dappNodeOrderEntity.getSurplusCnt();
+                surplusCnt = surplusCnt - 1;
+                dappNodeOrderEntity.setSurplusCnt(surplusCnt);
+                dappNodeOrderMapper.updateById(dappNodeOrderEntity);
 
+                /**
+                 * 流水关联用户购买节点记录
+                 */
+                flow.setSystemProfitId(dappMemberNodeEntityNew.getId());
+                /**
+                 * 链上转账的hash值
+                 */
                 flow.setFromHash(transferDto.getTxHash());
-                flow.setSystemProfitId(dappSystemProfit.getId());
                 flow.setStatus(DappFundFlowEntity.WITHDRAW_STATUS_AGREE);
                 dappFundFlowDao.updateById(flow);
-                //升级成为Agent
-                dappMemberDao.updateMemberAccountType(DataDictionaryEnum.AGENT.getCode(),member.getId());
-                dappMemberDao.updateMemberActiveStatus(1,member.getId());
-
-                //直接拿走0.05个BNB放入技术方
-                DataDictionaryCustom systemProfit = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(DataDictionaryEnum.SYSTEM_PROFIT.getType(), DataDictionaryEnum.SYSTEM_PROFIT.getCode());
-                String systemProfitStr = StrUtil.isEmpty(systemProfit.getValue()) ? "0.05" : systemProfit.getValue();
-                DappFundFlowEntity systemProfitFlow = new DappFundFlowEntity(1L, new BigDecimal(systemProfitStr), 2, 1, BigDecimal.ZERO, null,dappSystemProfit.getId());
-                dappFundFlowDao.insert(systemProfitFlow);
-                //发送转币消息
-//                chainProducer.sendBnbTransferMsg(systemProfitFlow.getId());
-                //直接返利30%给直接上级
+                /**
+                 * 升级账号类型为对应的节点名称
+                 */
+//                dappMemberDao.updateMemberAccountType(dappNodeOrderEntity.getNodeName(),member.getId());
+                /**
+                 * 更新账号的状态为已激活-即已经购买节点
+                 */
+//                dappMemberDao.updateMemberActiveStatus(1,member.getId());
+                /**
+                 * 直推奖励
+                 */
                 DappMemberEntity dappMemberEntity = dappMemberDao.selectById(member.getId());
                 String refererId = dappMemberEntity.getRefererId();
                 DappMemberEntity refererMember = dappMemberDao.selectMemberInfoByInviteId(refererId);
-
-                DataDictionaryCustom directProfitSet = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(DataDictionaryEnum.DIRECT_PROFIT.getType(), DataDictionaryEnum.DIRECT_PROFIT.getCode());
-                BigDecimal directProfitStr = new BigDecimal(StrUtil.isEmpty(directProfitSet.getValue()) ? "0.3" : directProfitSet.getValue());
-                BigDecimal subtract = transferDto.getAmount().subtract(new BigDecimal(systemProfitStr));
-                BigDecimal directProfit = subtract.multiply(directProfitStr).setScale(6,BigDecimal.ROUND_DOWN);
-                
-                DappFundFlowEntity fundFlow = new DappFundFlowEntity(refererMember.getId(), directProfit, 3, 1, BigDecimal.ZERO, null,dappSystemProfit.getId());
+                DataDictionaryCustom directProfitDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
+                        DataDictionaryEnum.DIRECT_PROFIT.getType(),
+                        DataDictionaryEnum.DIRECT_PROFIT.getCode());
+                BigDecimal directProfitPercent = new BigDecimal(StrUtil.isEmpty(directProfitDic.getValue()) ? "0.1" : directProfitDic.getValue());
+                BigDecimal amount = transferDto.getAmount();
+                BigDecimal directProfit = amount.multiply(directProfitPercent).setScale(6,BigDecimal.ROUND_DOWN);
+                //生成直推奖励的流水
+                DappFundFlowEntity fundFlow = new DappFundFlowEntity(
+                        refererMember.getId(),
+                        directProfit,
+                        3,
+                        1,
+                        BigDecimal.ZERO,
+                        null,
+                        dappMemberNodeEntityNew.getId());
                 dappFundFlowDao.insert(fundFlow);
-                //发送转币消息
+
+                /**
+                 * 发送转币消息
+                 */
                 chainProducer.sendBnbTransferMsg(fundFlow.getId());
-                //层级奖励30%
-                chainProducer.sendLevelProfitMsg(dappSystemProfit.getId());
-                //发送一个消息,计算当前是否有人可以出局
-                chainProducer.sendMemberOutMsg(dappSystemProfit.getId());
+
+
+                BigDecimal subtract = amount.subtract(directProfit);
+
+                //剩余的钱给分走
+                DappFundFlowEntity fundFlowEntityProject = new DappFundFlowEntity(
+                        4L,
+                        subtract,
+                        4,
+                        1,
+                        BigDecimal.ZERO,
+                        null,
+                        dappMemberNodeEntityNew.getId());
+                dappFundFlowDao.insert(fundFlowEntityProject);
+
+                /**
+                 * 发送转币消息
+                 */
+                chainProducer.sendBnbTransferMsg(fundFlowEntityProject.getId());
             } else {
                 DappFundFlowEntity flow = dappFundFlowDao.selectById(transferDto.getId());
                 if (flow.getStatus() == 1) {

--
Gitblit v1.9.1