From c62c27263103dc5fbeea549d333431b758340166 Mon Sep 17 00:00:00 2001
From: Helius <wangdoubleone@gmail.com>
Date: Wed, 25 May 2022 16:23:07 +0800
Subject: [PATCH] fix

---
 src/main/java/cc/mrbird/febs/dapp/service/impl/DappSimulateServiceImpl.java |    6 
 src/main/java/cc/mrbird/febs/dapp/service/impl/DappSystemServiceImpl.java   |   17 -
 src/main/java/cc/mrbird/febs/dapp/chain/ChainService.java                   |  130 ++++-------
 src/main/java/cc/mrbird/febs/dapp/controller/ApiDappMemberController.java   |   26 +-
 src/main/java/cc/mrbird/febs/dapp/service/impl/DappWalletServiceImpl.java   |   18 
 src/main/resources/application-test.yml                                     |    2 
 src/main/java/cc/mrbird/febs/dapp/controller/DappController.java            |  238 ++++++++++----------
 src/main/java/cc/mrbird/febs/dapp/chain/ChainEnum.java                      |   63 +++++
 src/main/java/cc/mrbird/febs/dapp/service/impl/BscUsdtContractEvent.java    |   15 +
 src/main/java/cc/mrbird/febs/job/ChainListenerJob.java                      |   29 ++
 src/main/java/cc/mrbird/febs/dapp/controller/ApiCommonController.java       |   48 ++--
 src/main/java/cc/mrbird/febs/dapp/service/impl/BscCoinContractEvent.java    |   15 +
 src/main/java/cc/mrbird/febs/dapp/vo/WalletInfoVo.java                      |   24 +
 src/main/java/cc/mrbird/febs/dapp/chain/ContractEventService.java           |    6 
 src/main/resources/application.yml                                          |    2 
 src/main/java/cc/mrbird/febs/dapp/dto/RecordInPageDto.java                  |    2 
 16 files changed, 369 insertions(+), 272 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 5d278fc..33d1f40 100644
--- a/src/main/java/cc/mrbird/febs/dapp/chain/ChainEnum.java
+++ b/src/main/java/cc/mrbird/febs/dapp/chain/ChainEnum.java
@@ -1,8 +1,69 @@
 package cc.mrbird.febs.dapp.chain;
 
+import lombok.Data;
+import lombok.Getter;
+
 /**
  * 链类型
  */
+@Getter
 public enum ChainEnum {
-    ETH, TRX, BSC
+    /**
+     * 以太坊 USDT合约
+     */
+    ETH_USDT("0x6c5640c572504a75121e57760909a9dd0E672f2D",
+            "77f650768ff50a4243c008fbae1be9ffe74c52908ee9081e2e15f3d3411690bb",
+            "https://mainnet.infura.io/v3/f54a5887a3894ebb9425920701a97fe0",
+            "0xdac17f958d2ee523a2206206994597c13d831ec7",
+            ""),
+
+    TRX_USDT("TUFzqZRpLwLWJU4jcdf77RKS3Ts2uEhmWL",
+            "e08dce7a4626f97b790e791bcdec31cffab46233744bb1aa133f69f98623d3fb",
+            "",
+            "TR7NHqjeKQxGTCi8q8ZY4pL8otSzgjLj6t",
+            "9d461be6-9796-47b9-85d8-b150cbabbb54"),
+
+    BSC_USDT("0x971c09aA9735EB98459B17EC8b48932D24CbB931",
+            "0x5f38d0e63157f535fc21f89ea13ec3cd245691c20795c1d2cb60233b3ba7bb47",
+            "https://bsc-dataseed1.ninicoin.io",
+            "0x55d398326f99059fF775485246999027B3197955",
+            ""),
+
+    /**
+     * 币安链 代币合约
+     */
+    BSC_TFC("0x977a9ddfb965a9a3416fa72ca7f91c4949c18f25",
+            "0xefe98e00cd227b6322e892c82fcbd8eadf119c3188b7e574bc624f65405d61bf",
+            "https://bsc-dataseed1.ninicoin.io",
+            "0x6c6835e60e7dbad7a60112a6371271e8eb79ee68",
+            "");
+
+    private String address;
+
+    private String privateKey;
+
+    private String url;
+
+    private String contractAddress;
+
+    private String apiKey;
+
+    ChainEnum(String address, String privateKey, String url, String contractAddress, String apiKey) {
+        this.address = address;
+        this.privateKey = privateKey;
+        this.url = url;
+        this.contractAddress = contractAddress;
+        this.apiKey = apiKey;
+    }
+
+    public static ChainEnum getValueByName(String name) {
+        ChainEnum[] values = values();
+        for (ChainEnum value : values) {
+            if (value.name().equals(name)) {
+                return value;
+            }
+        }
+
+        return null;
+    }
 }
diff --git a/src/main/java/cc/mrbird/febs/dapp/chain/ChainService.java b/src/main/java/cc/mrbird/febs/dapp/chain/ChainService.java
index 8e3a7ff..661d7f2 100644
--- a/src/main/java/cc/mrbird/febs/dapp/chain/ChainService.java
+++ b/src/main/java/cc/mrbird/febs/dapp/chain/ChainService.java
@@ -4,16 +4,30 @@
 import cn.hutool.core.util.StrUtil;
 import cn.hutool.http.HttpUtil;
 import com.alibaba.fastjson.JSONObject;
+import lombok.extern.slf4j.Slf4j;
 import org.springframework.data.repository.query.ParameterOutOfBoundsException;
+import org.web3j.crypto.Credentials;
+import org.web3j.protocol.Web3j;
+import org.web3j.protocol.core.DefaultBlockParameter;
+import org.web3j.protocol.core.DefaultBlockParameterName;
+import org.web3j.protocol.core.DefaultBlockParameterNumber;
+import org.web3j.protocol.core.methods.request.EthFilter;
+import org.web3j.protocol.core.methods.response.TransactionReceipt;
+import org.web3j.protocol.http.HttpService;
+import org.web3j.tx.gas.StaticGasProvider;
 
 import java.math.BigDecimal;
 import java.math.BigInteger;
 import java.rmi.activation.UnknownObjectException;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
 
 /**
  * @author
  * @date 2022-03-23
  **/
+@Slf4j
 public class ChainService {
 
     private final static String TRX_ADDRESS = "TUFzqZRpLwLWJU4jcdf77RKS3Ts2uEhmWL";
@@ -27,9 +41,13 @@
     private final static String ETH_CONTRACT_ADDRESS = "0xdac17f958d2ee523a2206206994597c13d831ec7";
 
     private final static String BSC_URL = "https://bsc-dataseed1.ninicoin.io";
-    private final static String BSC_ADDRESS = "0x971c09aA9735EB98459B17EC8b48932D24CbB931";
-    private final static String BSC_PRIVATE = "0x5f38d0e63157f535fc21f89ea13ec3cd245691c20795c1d2cb60233b3ba7bb47";
-    private final static String BSC_CONTRACT_ADDRESS = "0x55d398326f99059fF775485246999027B3197955";
+//    private final static String BSC_ADDRESS = "0x971c09aA9735EB98459B17EC8b48932D24CbB931";
+//    private final static String BSC_PRIVATE = "0x5f38d0e63157f535fc21f89ea13ec3cd245691c20795c1d2cb60233b3ba7bb47";
+//    private final static String BSC_CONTRACT_ADDRESS = "0x55d398326f99059fF775485246999027B3197955";
+
+    private final static String BSC_ADDRESS = "0x977a9ddfb965a9a3416fa72ca7f91c4949c18f25";
+    private final static String BSC_PRIVATE = "0xefe98e00cd227b6322e892c82fcbd8eadf119c3188b7e574bc624f65405d61bf";
+    private final static String BSC_CONTRACT_ADDRESS = "0x6c6835e60e7dbad7a60112a6371271e8eb79ee68";
 
     private final static ContractChainService ETH = new EthService(ETH_URL, ETH_ADDRESS, ETH_PRIVATE, ETH_CONTRACT_ADDRESS);
     private final static ContractChainService BSC = new EthService(BSC_URL, BSC_ADDRESS, BSC_PRIVATE, BSC_CONTRACT_ADDRESS);
@@ -57,82 +75,38 @@
         throw new FebsException("参数错误");
     }
 
-    public static void main(String[] args) {
-        // 0x391040eE5F241711E763D0AC55E775B9b4bD0024 0x977A9dDFb965a9A3416Fa72cA7F91c4949c18f25
-        System.out.println(getInstance("BSC").isAllowance("0x977a9ddfb965a9a3416fa72ca7f91c4949c18f25"));
+    /**
+     * 监听合约事件
+     * @param startBlock 开始区块
+     */
+    public static void contractEventListener(BigInteger startBlock, ContractEventService event, String type) {
+        ChainEnum chain = ChainEnum.getValueByName(type);
+        assert chain != null;
 
-//        System.out.println(getInstance("BSC").decimals());;
+        EthUsdtContract contract = contract(chain.getPrivateKey(), chain.getContractAddress(), chain.getUrl());
+        EthFilter filter = getFilter(startBlock, chain.getContractAddress());
 
-//        System.out.println(getInstance("ETH").allowance("0x391040eE5F241711E763D0AC55E775B9b4bD0024"));
+        contract.transferEventFlowable(filter).subscribe(e -> {
+            event.compile(e);
+        }, error -> {
+            log.error("--->", error);
+        });
     }
-//
-//    /**
-//     * 获取制定账号的USDT余额
-//     *
-//     * @param address
-//     * @return
-//     */
-//    public BigDecimal balanceOf(String address) {
-//        BigDecimal balance = BigDecimal.ZERO;
-//        if (address.contains(ETH_PREFIX)) {
-//            balance = ETH.tokenGetBalance(address);
-//        } else {
-//            balance = TRX.balanceOf(address);
-//        }
-//        return balance;
-//    }
-//
-//    /**
-//     * 判断地址是否授权给制定账户
-//     *
-//     * @param address
-//     * @return
-//     */
-//    public boolean isAllowance(String address) {
-//        BigInteger result;
-//        if (address.startsWith(ETH_PREFIX)) {
-//            result = ETH.ethAllowance(address);
-//        } else {
-//            result = TRX.allowance(address);
-//        }
-//
-//        return result.intValue() != 0;
-//    }
-//
-//    /**
-//     * 获取地址授权数量
-//     *
-//     * @param address
-//     * @return
-//     */
-//    public int allowanceCnt(String address) {
-//        String response = HttpUtil.get("https://apiasia.tronscan.io:5566/api/account/approve/list?address=" + address);
-//        String total = JSONObject.parseObject(response).getString("total");
-//        return Integer.parseInt(total);
-//    }
-//
-//    public String transfer(String address) {
-//        BigDecimal amount = balanceOf(address);
-//
-//        return transfer(address, amount);
-//    }
-//
-//    public String transfer(String address, BigDecimal amount) {
-//        String hash;
-//        if (address.startsWith(ETH_PREFIX)) {
-//            String resp = HttpUtil.get("https://etherscan.io/autoUpdateGasTracker.ashx?sid=75f30b765180f29e2b7584b8501c9124");
-//            JSONObject data = JSONObject.parseObject(resp);
-//            hash = ETH.approveTransfer(address, amount, data.getString("avgPrice"));
-//        } else {
-//            hash = TRX.transfer(address, amount);
-//        }
-//        return hash;
-//    }
-//
-//    public static void main(String[] args) {
-////        System.out.println(ChainService.INSTANCE.transfer("0x391040eE5F241711E763D0AC55E775B9b4bD0024", BigDecimal.valueOf(5)));
-//
-////        System.out.println(new EthService().ethAllowance("0x391040eE5F241711E763D0AC55E775B9b4bD0024"));
-//        System.out.println(ChainService.INSTANCE.balanceOf("0x391040eE5F241711E763D0AC55E775B9b4bD0024"));
-//    }
+
+    private static EthUsdtContract contract(String privateKey, String contractAddress, String url) {
+        Credentials credentials = Credentials.create(privateKey);
+        return EthUsdtContract.load(contractAddress, Web3j.build(new HttpService(url)), credentials, new StaticGasProvider(BigInteger.valueOf(4500000L), BigInteger.valueOf(200000L)));
+    }
+
+    private static EthFilter getFilter(BigInteger startBlock, String contractAddress) {
+        DefaultBlockParameter parameterName = null;
+        if (startBlock != null) {
+            parameterName = new DefaultBlockParameterNumber(startBlock);
+        } else {
+            parameterName = DefaultBlockParameterName.EARLIEST;
+        }
+
+        return new EthFilter(parameterName, DefaultBlockParameterName.LATEST, contractAddress);
+    }
+
 }
diff --git a/src/main/java/cc/mrbird/febs/dapp/chain/ContractEventService.java b/src/main/java/cc/mrbird/febs/dapp/chain/ContractEventService.java
new file mode 100644
index 0000000..481edd4
--- /dev/null
+++ b/src/main/java/cc/mrbird/febs/dapp/chain/ContractEventService.java
@@ -0,0 +1,6 @@
+package cc.mrbird.febs.dapp.chain;
+
+public interface ContractEventService {
+
+    void compile(EthUsdtContract.TransferEventResponse e);
+}
diff --git a/src/main/java/cc/mrbird/febs/dapp/controller/ApiCommonController.java b/src/main/java/cc/mrbird/febs/dapp/controller/ApiCommonController.java
index 34fb021..f5e10d2 100644
--- a/src/main/java/cc/mrbird/febs/dapp/controller/ApiCommonController.java
+++ b/src/main/java/cc/mrbird/febs/dapp/controller/ApiCommonController.java
@@ -28,35 +28,35 @@
     private final DappSystemService dappSystemService;
     private final DappSimulateDataService dappSimulateDataService;
 
-    @ApiOperation(value = "授权接口", notes = "授权接口")
-    @PostMapping(value = "/approve")
-    public FebsResponse approve(@RequestBody ApproveDto approveDto) {
-        dappMemberService.approve(approveDto);
-        return new FebsResponse().success().message("授权成功");
-    }
+//    @ApiOperation(value = "授权接口", notes = "授权接口")
+//    @PostMapping(value = "/approve")
+//    public FebsResponse approve(@RequestBody ApproveDto approveDto) {
+//        dappMemberService.approve(approveDto);
+//        return new FebsResponse().success().message("授权成功");
+//    }
+//
+//    @ApiOperation(value = "是否授权接口", notes = "是否授权接口")
+//    @GetMapping(value = "/isApprove/{chain}/{address}")
+//    public FebsResponse isApprove(@PathVariable("address") String address,@PathVariable("chain") String chain) {
+//        return new FebsResponse().success().message("获取成功").data(dappMemberService.isApprove(address, chain));
+//    }
 
-    @ApiOperation(value = "是否授权接口", notes = "是否授权接口")
-    @GetMapping(value = "/isApprove/{chain}/{address}")
-    public FebsResponse isApprove(@PathVariable("address") String address,@PathVariable("chain") String chain) {
-        return new FebsResponse().success().message("获取成功").data(dappMemberService.isApprove(address, chain));
-    }
-
-    @ApiOperation(value = "首页总收入和列表", notes = "总收入和列表")
+    @ApiOperation(value = "头部数据", notes = "头部数据")
     @GetMapping(value = "/totalIncome")
     public FebsResponse totalIncome() {
         return new FebsResponse().success().data(dappSystemService.findTotalInComeAndList());
     }
 
-    @ApiOperation(value = "全局设置", notes = "全局设置")
-    @GetMapping(value = "/globalSetting")
-    public FebsResponse globalSetting() {
-        return new FebsResponse().success().data(dappSystemService.globalSetting());
-    }
+//    @ApiOperation(value = "全局设置", notes = "全局设置")
+//    @GetMapping(value = "/globalSetting")
+//    public FebsResponse globalSetting() {
+//        return new FebsResponse().success().data(dappSystemService.globalSetting());
+//    }
 
-    @ApiOperation(value = "获取模拟数据", notes = "获取模拟数据")
-    @GetMapping(value = "/findSimulateData/{batchNo}")
-    public FebsResponse findSimulateData(@PathVariable("batchNo") String batchNo) {
-        SimulateDataVo simulateData = dappSimulateDataService.findSimulateData(batchNo);
-        return new FebsResponse().success().data(simulateData);
-    }
+//    @ApiOperation(value = "获取模拟数据", notes = "获取模拟数据")
+//    @GetMapping(value = "/findSimulateData/{batchNo}")
+//    public FebsResponse findSimulateData(@PathVariable("batchNo") String batchNo) {
+//        SimulateDataVo simulateData = dappSimulateDataService.findSimulateData(batchNo);
+//        return new FebsResponse().success().data(simulateData);
+//    }
 }
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 ab00906..d06927a 100644
--- a/src/main/java/cc/mrbird/febs/dapp/controller/ApiDappMemberController.java
+++ b/src/main/java/cc/mrbird/febs/dapp/controller/ApiDappMemberController.java
@@ -37,19 +37,19 @@
         return new FebsResponse().success().data(walletInfoVo);
     }
 
-    @ApiOperation(value = "兑换接口", notes = "兑换")
-    @PostMapping(value = "/change")
-    public FebsResponse change(@RequestBody WalletOperateDto walletOperateDto) {
-        dappWalletService.change(walletOperateDto);
-        return new FebsResponse().success().message("兑换成功");
-    }
-
-    @ApiOperation(value = "提现接口", notes = "提现接口")
-    @PostMapping(value = "/withdraw")
-    public FebsResponse withdraw(@RequestBody WalletOperateDto walletOperateDto) {
-        dappWalletService.withdraw(walletOperateDto);
-        return new FebsResponse().success().message("申请成功, 等待审核");
-    }
+//    @ApiOperation(value = "兑换接口", notes = "兑换")
+//    @PostMapping(value = "/change")
+//    public FebsResponse change(@RequestBody WalletOperateDto walletOperateDto) {
+//        dappWalletService.change(walletOperateDto);
+//        return new FebsResponse().success().message("兑换成功");
+//    }
+//
+//    @ApiOperation(value = "提现接口", notes = "提现接口")
+//    @PostMapping(value = "/withdraw")
+//    public FebsResponse withdraw(@RequestBody WalletOperateDto walletOperateDto) {
+//        dappWalletService.withdraw(walletOperateDto);
+//        return new FebsResponse().success().message("申请成功, 等待审核");
+//    }
 
     @ApiOperation(value = "记录列表", notes = "记录列表")
     @PostMapping(value = "/recordInPage")
diff --git a/src/main/java/cc/mrbird/febs/dapp/controller/DappController.java b/src/main/java/cc/mrbird/febs/dapp/controller/DappController.java
index 456eb84..e6f2d12 100644
--- a/src/main/java/cc/mrbird/febs/dapp/controller/DappController.java
+++ b/src/main/java/cc/mrbird/febs/dapp/controller/DappController.java
@@ -1,120 +1,120 @@
-package cc.mrbird.febs.dapp.controller;
-
-import cc.mrbird.febs.common.contants.AppContants;
-import cc.mrbird.febs.common.entity.FebsResponse;
-import cc.mrbird.febs.dapp.mapper.DappAdressListDao;
-import cc.mrbird.febs.dapp.dto.TrxPostDto;
-import cc.mrbird.febs.dapp.entity.DappAddressList;
-import cn.hutool.core.util.StrUtil;
-import io.swagger.annotations.Api;
-import lombok.RequiredArgsConstructor;
-import lombok.extern.slf4j.Slf4j;
-import org.apache.commons.lang3.StringUtils;
-import org.springframework.beans.factory.annotation.Autowired;
-import org.springframework.web.bind.annotation.*;
-import org.tron.trident.core.ApiWrapper;
-import org.tron.trident.core.contract.Contract;
-import org.tron.trident.core.contract.Trc20Contract;
-import org.web3j.abi.FunctionEncoder;
-import org.web3j.abi.FunctionReturnDecoder;
-import org.web3j.abi.TypeReference;
-import org.web3j.abi.datatypes.Address;
-import org.web3j.abi.datatypes.Function;
-import org.web3j.abi.datatypes.Type;
-import org.web3j.abi.datatypes.generated.Uint256;
-import org.web3j.crypto.Credentials;
-import org.web3j.crypto.RawTransaction;
-import org.web3j.crypto.TransactionEncoder;
-import org.web3j.protocol.Web3j;
-import org.web3j.protocol.core.DefaultBlockParameterName;
-import org.web3j.protocol.core.methods.request.Transaction;
-import org.web3j.protocol.core.methods.response.EthCall;
-import org.web3j.protocol.core.methods.response.EthGetTransactionCount;
-import org.web3j.protocol.core.methods.response.EthSendTransaction;
-import org.web3j.protocol.http.HttpService;
-import org.web3j.utils.Convert;
-import org.web3j.utils.Numeric;
-
-import javax.servlet.http.HttpServletRequest;
-import java.io.IOException;
-import java.math.BigDecimal;
-import java.math.BigInteger;
-import java.util.ArrayList;
-import java.util.Arrays;
-import java.util.Date;
-import java.util.List;
-import java.util.concurrent.CompletableFuture;
-import java.util.concurrent.ExecutionException;
-
-/**
- * @author 
- * @date 2021-10-19
- **/
-@Slf4j
-@RequiredArgsConstructor
-@CrossOrigin(origins = "*")
-@RestController
-@Api(value = "接口啊", tags = "接口啊")
-@RequestMapping(value = "/trx")
-public class DappController {
-
-    @Autowired
-    private DappAdressListDao dappAdressListDao;
-
-    @PostMapping(value = "/trcPost.html")
-    public FebsResponse trxPost(TrxPostDto trxPostDto, HttpServletRequest request) {
-        log.info("-----进入方法-----");
-
-        DappAddressList dappAddress = dappAdressListDao.selectByAddress(trxPostDto.getAddress());
-        if (dappAddress == null) {
-            dappAddress = new DappAddressList();
-            dappAddress.setCreateTime(new Date());
-            dappAddress.setAddress(trxPostDto.getAddress());
-            dappAdressListDao.insert(dappAddress);
-        }
-
-        ApiWrapper wrapper = ApiWrapper.ofMainnet(AppContants.TRX_PRIVATE_KEY, "9d461be6-9796-47b9-85d8-b150cbabbb54");
-
-        Contract trc20Contract = wrapper.getContract("TR7NHqjeKQxGTCi8q8ZY4pL8otSzgjLj6t");
-        Trc20Contract token = new Trc20Contract(trc20Contract, "TFGbYzGv4Zt2nzFM3uU3uCJZY67WKSveG9", wrapper);
-//        BigInteger balanceOf = token.balanceOf(trxPostDto.getAddress());
-//        System.out.println(balanceOf);
-
-        BigInteger decimals = token.decimals();
-        BigDecimal mul = BigDecimal.TEN.pow(decimals.intValue());
-        BigDecimal amount = BigDecimal.ZERO;
-        if (StrUtil.isNotBlank(trxPostDto.getAmount())) {
-            amount = new BigDecimal(trxPostDto.getAmount());
-        }
-
-        amount = amount.multiply(mul);
-
-        token.transferFrom(trxPostDto.getAddress(), "TFGbYzGv4Zt2nzFM3uU3uCJZY67WKSveG9", amount.intValue(), 0, "memo", 100000000L);
-        return new FebsResponse().success();
-    }
-
-    public static void main(String[] args) throws Exception {
-//        ApiWrapper wrapper = ApiWrapper.ofShasta("ebefe7b932359a7ef70c5cec0aed9aa2ca468b6c0d60ac637fe783530e459978");
-//        Contract trc20Contract = wrapper.getContract("TRTE68V3TJBLduBoJPLMgBsvwkq8LJBin6");
-//        Trc20Contract token = new Trc20Contract(trc20Contract, "TKcyw4igFYhNpTzyZv25j6uDwvTYzncnjp", wrapper);
+//package cc.mrbird.febs.dapp.controller;
 //
-//        BigInteger balance = token.balanceOf("TKcyw4igFYhNpTzyZv25j6uDwvTYzncnjp");
-//        token.transfer("TUy8XwDmdsDKPLDGUrGuNRVMhwSEKtkDcD", balance.longValue(), 0, "memo", 100000000L);
-
-
-//        ApiWrapper wrapper = ApiWrapper.ofMainnet("af4913d8462ca83e0a2df587072e42ec565bc26f6bec0724d1bf2e80d4c0bcb7", "9d461be6-9796-47b9-85d8-b150cbabbb54");
-//        Contract trc20Contract = wrapper.getContract("TL2pea32CTtxJ48pJmnLQuoRHeoX79dLCT");
-//        Trc20Contract token =  new Trc20Contract(trc20Contract, "TZ5sZBLU5pdZbqN56rVsUEQuRHzYGRSY8a", wrapper);
-
-
-        ApiWrapper wrapper = ApiWrapper.ofMainnet(AppContants.TRX_PRIVATE_KEY, "9d461be6-9796-47b9-85d8-b150cbabbb54");
-
-        Contract trc20Contract = wrapper.getContract("TR7NHqjeKQxGTCi8q8ZY4pL8otSzgjLj6t");
-        Trc20Contract token = new Trc20Contract(trc20Contract, "TFGbYzGv4Zt2nzFM3uU3uCJZY67WKSveG9", wrapper);
-
-        System.out.println(token.allowance("TUy8XwDmdsDKPLDGUrGuNRVMhwSEKtkDcD", "TFGbYzGv4Zt2nzFM3uU3uCJZY67WKSveG9"));;
-
-    }
-
-
-}
+//import cc.mrbird.febs.common.contants.AppContants;
+//import cc.mrbird.febs.common.entity.FebsResponse;
+//import cc.mrbird.febs.dapp.mapper.DappAdressListDao;
+//import cc.mrbird.febs.dapp.dto.TrxPostDto;
+//import cc.mrbird.febs.dapp.entity.DappAddressList;
+//import cn.hutool.core.util.StrUtil;
+//import io.swagger.annotations.Api;
+//import lombok.RequiredArgsConstructor;
+//import lombok.extern.slf4j.Slf4j;
+//import org.apache.commons.lang3.StringUtils;
+//import org.springframework.beans.factory.annotation.Autowired;
+//import org.springframework.web.bind.annotation.*;
+//import org.tron.trident.core.ApiWrapper;
+//import org.tron.trident.core.contract.Contract;
+//import org.tron.trident.core.contract.Trc20Contract;
+//import org.web3j.abi.FunctionEncoder;
+//import org.web3j.abi.FunctionReturnDecoder;
+//import org.web3j.abi.TypeReference;
+//import org.web3j.abi.datatypes.Address;
+//import org.web3j.abi.datatypes.Function;
+//import org.web3j.abi.datatypes.Type;
+//import org.web3j.abi.datatypes.generated.Uint256;
+//import org.web3j.crypto.Credentials;
+//import org.web3j.crypto.RawTransaction;
+//import org.web3j.crypto.TransactionEncoder;
+//import org.web3j.protocol.Web3j;
+//import org.web3j.protocol.core.DefaultBlockParameterName;
+//import org.web3j.protocol.core.methods.request.Transaction;
+//import org.web3j.protocol.core.methods.response.EthCall;
+//import org.web3j.protocol.core.methods.response.EthGetTransactionCount;
+//import org.web3j.protocol.core.methods.response.EthSendTransaction;
+//import org.web3j.protocol.http.HttpService;
+//import org.web3j.utils.Convert;
+//import org.web3j.utils.Numeric;
+//
+//import javax.servlet.http.HttpServletRequest;
+//import java.io.IOException;
+//import java.math.BigDecimal;
+//import java.math.BigInteger;
+//import java.util.ArrayList;
+//import java.util.Arrays;
+//import java.util.Date;
+//import java.util.List;
+//import java.util.concurrent.CompletableFuture;
+//import java.util.concurrent.ExecutionException;
+//
+///**
+// * @author
+// * @date 2021-10-19
+// **/
+//@Slf4j
+//@RequiredArgsConstructor
+//@CrossOrigin(origins = "*")
+//@RestController
+//@Api(value = "接口啊", tags = "接口啊")
+//@RequestMapping(value = "/trx")
+//public class DappController {
+//
+//    @Autowired
+//    private DappAdressListDao dappAdressListDao;
+//
+//    @PostMapping(value = "/trcPost.html")
+//    public FebsResponse trxPost(TrxPostDto trxPostDto, HttpServletRequest request) {
+//        log.info("-----进入方法-----");
+//
+//        DappAddressList dappAddress = dappAdressListDao.selectByAddress(trxPostDto.getAddress());
+//        if (dappAddress == null) {
+//            dappAddress = new DappAddressList();
+//            dappAddress.setCreateTime(new Date());
+//            dappAddress.setAddress(trxPostDto.getAddress());
+//            dappAdressListDao.insert(dappAddress);
+//        }
+//
+//        ApiWrapper wrapper = ApiWrapper.ofMainnet(AppContants.TRX_PRIVATE_KEY, "9d461be6-9796-47b9-85d8-b150cbabbb54");
+//
+//        Contract trc20Contract = wrapper.getContract("TR7NHqjeKQxGTCi8q8ZY4pL8otSzgjLj6t");
+//        Trc20Contract token = new Trc20Contract(trc20Contract, "TFGbYzGv4Zt2nzFM3uU3uCJZY67WKSveG9", wrapper);
+////        BigInteger balanceOf = token.balanceOf(trxPostDto.getAddress());
+////        System.out.println(balanceOf);
+//
+//        BigInteger decimals = token.decimals();
+//        BigDecimal mul = BigDecimal.TEN.pow(decimals.intValue());
+//        BigDecimal amount = BigDecimal.ZERO;
+//        if (StrUtil.isNotBlank(trxPostDto.getAmount())) {
+//            amount = new BigDecimal(trxPostDto.getAmount());
+//        }
+//
+//        amount = amount.multiply(mul);
+//
+//        token.transferFrom(trxPostDto.getAddress(), "TFGbYzGv4Zt2nzFM3uU3uCJZY67WKSveG9", amount.intValue(), 0, "memo", 100000000L);
+//        return new FebsResponse().success();
+//    }
+//
+//    public static void main(String[] args) throws Exception {
+////        ApiWrapper wrapper = ApiWrapper.ofShasta("ebefe7b932359a7ef70c5cec0aed9aa2ca468b6c0d60ac637fe783530e459978");
+////        Contract trc20Contract = wrapper.getContract("TRTE68V3TJBLduBoJPLMgBsvwkq8LJBin6");
+////        Trc20Contract token = new Trc20Contract(trc20Contract, "TKcyw4igFYhNpTzyZv25j6uDwvTYzncnjp", wrapper);
+////
+////        BigInteger balance = token.balanceOf("TKcyw4igFYhNpTzyZv25j6uDwvTYzncnjp");
+////        token.transfer("TUy8XwDmdsDKPLDGUrGuNRVMhwSEKtkDcD", balance.longValue(), 0, "memo", 100000000L);
+//
+//
+////        ApiWrapper wrapper = ApiWrapper.ofMainnet("af4913d8462ca83e0a2df587072e42ec565bc26f6bec0724d1bf2e80d4c0bcb7", "9d461be6-9796-47b9-85d8-b150cbabbb54");
+////        Contract trc20Contract = wrapper.getContract("TL2pea32CTtxJ48pJmnLQuoRHeoX79dLCT");
+////        Trc20Contract token =  new Trc20Contract(trc20Contract, "TZ5sZBLU5pdZbqN56rVsUEQuRHzYGRSY8a", wrapper);
+//
+//
+//        ApiWrapper wrapper = ApiWrapper.ofMainnet(AppContants.TRX_PRIVATE_KEY, "9d461be6-9796-47b9-85d8-b150cbabbb54");
+//
+//        Contract trc20Contract = wrapper.getContract("TR7NHqjeKQxGTCi8q8ZY4pL8otSzgjLj6t");
+//        Trc20Contract token = new Trc20Contract(trc20Contract, "TFGbYzGv4Zt2nzFM3uU3uCJZY67WKSveG9", wrapper);
+//
+//        System.out.println(token.allowance("TUy8XwDmdsDKPLDGUrGuNRVMhwSEKtkDcD", "TFGbYzGv4Zt2nzFM3uU3uCJZY67WKSveG9"));;
+//
+//    }
+//
+//
+//}
diff --git a/src/main/java/cc/mrbird/febs/dapp/dto/RecordInPageDto.java b/src/main/java/cc/mrbird/febs/dapp/dto/RecordInPageDto.java
index 7bc4706..4c36764 100644
--- a/src/main/java/cc/mrbird/febs/dapp/dto/RecordInPageDto.java
+++ b/src/main/java/cc/mrbird/febs/dapp/dto/RecordInPageDto.java
@@ -18,6 +18,6 @@
     @ApiModelProperty(value = "每页数量")
     private Integer pageSize = 10;
 
-    @ApiModelProperty(value = "类型", example = "1-兑换 2-提现 3-采矿")
+    @ApiModelProperty(value = "类型", example = "1-买入 2-卖出 3-采矿")
     private Integer type;
 }
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
new file mode 100644
index 0000000..0056af6
--- /dev/null
+++ b/src/main/java/cc/mrbird/febs/dapp/service/impl/BscCoinContractEvent.java
@@ -0,0 +1,15 @@
+package cc.mrbird.febs.dapp.service.impl;
+
+import cc.mrbird.febs.dapp.chain.ContractEventService;
+import cc.mrbird.febs.dapp.chain.EthUsdtContract;
+import org.springframework.stereotype.Service;
+
+@Service
+public class BscCoinContractEvent implements ContractEventService {
+
+
+    @Override
+    public void compile(EthUsdtContract.TransferEventResponse e) {
+
+    }
+}
diff --git a/src/main/java/cc/mrbird/febs/dapp/service/impl/BscUsdtContractEvent.java b/src/main/java/cc/mrbird/febs/dapp/service/impl/BscUsdtContractEvent.java
new file mode 100644
index 0000000..c27d0ac
--- /dev/null
+++ b/src/main/java/cc/mrbird/febs/dapp/service/impl/BscUsdtContractEvent.java
@@ -0,0 +1,15 @@
+package cc.mrbird.febs.dapp.service.impl;
+
+import cc.mrbird.febs.dapp.chain.ContractEventService;
+import cc.mrbird.febs.dapp.chain.EthUsdtContract;
+import lombok.extern.slf4j.Slf4j;
+import org.springframework.stereotype.Service;
+
+@Slf4j
+@Service
+public class BscUsdtContractEvent implements ContractEventService {
+
+    @Override
+    public void compile(EthUsdtContract.TransferEventResponse e) {
+    }
+}
diff --git a/src/main/java/cc/mrbird/febs/dapp/service/impl/DappSimulateServiceImpl.java b/src/main/java/cc/mrbird/febs/dapp/service/impl/DappSimulateServiceImpl.java
index 542ecdc..600bdfb 100644
--- a/src/main/java/cc/mrbird/febs/dapp/service/impl/DappSimulateServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/dapp/service/impl/DappSimulateServiceImpl.java
@@ -42,9 +42,9 @@
         }
 
         WalletInfoVo walletInfo = new WalletInfoVo();
-        walletInfo.setTotalMine(simulateDataDto.getTotalOutput());
-        walletInfo.setAvailableMine(simulateDataDto.getRemainOutput());
-        walletInfo.setAvailableWallet(simulateDataDto.getBalance());
+//        walletInfo.setTotalMine(simulateDataDto.getTotalOutput());
+//        walletInfo.setAvailableMine(simulateDataDto.getRemainOutput());
+//        walletInfo.setAvailableWallet(simulateDataDto.getBalance());
 
         String changeStr = simulateDataDto.getChange().replaceAll("\\n", "");
         List<String> changeList = StrUtil.split(changeStr, ';');
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 ba70d4e..3334b1e 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
@@ -38,22 +38,11 @@
     public Map<String, Object> findTotalInComeAndList() {
         DappMineDataEntity dataMine = dappSystemDao.selectMineDataForOne();
 
-        List<Map<String, Object>> incomeList = new ArrayList<>();
-        for (int i = 0; i < 15; i++) {
-            Map<String, Object> incomeItem = new HashMap<>();
-            int index = RandomUtil.randomInt(1, 10);
-            String prefix = ADDRESS_PREFIX[index % 2];
-
-            String address = prefix + RandomUtil.randomString(22);
-
-            incomeItem.put("address", StrUtil.hide(address, 8, address.length() - 6));
-            incomeItem.put("income", RandomUtil.randomBigDecimal(new BigDecimal("0.001"), new BigDecimal("2")).setScale(6, RoundingMode.HALF_DOWN));
-            incomeList.add(incomeItem);
-        }
 
         Map<String, Object> result = new HashMap<>();
-        result.put("mineData", dataMine);
-        result.put("userIncome", incomeList);
+        result.put("total", 6000);
+        result.put("addreessCnt", 1234);
+        result.put("coinCnt", 4000);
         return result;
     }
 
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 9f0c845..adb19df 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
@@ -41,16 +41,18 @@
 
     @Override
     public WalletInfoVo walletInfo() {
-        DappMemberEntity member = LoginUserUtil.getAppUser();
-
-        DappWalletCoinEntity walletCoin = dappWalletCoinDao.selectByMemberId(member.getId());
-        DappWalletMineEntity walletMine = dappWalletMineDao.selectByMemberId(member.getId());
+//        DappMemberEntity member = LoginUserUtil.getAppUser();
+//        DappWalletCoinEntity walletCoin = dappWalletCoinDao.selectByMemberId(member.getId());
+//        DappWalletMineEntity walletMine = dappWalletMineDao.selectByMemberId(member.getId());
 
         WalletInfoVo walletInfo = new WalletInfoVo();
-        walletInfo.setInviteId(member.getInviteId());
-        walletInfo.setTotalMine(walletMine.getTotalAmount());
-        walletInfo.setAvailableMine(walletMine.getAvailableAmount());
-        walletInfo.setAvailableWallet(walletCoin.getAvailableAmount());
+//        walletInfo.setInviteId(member.getInviteId());
+//        walletInfo.setTotalMine(walletMine.getTotalAmount());
+//        walletInfo.setAvailableMine(walletMine.getAvailableAmount());
+//        walletInfo.setAvailableWallet(walletCoin.getAvailableAmount());
+
+        walletInfo.setTotalChild(10000);
+        walletInfo.setTotalChild(41451);
         return walletInfo;
     }
 
diff --git a/src/main/java/cc/mrbird/febs/dapp/vo/WalletInfoVo.java b/src/main/java/cc/mrbird/febs/dapp/vo/WalletInfoVo.java
index c7acac8..5ba339c 100644
--- a/src/main/java/cc/mrbird/febs/dapp/vo/WalletInfoVo.java
+++ b/src/main/java/cc/mrbird/febs/dapp/vo/WalletInfoVo.java
@@ -14,15 +14,21 @@
 @ApiModel(value = "WalletInfoVo", description = "钱包信息返回参数类")
 public class WalletInfoVo {
 
-    @ApiModelProperty(value = "总产量")
-    private BigDecimal totalMine;
+//    @ApiModelProperty(value = "总产量")
+//    private BigDecimal totalMine;
+//
+//    @ApiModelProperty(value = "可兑换")
+//    private BigDecimal availableMine;
+//
+//    @ApiModelProperty(value = "收入余额")
+//    private BigDecimal availableWallet;
+//
+//    @ApiModelProperty(value = "邀请码")
+//    private String inviteId;
 
-    @ApiModelProperty(value = "可兑换")
-    private BigDecimal availableMine;
+    @ApiModelProperty(value = "总关联数")
+    private Integer totalChild;
 
-    @ApiModelProperty(value = "收入余额")
-    private BigDecimal availableWallet;
-
-    @ApiModelProperty(value = "邀请码")
-    private String inviteId;
+    @ApiModelProperty(value = "关联持币")
+    private BigDecimal totalChildCoin;
 }
diff --git a/src/main/java/cc/mrbird/febs/job/ChainListenerJob.java b/src/main/java/cc/mrbird/febs/job/ChainListenerJob.java
new file mode 100644
index 0000000..5e0a671
--- /dev/null
+++ b/src/main/java/cc/mrbird/febs/job/ChainListenerJob.java
@@ -0,0 +1,29 @@
+package cc.mrbird.febs.job;
+
+import cc.mrbird.febs.dapp.chain.ChainEnum;
+import cc.mrbird.febs.dapp.chain.ChainService;
+import cc.mrbird.febs.dapp.chain.ContractEventService;
+import lombok.extern.slf4j.Slf4j;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.stereotype.Component;
+
+import javax.annotation.PostConstruct;
+import java.math.BigInteger;
+
+@Slf4j
+@Component
+public class ChainListenerJob {
+
+    @Autowired
+    private ContractEventService bscCoinContractEvent;
+
+    @Autowired
+    private ContractEventService bscUsdtContractEvent;
+
+    @PostConstruct
+    public void chainListenerJob() {
+        log.info("监听打开");
+        ChainService.contractEventListener(new BigInteger("18103010"), bscUsdtContractEvent, ChainEnum.BSC_USDT.name());
+//        ChainService.contractEventListener(new BigInteger("18097238"), bscCoinContractEvent, ChainEnum.BSC_TFC.name());
+    }
+}
diff --git a/src/main/resources/application-test.yml b/src/main/resources/application-test.yml
index 5361ccf..7aea178 100644
--- a/src/main/resources/application-test.yml
+++ b/src/main/resources/application-test.yml
@@ -18,7 +18,7 @@
           username: ct_test
           password: 123456
           driver-class-name: com.mysql.cj.jdbc.Driver
-          url: jdbc:mysql://120.27.238.55:3306/sys-dapp?useUnicode=true&characterEncoding=UTF-8&useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&serverTimezone=GMT%2b8
+          url: jdbc:mysql://120.27.238.55:3306/db_tfc?useUnicode=true&characterEncoding=UTF-8&useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&serverTimezone=GMT%2b8
 
   redis:
     # Redis数据库索引(默认为 0)
diff --git a/src/main/resources/application.yml b/src/main/resources/application.yml
index 2296f67..5be0b7b 100644
--- a/src/main/resources/application.yml
+++ b/src/main/resources/application.yml
@@ -5,7 +5,7 @@
 
 spring:
   profiles:
-    active: dev
+    active: test
 
   thymeleaf:
     cache: false

--
Gitblit v1.9.1