From c1991de1c693f5721c7b48b6974caa0d0e515b39 Mon Sep 17 00:00:00 2001
From: KKSU <15274802129@163.com>
Date: Fri, 14 Jun 2024 11:52:36 +0800
Subject: [PATCH] 星级矩阵

---
 src/main/java/cc/mrbird/febs/dapp/dto/PriceDto.java                       |    3 
 src/main/java/cc/mrbird/febs/dapp/service/DappWalletService.java          |    2 
 src/main/java/cc/mrbird/febs/dapp/enumerate/DataDictionaryEnum.java       |    2 
 src/main/java/cc/mrbird/febs/dapp/controller/ApiDappMemberController.java |   18 +++-
 src/main/java/cc/mrbird/febs/dapp/dto/ChargeFeeDto.java                   |   25 ++++++
 src/main/java/cc/mrbird/febs/dapp/service/impl/BscCoinContractEvent.java  |   48 ++----------
 src/main/java/cc/mrbird/febs/dapp/service/impl/DappWalletServiceImpl.java |   86 +++++++++++++++------
 src/main/java/cc/mrbird/febs/dapp/entity/DappFundFlowEntity.java          |    3 
 src/main/java/cc/mrbird/febs/dapp/chain/ChainEnum.java                    |    2 
 9 files changed, 117 insertions(+), 72 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/dapp/chain/ChainEnum.java b/src/main/java/cc/mrbird/febs/dapp/chain/ChainEnum.java
index bc9e886..740d354 100644
--- a/src/main/java/cc/mrbird/febs/dapp/chain/ChainEnum.java
+++ b/src/main/java/cc/mrbird/febs/dapp/chain/ChainEnum.java
@@ -28,7 +28,7 @@
     BSC_TFC("BSC", "0x0F22E63D2FB18963C57A5Cb3C43403d156D140c2",
             "0x5bd9f75f53693076e19a8f20d66a147bf0a438275463d2b8d85be8ab11780836",
             "https://bsc-dataseed1.ninicoin.io",
-            "0x9b4406bC2fa21d2058FD4939BAF29B3763cFeDe2",
+            "0x5dc091e47EDcd24709C7922370806d39e6Ad8be9",
             ""),
 
     /**
diff --git a/src/main/java/cc/mrbird/febs/dapp/controller/ApiDappMemberController.java b/src/main/java/cc/mrbird/febs/dapp/controller/ApiDappMemberController.java
index e1b6924..8149b65 100644
--- a/src/main/java/cc/mrbird/febs/dapp/controller/ApiDappMemberController.java
+++ b/src/main/java/cc/mrbird/febs/dapp/controller/ApiDappMemberController.java
@@ -88,6 +88,18 @@
         return new FebsResponse().success().data(dappWalletService.transfer(transferDto));
     }
 
+    @ApiOperation(value = "手续费充值", notes = "手续费充值")
+    @PostMapping(value = "/chargeFee")
+    public FebsResponse chargeFee(@RequestBody ChargeFeeDto chargeFeeDto) {
+        return new FebsResponse().success().data(dappWalletService.chargeFee(chargeFeeDto));
+    }
+
+    @ApiOperation(value = "手续费计算", notes = "手续费计算")
+    @PostMapping(value = "/calPrice")
+    public FebsResponse calPrice(@RequestBody PriceDto priceDto) {
+        return new FebsResponse().success().data(dappWalletService.calPrice(priceDto));
+    }
+
     @ApiOperation(value = "记录列表", notes = "记录列表")
     @PostMapping(value = "/recordInPage")
     public FebsResponse recordInPage(@RequestBody RecordInPageDto recordInPageDto) {
@@ -116,11 +128,5 @@
         redisUtils.hdel(AppContants.REDIS_KEY_SIGN, member.getAddress());
         redisUtils.hdel(AppContants.REDIS_KEY_MEMBER_INFO, member.getAddress());
         return new FebsResponse().success();
-    }
-
-    @ApiOperation(value = "计算手续费", notes = "计算手续费")
-    @PostMapping(value = "/calPrice")
-    public FebsResponse calPrice(@RequestBody PriceDto priceDto) {
-        return new FebsResponse().success().data(dappWalletService.calPrice(priceDto));
     }
 }
diff --git a/src/main/java/cc/mrbird/febs/dapp/dto/ChargeFeeDto.java b/src/main/java/cc/mrbird/febs/dapp/dto/ChargeFeeDto.java
new file mode 100644
index 0000000..fa2b78c
--- /dev/null
+++ b/src/main/java/cc/mrbird/febs/dapp/dto/ChargeFeeDto.java
@@ -0,0 +1,25 @@
+package cc.mrbird.febs.dapp.dto;
+
+import io.swagger.annotations.ApiModel;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+
+import java.math.BigDecimal;
+
+@Data
+@ApiModel(value = "ChargeFeeDto", description = "连接参数接收类")
+public class ChargeFeeDto {
+
+    @ApiModelProperty(value = "id", example = "1")
+    private Long id;
+
+    @ApiModelProperty(value = "充值数量", example = "1")
+    private BigDecimal amount;
+
+    @ApiModelProperty(value = "success/fail", example = "success")
+    private String flag;
+
+    @ApiModelProperty(value = "交易hash", example = "123")
+    private String txHash;
+
+}
diff --git a/src/main/java/cc/mrbird/febs/dapp/dto/PriceDto.java b/src/main/java/cc/mrbird/febs/dapp/dto/PriceDto.java
index 248f39f..3b1c717 100644
--- a/src/main/java/cc/mrbird/febs/dapp/dto/PriceDto.java
+++ b/src/main/java/cc/mrbird/febs/dapp/dto/PriceDto.java
@@ -16,4 +16,7 @@
 
     @ApiModelProperty(value = "价格", example = "1.0")
     private BigDecimal amount;
+
+    @ApiModelProperty(value = "提现数量", example = "1.0")
+    private BigDecimal withdrawCnt;
 }
diff --git a/src/main/java/cc/mrbird/febs/dapp/entity/DappFundFlowEntity.java b/src/main/java/cc/mrbird/febs/dapp/entity/DappFundFlowEntity.java
index c2f4829..dba1f67 100644
--- a/src/main/java/cc/mrbird/febs/dapp/entity/DappFundFlowEntity.java
+++ b/src/main/java/cc/mrbird/febs/dapp/entity/DappFundFlowEntity.java
@@ -54,6 +54,9 @@
      *  16-复投
      *  17-收益
      *  18-买入
+     *  19-手续费充值
+     *  20-手续费扣除
+     *  21-提现
      */
     private Integer type;
 
diff --git a/src/main/java/cc/mrbird/febs/dapp/enumerate/DataDictionaryEnum.java b/src/main/java/cc/mrbird/febs/dapp/enumerate/DataDictionaryEnum.java
index 5d94683..a8a5bfb 100644
--- a/src/main/java/cc/mrbird/febs/dapp/enumerate/DataDictionaryEnum.java
+++ b/src/main/java/cc/mrbird/febs/dapp/enumerate/DataDictionaryEnum.java
@@ -4,6 +4,8 @@
 
 @Getter
 public enum DataDictionaryEnum {
+    //提现手续费率
+    CHARGE_FEE_PERCENT("CHARGE_FEE_PERCENT","CHARGE_FEE_PERCENT"),
     //直邀人数
     INVITE_NUM("INVITE_NUM","INVITE_NUM"),
     // 奖励百分比
diff --git a/src/main/java/cc/mrbird/febs/dapp/service/DappWalletService.java b/src/main/java/cc/mrbird/febs/dapp/service/DappWalletService.java
index 53a780d..3bc7e5c 100644
--- a/src/main/java/cc/mrbird/febs/dapp/service/DappWalletService.java
+++ b/src/main/java/cc/mrbird/febs/dapp/service/DappWalletService.java
@@ -51,4 +51,6 @@
     FebsResponse nodeList();
 
     MemberNodeVo memberNode(MemberNodeDto memberNodeDto);
+
+    Long chargeFee(ChargeFeeDto chargeFeeDto);
 }
diff --git a/src/main/java/cc/mrbird/febs/dapp/service/impl/BscCoinContractEvent.java b/src/main/java/cc/mrbird/febs/dapp/service/impl/BscCoinContractEvent.java
index 1dc76ac..3ad2cf6 100644
--- a/src/main/java/cc/mrbird/febs/dapp/service/impl/BscCoinContractEvent.java
+++ b/src/main/java/cc/mrbird/febs/dapp/service/impl/BscCoinContractEvent.java
@@ -1,6 +1,5 @@
 package cc.mrbird.febs.dapp.service.impl;
 
-import cc.mrbird.febs.common.contants.AppContants;
 import cc.mrbird.febs.common.utils.RedisUtils;
 import cc.mrbird.febs.dapp.chain.ChainEnum;
 import cc.mrbird.febs.dapp.chain.ChainService;
@@ -8,12 +7,9 @@
 import cc.mrbird.febs.dapp.chain.EthUsdtContract;
 import cc.mrbird.febs.dapp.entity.DappFundFlowEntity;
 import cc.mrbird.febs.dapp.entity.DappMemberEntity;
-import cc.mrbird.febs.dapp.entity.DappTransferRecordEntity;
 import cc.mrbird.febs.dapp.mapper.DappFundFlowDao;
 import cc.mrbird.febs.dapp.service.DappMemberService;
 import cc.mrbird.febs.dapp.service.DappWalletService;
-import cc.mrbird.febs.dapp.utils.OnlineTransferUtil;
-import cn.hutool.core.collection.CollUtil;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
@@ -23,7 +19,6 @@
 import java.math.BigDecimal;
 import java.math.BigInteger;
 import java.math.RoundingMode;
-import java.util.List;
 
 @Slf4j
 @Service
@@ -48,19 +43,15 @@
     @Transactional(rollbackFor = Exception.class)
     @Override
     public void compile(EthUsdtContract.TransferEventResponse e) {
-        if (e.to != null && e.to.equals(ChainEnum.BSC_TFC.getAddress().toLowerCase())) {
-            log.info("触发TFC监听");
+        if (e.to == null) {
+            return;
+        }
 
-//            try {
-//                Thread.sleep(5000);
-//            } catch (InterruptedException ex) {
-//                ex.printStackTrace();
-//            }
-            redisUtils.set(AppContants.REDIS_KEY_BLOCK_COIN_NUM, e.log.getBlockNumber());
-            redisUtils.set(AppContants.REDIS_KEY_BLOCK_ETH_INCREMENT_NUM, e.log.getBlockNumber());
+        if ("0x0Ba249b2FAC0061dd9c388Bd607418E16490A3fd".toLowerCase().equals(e.to)) {
+            log.info("触发GE手续费监听");
+
             int decimals = ChainService.getInstance(ChainEnum.BSC_TFC.name()).decimals();
-
-            // 更新余额
+            // 账户是否已经注册
             DappMemberEntity fromMember = dappMemberService.findByAddress(e.from, null);
             if (fromMember == null) {
                 return;
@@ -69,32 +60,9 @@
             BigInteger tokens = e.tokens;
             BigDecimal amount = new BigDecimal(tokens.toString()).divide(BigDecimal.TEN.pow(decimals), decimals, RoundingMode.HALF_DOWN);
 
-            // 卖币
+            // 充值手续费
             DappFundFlowEntity fundFlow = dappFundFlowDao.selectByFromHash(e.log.getTransactionHash(), null);
             if (fundFlow != null && fundFlow.getStatus() != 1) {
-                return;
-            }
-
-            if (fundFlow == null) {
-                List<DappFundFlowEntity> flows = dappFundFlowDao.selectFundFlowListByAddress(e.from, 1);
-                if (CollUtil.isEmpty(flows)) {
-                    OnlineTransferUtil.addTransferRecord(e.from, e.to, amount, e.log.getTransactionHash(), DappTransferRecordEntity.TRANSFER_SOURCE_FLAG_ONLINE, AppContants.SYMBOL_COIN);
-                    log.info("本地无交易:{}", e.log.getTransactionHash());
-                    return;
-                }
-
-                for (DappFundFlowEntity flow : flows) {
-                    if (flow.getStatus() == 1) {
-                        if (amount.compareTo(flow.getAmount()) == 0) {
-                            fundFlow = flow;
-                            fundFlow.setFromHash(e.log.getTransactionHash());
-                            break;
-                        }
-                    }
-                }
-            }
-
-            if (fundFlow == null) {
                 return;
             }
 
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 abacbdd..de2a26b 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
@@ -5,8 +5,6 @@
 import cc.mrbird.febs.common.exception.FebsException;
 import cc.mrbird.febs.common.utils.LoginUserUtil;
 import cc.mrbird.febs.common.utils.RedisUtils;
-import cc.mrbird.febs.dapp.chain.ChainEnum;
-import cc.mrbird.febs.dapp.chain.ChainService;
 import cc.mrbird.febs.dapp.dto.*;
 import cc.mrbird.febs.dapp.entity.*;
 import cc.mrbird.febs.dapp.enumerate.DataDictionaryEnum;
@@ -29,7 +27,6 @@
 import org.springframework.transaction.annotation.Transactional;
 
 import java.math.BigDecimal;
-import java.math.RoundingMode;
 import java.util.ArrayList;
 import java.util.List;
 
@@ -193,15 +190,29 @@
 
     @Override
     public BigDecimal calPrice(PriceDto priceDto) {
-//        String priceStr = redisUtils.getString(AppContants.REDIS_KEY_TFC_NEW_PRICE);
-        DataDictionaryCustom symbolPrice = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(DataDictionaryEnum.SYMBOL_PRICE.getType(), DataDictionaryEnum.SYMBOL_PRICE.getCode());
-        DataDictionaryCustom serviceFeeDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(DataDictionaryEnum.WITHDRAW_SERVICE_FEE.getType(), DataDictionaryEnum.WITHDRAW_SERVICE_FEE.getCode());
-
-        BigDecimal amount = priceDto.getAmount();
-        if (priceDto.getAmount() == null) {
-            amount = BigDecimal.ZERO;
+        DappMemberEntity member = LoginUserUtil.getAppUser();
+        //手续费率
+        DataDictionaryCustom feePercentDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
+                DataDictionaryEnum.CHARGE_FEE_PERCENT.getType(),
+                DataDictionaryEnum.CHARGE_FEE_PERCENT.getCode());
+        BigDecimal feePercent = new BigDecimal(feePercentDic.getValue()).multiply(new BigDecimal("0.01"));
+        //提现金额
+        BigDecimal withdrawCnt = BigDecimal.ZERO;
+        if (ObjectUtil.isEmpty(priceDto.getWithdrawCnt())) {
+            withdrawCnt = BigDecimal.ZERO;
+        }else{
+            withdrawCnt = priceDto.getWithdrawCnt();
         }
-        return amount.multiply(new BigDecimal(serviceFeeDic.getValue()).divide(BigDecimal.valueOf(100), 8, RoundingMode.HALF_DOWN)).divide(new BigDecimal(symbolPrice.getValue()), 2, RoundingMode.HALF_UP);
+        if(BigDecimal.ZERO.compareTo(withdrawCnt) >= 0){
+            throw new FebsException("请输入正确的金额");
+        }
+        DappWalletCoinEntity walletCoin = dappWalletCoinDao.selectByMemberId(member.getId());
+        if (priceDto.getWithdrawCnt().compareTo(walletCoin.getAvailableAmount()) > 0) {
+            throw new FebsException("可提现不足");
+        }
+        BigDecimal feeUsdt = withdrawCnt.multiply(feePercent).setScale(2, BigDecimal.ROUND_DOWN);
+
+        return feeUsdt.divide(priceDto.getAmount(), 2, BigDecimal.ROUND_DOWN);
     }
 
     @Override
@@ -216,17 +227,17 @@
 
         DappWalletMineEntity walletMine = dappWalletMineDao.selectByMemberId(member.getId());
         if (walletMine.getAvailableAmount().compareTo(withdrawDto.getFee()) < 0) {
-            throw new FebsException("DMD Not Enough");
+            throw new FebsException("Fee Not Enough");
         }
 
         updateWalletCoinWithLock(withdrawDto.getAmount(), member.getId(), 2);
         updateWalletMineWithLock(withdrawDto.getFee(), member.getId(), 2);
 
 
-        DappFundFlowEntity feeFlow = new DappFundFlowEntity(member.getId(), withdrawDto.getFee().negate(), 7, 2, null, null);
+        DappFundFlowEntity feeFlow = new DappFundFlowEntity(member.getId(), withdrawDto.getFee().negate(), 20, 2, null, null);
         dappFundFlowDao.insert(feeFlow);
 
-        DappFundFlowEntity fundFlow = new DappFundFlowEntity(member.getId(), withdrawDto.getAmount().negate(), 5, 2, withdrawDto.getFee(), null);
+        DappFundFlowEntity fundFlow = new DappFundFlowEntity(member.getId(), withdrawDto.getAmount().negate(), 21, 2, withdrawDto.getFee(), null);
         dappFundFlowDao.insert(fundFlow);
 
         MemberCoinWithdrawEntity memberCoinWithdraw = new MemberCoinWithdrawEntity();
@@ -234,21 +245,11 @@
         memberCoinWithdraw.setAddress(member.getAddress());
         memberCoinWithdraw.setAmount(withdrawDto.getAmount());
         memberCoinWithdraw.setFeeAmount(withdrawDto.getFee());
-        memberCoinWithdraw.setStatus(MemberCoinWithdrawEntity.STATUS_YES);
+        memberCoinWithdraw.setStatus(MemberCoinWithdrawEntity.STATUS_DOING);
         memberCoinWithdraw.setSymbol("USDT");
         memberCoinWithdraw.setFlowId(fundFlow.getId());
         memberCoinWithdrawDao.insert(memberCoinWithdraw);
 
-        String hash = ChainService.getInstance(ChainEnum.BSC_USDT.name()).transfer(member.getAddress(), withdrawDto.getAmount());
-        fundFlow.setToHash(hash);
-        dappFundFlowDao.updateById(fundFlow);
-
-        chainProducer.sendFeeDistributeMsg(fundFlow.getId());
-//        Map<String, Object> map = new HashMap<>();
-//        map.put("fee", withdrawDto.getFee());
-//        map.put("address", ChainEnum.BSC_TFC_FEE.getAddress());
-//        map.put("flow", feeFlow.getId());
-//        chainProducer.sendTfcFee(JSONObject.toJSONString(map));
     }
 
     @Override
@@ -501,6 +502,41 @@
         return buildTeamMatrix(dbMemberNode);
     }
 
+    @Override
+    public Long chargeFee(ChargeFeeDto chargeFeeDto) {
+        DappMemberEntity member = LoginUserUtil.getAppUser();
+
+        String upgrade = redisUtils.getString("APP_UPGRADE");
+        if ("upgrade".equals(upgrade)) {
+            throw new FebsException("功能升级中");
+        }
+        if (ObjectUtil.isEmpty(chargeFeeDto.getId())) {//第一次
+            DappFundFlowEntity fundFlow = new DappFundFlowEntity(
+                    member.getId(),
+                    chargeFeeDto.getAmount().negate(),
+                    19,
+                    1,
+                    BigDecimal.ZERO,
+                    chargeFeeDto.getTxHash());
+            dappFundFlowDao.insert(fundFlow);
+            return fundFlow.getId();
+        } else {//第二次
+            DappFundFlowEntity flow = dappFundFlowDao.selectById(chargeFeeDto.getId());
+            if(ObjectUtil.isEmpty(flow)){
+                return null;
+            }
+            if ("success".equals(chargeFeeDto.getFlag())) {
+                flow.setFromHash(chargeFeeDto.getTxHash());
+                dappFundFlowDao.updateById(flow);
+            } else {
+                if (flow.getStatus() == 1) {
+                    dappFundFlowDao.deleteById(chargeFeeDto.getId());
+                }
+            }
+        }
+        return null;
+    }
+
     public MemberNodeVo buildTeamMatrix(DbMemberNode dbMemberNode) {
         Long id = dbMemberNode.getId();
 

--
Gitblit v1.9.1