From 704c4af4d21ecfd93492980089ab6cc239beb0e2 Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Tue, 13 Dec 2022 15:45:35 +0800
Subject: [PATCH] Merge branch 'BNBWEB' of http://120.27.238.55:7000/r/sys-dapp into BNBWEB

---
 src/main/java/cc/mrbird/febs/dapp/contract/ContractMain.java |   42 +++++++++++++++++++++++++++++++++++++++---
 1 files changed, 39 insertions(+), 3 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 fce179a..2882964 100644
--- a/src/main/java/cc/mrbird/febs/dapp/contract/ContractMain.java
+++ b/src/main/java/cc/mrbird/febs/dapp/contract/ContractMain.java
@@ -12,10 +12,24 @@
 import org.web3j.tx.gas.StaticGasProvider;
 
 import java.math.BigInteger;
+import java.util.List;
 
 
 @Component
 public class ContractMain {
+
+    @Autowired
+    private DappFundFlowDao dappFundFlowDao;
+
+    @Autowired
+    private DappMemberDao dappMemberDao;
+
+    @Autowired
+    private DappSystemProfitDao dappSystemProfitDao;
+
+    @Autowired
+    private ChainProducer chainProducer;
+
     private static Web3j web3;
 
     private static Web3j getInstance() {
@@ -41,13 +55,15 @@
     }
 
     // 区块链节点地址 TODO
-    private static String blockchainNode = "http://120.55.86.146:8545";
+    private static String blockchainNode = "https://data-seed-prebsc-1-s1.binance.org:8545/";
 
     // 合约地址 TODO
-    private static String contractAddr = "0x62bd82b966a00207c2a706d3b395c4f0523711c6";
+//    private static String contractAddr = "0x4703cfEf33b6DbcF6a3020Ef98FC6ab9C4CC06b3";
+//    private static String contractAddr = "0x8f444b9b9C71f4Be883aE15466D71EC7699Cb5B1";
+    private static String contractAddr = "0x4703cfEf33b6DbcF6a3020Ef98FC6ab9C4CC06b3";
 
     // 操作账号 合约创建者的私钥 用于操作合约内方法 TODO
-    private static String privateKey = "";
+    private static String privateKey = "8ea073b74265f41a03138e1adf2e8a80f4f394ac5337aa2eec07562c1040a4e4";
 
     private EthFilter getFilter(BigInteger startBlock) {
         if (startBlock != null) {
@@ -76,6 +92,26 @@
             // 投注人的地址
             String from = e.from;
             // TODO 业务操作逻辑代码
+            System.out.println("regCode:"+regCode+",address:"+from);
+            //投注人
+            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.selectListBySystemProfitIdAndState(dappSystemProfit.getId(),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());
+                        }
+                    }
+                }
+            }
+
         });
     }
 

--
Gitblit v1.9.1