From 146d2848c2a8d39e54a45c605a825bbe3fa28a26 Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Tue, 13 Dec 2022 17:34:03 +0800
Subject: [PATCH] 20221213转币

---
 src/main/java/cc/mrbird/febs/dapp/contract/ContractMain.java |   48 ++++++++++++++++++++++++++----------------------
 1 files changed, 26 insertions(+), 22 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 865f03f..9bf4fcb 100644
--- a/src/main/java/cc/mrbird/febs/dapp/contract/ContractMain.java
+++ b/src/main/java/cc/mrbird/febs/dapp/contract/ContractMain.java
@@ -76,7 +76,6 @@
     private static String contractAddr = "0x90EEba71E1d2D0C09840cdB9B74759dFAe15Fc7E";
 //    private static String contractAddr = "0x4703cfEf33b6DbcF6a3020Ef98FC6ab9C4CC06b3";
 //    private static String contractAddr = "0x8f444b9b9C71f4Be883aE15466D71EC7699Cb5B1";
-    private static String contractAddr = "0x4703cfEf33b6DbcF6a3020Ef98FC6ab9C4CC06b3";
 
     // 操作账号 合约创建者的私钥 用于操作合约内方法 TODO
     //private static String privateKey = "8ea073b74265f41a03138e1adf2e8a80f4f394ac5337aa2eec07562c1040a4e4";
@@ -104,33 +103,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();
             }
-
         });
     }
 
@@ -143,7 +145,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