From b50ce4f17ad242f8e27d9fae71ee4c01623a5983 Mon Sep 17 00:00:00 2001 From: xiaoyong931011 <15274802129@163.com> Date: Wed, 29 Mar 2023 10:45:50 +0800 Subject: [PATCH] 后台修改 --- src/test/java/cc/mrbird/febs/ProfitTest.java | 160 ++++++++++++++++++++++++++++++++++++++-------------- 1 files changed, 116 insertions(+), 44 deletions(-) diff --git a/src/test/java/cc/mrbird/febs/ProfitTest.java b/src/test/java/cc/mrbird/febs/ProfitTest.java index 05c3c10..b3b3892 100644 --- a/src/test/java/cc/mrbird/febs/ProfitTest.java +++ b/src/test/java/cc/mrbird/febs/ProfitTest.java @@ -32,8 +32,11 @@ import org.junit.jupiter.api.Test; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.boot.test.context.SpringBootTest; +import org.web3j.crypto.Credentials; +import org.web3j.crypto.WalletUtils; import javax.annotation.Resource; +import java.io.File; import java.math.BigDecimal; import java.math.BigInteger; import java.text.DecimalFormat; @@ -104,8 +107,35 @@ private DataDictionaryCustomMapper dataDictionaryCustomMapper; @Test + public void tetstgetPrikey(){ + Map<String, String> wallet = new HashMap<String, String>(); + try { + String walletPassword = "secr3t"; + // 文件路径 + String walletDirectory = "E:\\address"; + String walletName = "UTC--2023-01-13T08-03-47.600000000Z--aec294ac13f0a64c57a7b9ddb3aee5e791cff06a.json"; + +// String walletName = WalletUtils.generateNewWalletFile(walletPassword, new File(walletDirectory)); +// System.out.println("wallet location: " + walletDirectory + "/" + walletName); + Credentials credentials = WalletUtils.loadCredentials(walletPassword, walletDirectory + "/" + walletName); + String accountAddress = credentials.getAddress(); + String privateKey = credentials.getEcKeyPair().getPrivateKey().toString(16); + // 钱包地址 + wallet.put("address", accountAddress); + // 钱包私钥 + wallet.put("privateKey", privateKey); + System.out.println(accountAddress); + System.out.println(privateKey); + // 产生的钱包文件地址 + wallet.put("walletLocation", walletDirectory + "/" + walletName); + } catch (Exception e) { + e.printStackTrace(); + } + } + + @Test public void directorProfitTest() { - Long directRewardId = 607L; + Long directRewardId = 701L; MallOrderInfo orderInfo = mallOrderInfoMapper.selectById(directRewardId); if(ObjectUtil.isEmpty(orderInfo)){ return; @@ -151,29 +181,32 @@ * 2、返利对象:下单人的直推上级 10%,直推的直推 5% * 3、金额:补贴金额乘以分享奖励的比例 */ + if(StrUtil.isEmpty(mallMember.getReferrerId())){ + return; + } //下单人的直推上级 MallMember mallMemberOne = memberMapper.selectInfoByInviteId(mallMember.getReferrerId()); //生成直推返利的流水记录 if(ObjectUtil.isNotEmpty(mallMemberOne)){ - DataDictionaryCustom rewardPercentDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( - DataDictionaryEnum.REWARD_PERCENT.getType(), - DataDictionaryEnum.REWARD_PERCENT.getCode() - ); - BigDecimal rewardPercent = new BigDecimal(rewardPercentDic.getValue()).multiply(new BigDecimal(0.01)).setScale(2,BigDecimal.ROUND_DOWN); - BigDecimal directRewardAmount = subsidyAmount.multiply(rewardPercent).setScale(4, BigDecimal.ROUND_DOWN); - - Long marketSubsidyFlowId = mallMoneyFlowService.addMoneyFlow( - mallMember.getId(), - orderInfo.getOrderNo(), - directRewardAmount, - MallMoneyFlowTypeEnum.DIRECT_REWARD.getCode(), - MallMoneyFlow.STATUS_SUCCESS, - MallMoneyFlow.IS_RETURN_Y, - mallMemberOne.getId(), - FlowTypeEnum.BALANCE.getValue(), - MallMoneyFlowTypeEnum.DIRECT_REWARD.getName() - ); - memberWalletService.addBalance(directRewardAmount,mallMemberOne.getId()); +// DataDictionaryCustom rewardPercentDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( +// DataDictionaryEnum.REWARD_PERCENT.getType(), +// DataDictionaryEnum.REWARD_PERCENT.getCode() +// ); +// BigDecimal rewardPercent = new BigDecimal(rewardPercentDic.getValue()).multiply(new BigDecimal(0.01)).setScale(2,BigDecimal.ROUND_DOWN); +// BigDecimal directRewardAmount = subsidyAmount.multiply(rewardPercent).setScale(4, BigDecimal.ROUND_DOWN); +// +// Long marketSubsidyFlowId = mallMoneyFlowService.addMoneyFlow( +// mallMember.getId(), +// orderInfo.getOrderNo(), +// directRewardAmount, +// MallMoneyFlowTypeEnum.DIRECT_REWARD.getCode(), +// MallMoneyFlow.STATUS_SUCCESS, +// MallMoneyFlow.IS_RETURN_Y, +// mallMemberOne.getId(), +// FlowTypeEnum.BALANCE.getValue(), +// MallMoneyFlowTypeEnum.DIRECT_REWARD.getName() +// ); +// memberWalletService.addBalance(directRewardAmount,mallMemberOne.getId()); DataDictionaryCustom shareOneDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( DataDictionaryEnum.LEVEL_ONE.getType(), DataDictionaryEnum.LEVEL_ONE.getCode() @@ -193,6 +226,10 @@ MallMoneyFlowTypeEnum.SHARE_REWARD_ONE.getName() ); memberWalletService.addBalance(shareOneAmount,mallMemberOne.getId()); + } + + if(StrUtil.isEmpty(mallMemberOne.getReferrerId())){ + return; } //下单人的直推上级的直推 MallMember mallMemberTwo = memberMapper.selectInfoByInviteId(mallMemberOne.getReferrerId()); @@ -219,6 +256,11 @@ /** * 团队管理补贴 */ + + + if(StrUtil.isEmpty(mallMember.getReferrerIds())){ + return; + } //下单人所有的上级 String referrerIds = mallMember.getReferrerIds(); List<String> refererIdList = StrUtil.split(referrerIds, ",", -1, true, true); @@ -437,27 +479,27 @@ @Test public void scorePool(){ - String next = "0xc1be17a02127e5cc1e6b2298436e8b467531f798"; - MemberCoinAddressEntity memberCoinAddressEntity = memberCoinAddressDao.selectCoinAddressByAddressAndSymbolTag(next, "USDT", "ERC20"); - if(ObjectUtil.isEmpty(memberCoinAddressEntity)){ - return; - } - BigDecimal balanceOf = ChainService.getInstance(ChainEnum.BSC_USDT.name()).balanceOf(next); - if (balanceOf == null || balanceOf.compareTo(new BigDecimal("0.05")) < 1) { - return; - } - //查询手续费 - BigDecimal balanceOfBaseToken = ChainService.getInstance(ChainEnum.BSC_USDT.name()).balanceOfBaseToken(next); - - String gas = "5"; - if(balanceOfBaseToken.compareTo(new BigDecimal(gas)) < 0){ - //转手续费 - ChainService.getInstance(ChainEnum.BSC_USDT.name()).transferBaseToken(next, new BigDecimal(gas)); - } - ChainService.getInstance(ChainEnum.BSC_USDT.name()).transfer(memberCoinAddressEntity.getPrivateKey(), - memberCoinAddressEntity.getAddress(), - AppContants.ERC20_POOL_ADDRESS, - balanceOf.toString()); +// String next = "0xc1be17a02127e5cc1e6b2298436e8b467531f798"; +// MemberCoinAddressEntity memberCoinAddressEntity = memberCoinAddressDao.selectCoinAddressByAddressAndSymbolTag(next, "USDT", "ERC20"); +// if(ObjectUtil.isEmpty(memberCoinAddressEntity)){ +// return; +// } +// BigDecimal balanceOf = ChainService.getInstance(ChainEnum.BSC_USDT.name()).balanceOf(next); +// if (balanceOf == null || balanceOf.compareTo(new BigDecimal("0.05")) < 1) { +// return; +// } +// //查询手续费 +// BigDecimal balanceOfBaseToken = ChainService.getInstance(ChainEnum.BSC_USDT.name()).balanceOfBaseToken(next); +// +// String gas = "5"; +// if(balanceOfBaseToken.compareTo(new BigDecimal(gas)) < 0){ +// //转手续费 +// ChainService.getInstance(ChainEnum.BSC_USDT.name()).transferBaseToken(next, new BigDecimal(gas)); +// } +// ChainService.getInstance(ChainEnum.BSC_USDT.name()).transfer(memberCoinAddressEntity.getPrivateKey(), +// memberCoinAddressEntity.getAddress(), +// AppContants.ERC20_POOL_ADDRESS, +// balanceOf.toString()); // long start = System.currentTimeMillis(); // Object incrementObj = redisUtils.get(AppContants.REDIS_KEY_BLOCK_ETH_INCREMENT_NUM); // BigInteger newest = ChainService.getInstance(ChainEnum.BSC_USDT.name()).blockNumber(); @@ -465,10 +507,40 @@ // if (incrementObj == null) { // block = newest; // } else { -// block = (BigInteger) incrementObj; +// block = newest; // } -//// ChainService.wssBaseCoinEventListener(BigInteger.valueOf(24317595), baseCoinService); -// ChainService.wssContractEventListener(BigInteger.valueOf(24317595), bscUsdtContractEvent, ChainEnum.BSC_USDT.name()); +//// ChainService.wssBaseCoinEventListener(BigInteger.valueOf(26737044), baseCoinService); +// ChainService.wssContractEventListener2(BigInteger.valueOf(26739725), bscUsdtContractEvent, ChainEnum.BSC_USDT.name()); + + + long start = System.currentTimeMillis(); + Object incrementObj = redisUtils.get(AppContants.REDIS_KEY_BLOCK_ETH_INCREMENT_NUM); + BigInteger newest = ChainService.getInstance(ChainEnum.BSC_USDT.name()).blockNumber(); + BigInteger block; + if (incrementObj == null) { + block = newest; + } else { + block = (BigInteger) incrementObj; + } + + +// ChainService.wssBaseCoinEventListener(block, baseCoinService); +// ChainService.wssBaseCoinEventListener(block, bscUsdtContractEvent); +// ChainService.wssContractEventListener(block, bscUsdtContractEvent, ChainEnum.BSC_USDT.name()); +// ChainService.wssContractEventListener2(block, bscUsdtContractEvent, ChainEnum.BSC_USDT.name()); + + BigInteger section = BigInteger.valueOf(5000); + while (newest.subtract(block).compareTo(section) > -1) { + BigInteger end = block.add(section); + ChainService.contractEventListener(block, end, bscUsdtContractEvent, ChainEnum.BSC_USDT.name()); + + block = block.add(section); + if (block.compareTo(newest) > 0) { + block = newest; + } + } + ChainService.contractEventListener(block, bscUsdtContractEvent, ChainEnum.BSC_USDT.name()); + long end = System.currentTimeMillis(); } // // @Test -- Gitblit v1.9.1