From 422be47bbda3dbf14a350b119bbf0d0eb3a91c3e Mon Sep 17 00:00:00 2001
From: wzy <wzy19931122ai@163.com>
Date: Sun, 28 Aug 2022 20:32:59 +0800
Subject: [PATCH] fix

---
 src/main/java/cc/mrbird/febs/dapp/service/impl/DappSystemServiceImpl.java |   22 ++++++++++++++--------
 1 files changed, 14 insertions(+), 8 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 1c7517e..dd0362d 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
@@ -759,13 +759,20 @@
      */
     @Override
     public void sdmWithdrawFee(String data) {
-        BigDecimal totalFee = new BigDecimal(data);
+        JSONObject jsonObject = JSONObject.parseObject(data);
+
+        String address = jsonObject.getString("address");
+        if (!ChainEnum.BSC_TFC_FEE.getAddress().equals(address)) {
+            return;
+        }
+
+        BigDecimal totalFee = new BigDecimal(jsonObject.getString("fee"));
         String batchNo = RandomUtil.randomString(16);
 
         BigDecimal cardProfit = totalFee.multiply(new BigDecimal("0.5"));
         BigDecimal destroy = totalFee.subtract(cardProfit);
 
-        BigDecimal preFee = cardProfit.divide(BigDecimal.valueOf(5000), 2, RoundingMode.HALF_UP);
+        BigDecimal preFee = cardProfit.divide(BigDecimal.valueOf(5000), ChainService.getInstance(ChainEnum.BSC_TFC.name()).decimals(), RoundingMode.HALF_UP);
 
         Map<String, Integer> cardCntMap = nfcCardMap();
         if (!cardCntMap.isEmpty()) {
@@ -773,14 +780,13 @@
                 BigDecimal amount = preFee.multiply(new BigDecimal(entry.getValue()));
 
                 DappMemberEntity member = dappMemberDao.selectByAddress(entry.getKey(), "BSC");
-                DappFundFlowEntity fundFlow = new DappFundFlowEntity(member.getId(), amount, 4, 1, null, null);
+                if (member == null) {
+                    continue;
+                }
+                DappFundFlowEntity fundFlow = new DappFundFlowEntity(member.getId(), amount, 4, 2, null, null);
                 dappFundFlowDao.insert(fundFlow);
 
                 OnlineTransferUtil.addTransfer(entry.getKey(), amount, 5, 1, ChainEnum.BSC_TFC_FEE.name(), AppContants.SYMBOL_COIN, batchNo);
-
-                Map<String, Object> map = new HashMap<>();
-                map.put("batchNo", batchNo);
-                chainProducer.sendOnlineTransfer(JSONObject.toJSONString(map));
             }
         }
 
@@ -793,7 +799,7 @@
 
     private Map<String, Integer> nfcCardMap() {
         ContractChainService nftInstance = ChainService.getInstance(ChainEnum.BSC_NFT_SDC.name());
-        BigInteger totalNFT = nftInstance.totalSupply();
+        BigInteger totalNFT = nftInstance.totalSupplyNFT();
 
         Map<String, Integer> cardCntMap = new HashMap<>();
         for (int i = 0; i < totalNFT.intValue(); i++) {

--
Gitblit v1.9.1