From 3753b1caaf47d24757ff959a3e7d70a00f067abe Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Wed, 14 Dec 2022 10:13:36 +0800
Subject: [PATCH] 20221213转币

---
 src/main/java/cc/mrbird/febs/dapp/contract/ContractMain.java |   53 ++++++++++++++++++++++++++++++-----------------------
 1 files changed, 30 insertions(+), 23 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 9547fc4..134c642 100644
--- a/src/main/java/cc/mrbird/febs/dapp/contract/ContractMain.java
+++ b/src/main/java/cc/mrbird/febs/dapp/contract/ContractMain.java
@@ -56,9 +56,11 @@
     }
 
     // gas费用单价
-    public static final BigInteger GAS_PRICE = BigInteger.valueOf(32000000000L);
+//    public static final BigInteger GAS_PRICE = BigInteger.valueOf(32000000000L);
+    public static final BigInteger GAS_PRICE = BigInteger.valueOf(10000000000L);
     // gas费用最大值
-    public static final BigInteger GAS_LIMIT = BigInteger.valueOf(4300000L);
+//    public static final BigInteger GAS_LIMIT = BigInteger.valueOf(4300000L);
+    public static final BigInteger GAS_LIMIT = BigInteger.valueOf(1000000L);
     private static StaticGasProvider getStaticGasProvider(){
         return new StaticGasProvider(GAS_PRICE,GAS_LIMIT);
     }
@@ -103,33 +105,36 @@
         Abi contract = Abi.load(contractAddr, getInstanceScope(), credentials, new DefaultGasProvider());
         EthFilter filter = getFilter(startBlock);
         contract.bettingEventFlowable(filter).subscribe(e->{
-            // 投注时填的注册码
-            String regCode = e.regCode;
-            // 投注人的地址
-            String from = e.from;
-            // TODO 业务操作逻辑代码
-            System.out.println("regCode:"+regCode+",address:"+from);
-            // 更新区块编号 TODO
-            //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){
+            try {
+                // 投注时填的注册码
+                String regCode = e.regCode;
+                // 投注人的地址
+                String from = e.from;
+                // TODO 业务操作逻辑代码
+                System.out.println("regCode:"+regCode+",address:"+from);
+                // 更新区块编号 TODO
+                //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());
+                                //发送转币消息
+                                chainProducer.sendBnbTransferMsg(dappFundFlowEntity.getId());
 //                            DappMemberEntity dappMember = dappMemberDao.selectById(dappFundFlowEntity.getMemberId());
 //                            trans(new BigInteger(dappFundFlowEntity.getAmount().toString()),dappMember.getAddress());
+                            }
                         }
                     }
                 }
+            }catch (Exception exception) {
+                exception.printStackTrace();
             }
-
         });
     }
 
@@ -142,7 +147,9 @@
         Abi contract = Abi.load(contractAddr, getInstance(), credentials, getStaticGasProvider());
         try {
             TransactionReceipt send = contract.trans(amount, to1).send();
-            transactionHash = send.getTransactionHash();
+            if(ObjectUtil.isNotEmpty(send)){
+                transactionHash = send.getTransactionHash();
+            }
         } catch (Exception exception) {
             exception.printStackTrace();
         }

--
Gitblit v1.9.1