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