From 03f330eaed9ae6666e6fbe72b12d0ce279bf56e6 Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Wed, 30 Nov 2022 10:10:34 +0800
Subject: [PATCH] 20221124

---
 src/main/java/cc/mrbird/febs/dapp/service/impl/DappWalletServiceImpl.java |   46 +++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 45 insertions(+), 1 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 341b391..136444d 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
@@ -174,6 +174,9 @@
                 //插入一条会员入列记录,即加入动能队列
                 DappSystemProfit dappSystemProfit = new DappSystemProfit(member.getId(), transferDto.getAmount());
                 dappSystemProfitDao.insert(dappSystemProfit);
+                //升级成为Agent
+                dappMemberDao.updateMemberAccountType(DataDictionaryEnum.AGENT.getCode(),member.getId());
+
                 DappFundFlowEntity flow = dappFundFlowDao.selectById(transferDto.getId());
                 flow.setFromHash(transferDto.getTxHash());
                 flow.setSystemProfitId(dappSystemProfit.getId());
@@ -198,7 +201,7 @@
                 //层级奖励30%
                 chainProducer.sendLevelProfitMsg(dappSystemProfit.getId());
                 //发送一个消息,计算当前是否有人可以出局
-
+                chainProducer.sendMemberOutMsg(dappSystemProfit.getId());
             } else {
                 DappFundFlowEntity flow = dappFundFlowDao.selectById(transferDto.getId());
                 if (flow.getStatus() == 1) {
@@ -369,4 +372,45 @@
     public DappWalletCoinEntity findByMemberId(Long memberId) {
         return dappWalletCoinDao.selectByMemberId(memberId);
     }
+
+    @Override
+    public void transferAgain(TransferDto transferDto) {
+        Long memberId = transferDto.getMemberId();
+        DappMemberEntity member = dappMemberDao.selectById(memberId);
+        String upgrade = redisUtils.getString("APP_UPGRADE");
+        if ("upgrade".equals(upgrade)) {
+            throw new FebsException("功能升级中");
+        }
+        if ("success".equals(transferDto.getFlag())) {
+            //插入一条会员入列记录,即加入动能队列
+            DappSystemProfit dappSystemProfit = new DappSystemProfit(member.getId(), transferDto.getAmount());
+            dappSystemProfitDao.insert(dappSystemProfit);
+            DappFundFlowEntity flow = dappFundFlowDao.selectById(transferDto.getId());
+            flow.setFromHash(transferDto.getTxHash());
+            flow.setSystemProfitId(dappSystemProfit.getId());
+            dappFundFlowDao.updateById(flow);
+
+            //直接拿走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(member.getId(), new BigDecimal(systemProfitStr), 2, 2, BigDecimal.ZERO, transferDto.getTxHash(),dappSystemProfit.getId());
+            dappFundFlowDao.insert(systemProfitFlow);
+            //直接返利30%给直接上级
+            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 directProfit = (transferDto.getAmount().subtract(new BigDecimal(systemProfitStr))).multiply(directProfitStr).setScale(BigDecimal.ROUND_DOWN, 2);
+
+            DappFundFlowEntity fundFlow = new DappFundFlowEntity(refererMember.getId(), directProfit, 3, 2, BigDecimal.ZERO, transferDto.getTxHash(),dappSystemProfit.getId());
+            dappFundFlowDao.insert(fundFlow);
+            //层级奖励30%
+            chainProducer.sendLevelProfitMsg(dappSystemProfit.getId());
+            //发送一个消息,计算当前是否有人可以出局
+            chainProducer.sendMemberOutMsg(dappSystemProfit.getId());
+
+        }
+    }
 }

--
Gitblit v1.9.1