From 17585522e004c8f70e9cf346f7debc18c65ffc60 Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Wed, 14 Dec 2022 15:52:21 +0800
Subject: [PATCH] 20221213转币

---
 src/main/java/cc/mrbird/febs/dapp/contract/ContractMain.java |   70 ++++++++++++++++++++++-------------
 1 files changed, 44 insertions(+), 26 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/dapp/contract/ContractMain.java b/src/main/java/cc/mrbird/febs/dapp/contract/ContractMain.java
index 96d14bd..32e7eb7 100644
--- a/src/main/java/cc/mrbird/febs/dapp/contract/ContractMain.java
+++ b/src/main/java/cc/mrbird/febs/dapp/contract/ContractMain.java
@@ -61,6 +61,7 @@
     // gas费用单价
 //    public static final BigInteger GAS_PRICE = BigInteger.valueOf(32000000000L);
     public static final BigInteger GAS_PRICE = Convert.toWei(getGas(), Convert.Unit.GWEI).toBigInteger();
+//    public static final BigInteger GAS_PRICE = Convert.toWei("5", Convert.Unit.GWEI).toBigInteger();
     // gas费用最大值
 //    public static final BigInteger GAS_LIMIT = BigInteger.valueOf(4300000L);
     public static final BigInteger GAS_LIMIT = Convert.toWei("100000", Convert.Unit.WEI).toBigInteger();
@@ -69,11 +70,15 @@
     }
 
     private static String getGas() {
-        String gas;
-        String resp = HttpUtil.get("https://gbsc.blockscan.com/gasapi.ashx?apikey=key&method=gasoracle");
-        JSONObject data = JSONObject.parseObject(resp);
-        gas = data.getString("FastGasPrice");
-        return StrUtil.isBlank(gas) ? "35" : gas;
+        String gas = "5";
+        try{
+            String resp = HttpUtil.get("https://gbsc.blockscan.com/gasapi.ashx?apikey=key&method=gasoracle");
+            JSONObject data = JSONObject.parseObject(resp);
+            gas = data.getString("FastGasPrice");
+        }catch (Exception exception) {
+            exception.printStackTrace();
+        }
+        return StrUtil.isBlank(gas) ? "5" : gas;
     }
 
     private static Web3j getInstanceScope() {
@@ -83,16 +88,17 @@
     }
 
     // 区块链节点地址 TODO
-    private static String blockchainNode = "https://data-seed-prebsc-1-s1.binance.org:8545/";
+//    private static String blockchainNode = "https://bsc-dataseed.binance.org";
+    private static String blockchainNode = "https://bsc-dataseed1.ninicoin.io";
 
     // 合约地址 TODO
-    private static String contractAddr = "0x90EEba71E1d2D0C09840cdB9B74759dFAe15Fc7E";
+    private static String contractAddr = "0xDc94C3DcaddE676142B4596E0310AE5C54Bd3765";
 //    private static String contractAddr = "0x4703cfEf33b6DbcF6a3020Ef98FC6ab9C4CC06b3";
 //    private static String contractAddr = "0x8f444b9b9C71f4Be883aE15466D71EC7699Cb5B1";
 
     // 操作账号 合约创建者的私钥 用于操作合约内方法 TODO
     //private static String privateKey = "8ea073b74265f41a03138e1adf2e8a80f4f394ac5337aa2eec07562c1040a4e4";
-    private static String privateKey = "0x8daacf781c7ad486abafba45aa9a68d6febcb618ce9cfaf21b9e6059729dac4e";
+    private static String privateKey = "0xbf6f11f5689961d5351375bebbae751de0d0d5c2e2095c1017368485dc909ff8";
 
     private EthFilter getFilter(BigInteger startBlock) {
         if (startBlock != null) {
@@ -121,28 +127,30 @@
                 String regCode = e.regCode;
                 // 投注人的地址
                 String from = e.from;
+                if(from==null){
+                    // 为空则不进入后续逻辑
+                    return;
+                }
+
                 // TODO 业务操作逻辑代码
                 System.out.println("regCode:"+regCode+",address:"+from);
                 // 更新区块编号 TODO
-                //redisService.set("BNB_BLOCK_NUMBER",e.log.getBlockNumber().intValue());
+                redisService.set("BNB_BLOCK_NUMBER",e.log.getBlockNumber().intValue());
                 //投注人
-                DappMemberEntity dappMemberEntity = dappMemberDao.selectByAddress(from, "BSC");
-                if(ObjectUtil.isNotEmpty(dappMemberEntity)){
-                    //投注人是否加入
-                    DappSystemProfit dappSystemProfit = dappSystemProfitDao.selectByMemberIdAndState(dappMemberEntity.getId(), DappSystemProfit.STATE_IN);
-                    if(ObjectUtil.isNotEmpty(dappSystemProfit)){
-                        List<DappFundFlowEntity> dappFundFlowEntities = dappFundFlowDao.selectListByState(DappFundFlowEntity.WITHDRAW_STATUS_ING);
-                        if(CollUtil.isNotEmpty(dappFundFlowEntities)){
-                            for(DappFundFlowEntity dappFundFlowEntity : dappFundFlowEntities){
-
-                                //发送转币消息
-                                chainProducer.sendBnbTransferMsg(dappFundFlowEntity.getId());
-//                            DappMemberEntity dappMember = dappMemberDao.selectById(dappFundFlowEntity.getMemberId());
-//                            trans(new BigInteger(dappFundFlowEntity.getAmount().toString()),dappMember.getAddress());
-                            }
-                        }
-                    }
-                }
+//                DappMemberEntity dappMemberEntity = dappMemberDao.selectByAddress(from, "BSC");
+//                if(ObjectUtil.isNotEmpty(dappMemberEntity)){
+//                    //投注人是否加入
+//                    DappSystemProfit dappSystemProfit = dappSystemProfitDao.selectByMemberIdAndState(dappMemberEntity.getId(), DappSystemProfit.STATE_IN);
+//                    if(ObjectUtil.isNotEmpty(dappSystemProfit)){
+//                        List<DappFundFlowEntity> dappFundFlowEntities = dappFundFlowDao.selectListByState(DappFundFlowEntity.WITHDRAW_STATUS_ING);
+//                        if(CollUtil.isNotEmpty(dappFundFlowEntities)){
+//                            for(DappFundFlowEntity dappFundFlowEntity : dappFundFlowEntities){
+//                                //发送转币消息
+//                                chainProducer.sendBnbTransferMsg(dappFundFlowEntity.getId());
+//                            }
+//                        }
+//                    }
+//                }
             }catch (Exception exception) {
                 exception.printStackTrace();
             }
@@ -157,6 +165,7 @@
         Credentials credentials = Credentials.create(privateKey);
         Abi contract = Abi.load(contractAddr, getInstance(), credentials, getStaticGasProvider());
         try {
+            //BigInteger bigInteger = Convert.toWei(amount.toString(), Convert.Unit.ETHER).toBigInteger();
             TransactionReceipt send = contract.trans(amount, to1).send();
             if(ObjectUtil.isNotEmpty(send)){
                 transactionHash = send.getTransactionHash();
@@ -166,4 +175,13 @@
         }
         return transactionHash;
     }
+
+    public static void main(String[] args) {
+        ContractMain contractMain = new ContractMain();
+
+        String address = "0xd9076245473060dda1a65f5f3d89a4d0598995e6";
+        BigInteger bigInteger = new BigInteger(Convert.toWei("0.00105", Convert.Unit.ETHER).setScale(0).toString());
+        String hash = contractMain.trans(bigInteger,address);
+        System.out.println(hash);
+    }
 }

--
Gitblit v1.9.1