From cbc6726bb3a9b68881987e47f966237503973234 Mon Sep 17 00:00:00 2001
From: Helius <wangdoubleone@gmail.com>
Date: Wed, 25 May 2022 18:39:21 +0800
Subject: [PATCH] bsc tfc
---
src/main/java/cc/mrbird/febs/dapp/chain/ChainService.java | 32 ++++++++++
src/main/java/cc/mrbird/febs/dapp/service/impl/BscUsdtContractEvent.java | 7 ++
src/main/java/cc/mrbird/febs/job/ChainListenerJob.java | 4
src/main/resources/mapper/dapp/DappMemberDao.xml | 5 +
src/main/java/cc/mrbird/febs/dapp/service/impl/BscCoinContractEvent.java | 75 +++++++++++++++++++++++++
5 files changed, 119 insertions(+), 4 deletions(-)
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 661d7f2..135f689 100644
--- a/src/main/java/cc/mrbird/febs/dapp/chain/ChainService.java
+++ b/src/main/java/cc/mrbird/febs/dapp/chain/ChainService.java
@@ -52,6 +52,7 @@
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);
private final static ContractChainService TRX = new TrxService(TRX_ADDRESS, TRX_PRIVATE, TRX_CONTRACT_ADDRESS, API_KEY);
+ private final static ContractChainService BSC_TFC = new EthService(ChainEnum.BSC_TFC.getUrl(), ChainEnum.BSC_TFC.getAddress(), ChainEnum.BSC_TFC.getPrivateKey(), ChainEnum.BSC_TFC.getContractAddress());
private final String ETH_PREFIX = "0x";
@@ -68,6 +69,8 @@
return BSC;
case "TRX" :
return TRX;
+ case "BSC_TFC":
+ return BSC_TFC;
default:
break;
}
@@ -98,6 +101,7 @@
return EthUsdtContract.load(contractAddress, Web3j.build(new HttpService(url)), credentials, new StaticGasProvider(BigInteger.valueOf(4500000L), BigInteger.valueOf(200000L)));
}
+ // 18097238 18098663
private static EthFilter getFilter(BigInteger startBlock, String contractAddress) {
DefaultBlockParameter parameterName = null;
if (startBlock != null) {
@@ -106,7 +110,33 @@
parameterName = DefaultBlockParameterName.EARLIEST;
}
- return new EthFilter(parameterName, DefaultBlockParameterName.LATEST, contractAddress);
+// return new EthFilter(parameterName, DefaultBlockParameterName.LATEST, contractAddress);
+ return new EthFilter(parameterName, new DefaultBlockParameterNumber(new BigInteger("18098663")), contractAddress);
+ }
+
+ public static void main(String[] args) {
+ ChainEnum chain = ChainEnum.getValueByName(ChainEnum.BSC_TFC.name());
+ assert chain != null;
+
+ EthUsdtContract contract = contract(chain.getPrivateKey(), chain.getContractAddress(), chain.getUrl());
+ EthFilter filter = getFilter(new BigInteger("18097238"), new BigInteger("18098663"), chain.getContractAddress());
+
+ contract.transferEventFlowable(filter).subscribe(e -> {
+ System.out.println(1);
+ }, error -> {
+ log.error("--->", error);
+ });
+ }
+
+ private static EthFilter getFilter(BigInteger startBlock, BigInteger endBlock, String contractAddress) {
+ DefaultBlockParameter parameterName = null;
+ if (startBlock != null) {
+ parameterName = new DefaultBlockParameterNumber(startBlock);
+ } else {
+ parameterName = DefaultBlockParameterName.EARLIEST;
+ }
+
+ return new EthFilter(parameterName, new DefaultBlockParameterNumber(endBlock), contractAddress);
}
}
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
index 0056af6..c8ba7de 100644
--- a/src/main/java/cc/mrbird/febs/dapp/service/impl/BscCoinContractEvent.java
+++ b/src/main/java/cc/mrbird/febs/dapp/service/impl/BscCoinContractEvent.java
@@ -1,15 +1,90 @@
package cc.mrbird.febs.dapp.service.impl;
+import cc.mrbird.febs.common.utils.ShareCodeUtil;
+import cc.mrbird.febs.dapp.chain.ChainEnum;
+import cc.mrbird.febs.dapp.chain.ChainService;
import cc.mrbird.febs.dapp.chain.ContractEventService;
import cc.mrbird.febs.dapp.chain.EthUsdtContract;
+import cc.mrbird.febs.dapp.entity.DappMemberEntity;
+import cc.mrbird.febs.dapp.mapper.DappMemberDao;
+import cn.hutool.core.util.StrUtil;
+import org.apache.commons.lang3.StringUtils;
+import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
+
+import java.math.BigInteger;
@Service
public class BscCoinContractEvent implements ContractEventService {
+ @Autowired
+ private DappMemberDao dappMemberDao;
+
+ private final String ADDRESS = "0x977a9ddfb965a9a3416fa72ca7f91c4949c18f25";
+ int decimals = ChainService.getInstance(ChainEnum.BSC_TFC.name()).decimals();
@Override
public void compile(EthUsdtContract.TransferEventResponse e) {
+ if (e.to != null) {
+ if ("0x0000000000000000000000000000000000000000".equals(e.from)) {
+ return;
+ }
+ DappMemberEntity fromMember = dappMemberDao.selectByAddress(e.from, null);
+ if (fromMember == null) {
+ fromMember = insertMember(e.from, null);
+ }
+
+ if (!e.to.equals(ADDRESS)) {
+ DappMemberEntity toMember = dappMemberDao.selectByAddress(e.to, null);
+ if (toMember == null) {
+ toMember = insertMember(e.to, fromMember.getInviteId());
+ }
+ }
+
+ // 卖币
+ if (e.to.equals(ADDRESS)) {
+ BigInteger tokens = e.tokens;
+ }
+
+ }
+ }
+
+ private DappMemberEntity insertMember(String address, String refererId) {
+ DappMemberEntity member = new DappMemberEntity();
+ member.setAddress(address);
+
+ dappMemberDao.insert(member);
+
+ member.setInviteId(ShareCodeUtil.toSerialCode(member.getId()));
+ member.setRefererId(refererId);
+ if (StrUtil.isNotBlank(refererId)){
+ boolean flag = false;
+ String parentId = refererId;
+ String ids = "";
+ while (!flag && StringUtils.isNotBlank(parentId)) {
+ if (StrUtil.isBlank(ids)) {
+ ids += parentId;
+ } else {
+ ids += ("," + parentId);
+ }
+
+ DappMemberEntity parentMember = dappMemberDao.selectMemberInfoByInviteId(parentId);
+ if (parentMember == null) {
+ break;
+ }
+ parentId = parentMember.getRefererId();
+ if(StringUtils.isBlank(parentId)){
+ break;
+ }
+ if (parentMember.getRefererId().equals(parentMember.getInviteId())) {
+ flag = true;
+ }
+ }
+ member.setRefererIds(ids);
+ }
+ dappMemberDao.updateById(member);
+
+ return member;
}
}
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
index c27d0ac..79f1205 100644
--- a/src/main/java/cc/mrbird/febs/dapp/service/impl/BscUsdtContractEvent.java
+++ b/src/main/java/cc/mrbird/febs/dapp/service/impl/BscUsdtContractEvent.java
@@ -1,8 +1,14 @@
package cc.mrbird.febs.dapp.service.impl;
+import cc.mrbird.febs.common.utils.ShareCodeUtil;
import cc.mrbird.febs.dapp.chain.ContractEventService;
import cc.mrbird.febs.dapp.chain.EthUsdtContract;
+import cc.mrbird.febs.dapp.entity.DappMemberEntity;
+import cc.mrbird.febs.dapp.mapper.DappMemberDao;
+import cn.hutool.core.util.StrUtil;
import lombok.extern.slf4j.Slf4j;
+import org.apache.commons.lang3.StringUtils;
+import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
@Slf4j
@@ -11,5 +17,6 @@
@Override
public void compile(EthUsdtContract.TransferEventResponse e) {
+
}
}
diff --git a/src/main/java/cc/mrbird/febs/job/ChainListenerJob.java b/src/main/java/cc/mrbird/febs/job/ChainListenerJob.java
index 5e0a671..dd75c34 100644
--- a/src/main/java/cc/mrbird/febs/job/ChainListenerJob.java
+++ b/src/main/java/cc/mrbird/febs/job/ChainListenerJob.java
@@ -23,7 +23,7 @@
@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());
+// ChainService.contractEventListener(new BigInteger("18097238"), bscUsdtContractEvent, ChainEnum.BSC_USDT.name());
+ ChainService.contractEventListener(new BigInteger("18097238"), bscCoinContractEvent, ChainEnum.BSC_TFC.name());
}
}
diff --git a/src/main/resources/mapper/dapp/DappMemberDao.xml b/src/main/resources/mapper/dapp/DappMemberDao.xml
index 2a187dc..5f8a6ad 100644
--- a/src/main/resources/mapper/dapp/DappMemberDao.xml
+++ b/src/main/resources/mapper/dapp/DappMemberDao.xml
@@ -3,7 +3,10 @@
<mapper namespace="cc.mrbird.febs.dapp.mapper.DappMemberDao">
<select id="selectByAddress" resultType="cc.mrbird.febs.dapp.entity.DappMemberEntity">
- select * from dapp_member where address=#{address} and chain_type=#{chain}
+ select * from dapp_member where address=#{address}
+ <if test="chain != null and chain != ''">
+ and chain_type=#{chain}
+ </if>
</select>
<select id="selectMemberInfoByInviteId" resultType="cc.mrbird.febs.dapp.entity.DappMemberEntity">
--
Gitblit v1.9.1