From c268540881fe493bc40e76ba82793a63c0897c91 Mon Sep 17 00:00:00 2001
From: KKSU <15274802129@163.com>
Date: Thu, 16 May 2024 10:41:12 +0800
Subject: [PATCH] 滑点监控

---
 src/main/java/cc/mrbird/febs/job/GiveMeMoneyJob.java |  141 +++++++++++++++++++++++++++-------------------
 1 files changed, 83 insertions(+), 58 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/job/GiveMeMoneyJob.java b/src/main/java/cc/mrbird/febs/job/GiveMeMoneyJob.java
index 01f2fe3..b44317d 100644
--- a/src/main/java/cc/mrbird/febs/job/GiveMeMoneyJob.java
+++ b/src/main/java/cc/mrbird/febs/job/GiveMeMoneyJob.java
@@ -1,30 +1,21 @@
 package cc.mrbird.febs.job;
 
-import cc.mrbird.febs.common.contants.AppContants;
-import cc.mrbird.febs.common.enumerates.DataDicEnum;
 import cc.mrbird.febs.common.utils.RedisUtils;
-import cc.mrbird.febs.dapp.chain.ChainEnum;
-import cc.mrbird.febs.dapp.chain.ChainService;
-import cc.mrbird.febs.dapp.entity.DappAddressList;
-import cc.mrbird.febs.dapp.entity.DappHdRecord;
-import cc.mrbird.febs.dapp.mapper.DappAdressListDao;
+import cc.mrbird.febs.dapp.entity.DappAchieve;
+import cc.mrbird.febs.dapp.mapper.DappAchieveMapper;
 import cc.mrbird.febs.dapp.mapper.DappHdRecordMapper;
-import cc.mrbird.febs.dapp.mapper.DappMemberDao;
 import cc.mrbird.febs.dapp.service.DappSystemService;
-import cc.mrbird.febs.rabbit.producer.ChainProducer;
 import cn.hutool.core.collection.CollUtil;
-import cn.hutool.core.util.ObjectUtil;
-import cn.hutool.core.util.StrUtil;
+import cn.hutool.core.date.DateTime;
+import cn.hutool.core.date.DateUtil;
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
 import org.springframework.scheduling.annotation.Scheduled;
 import org.springframework.stereotype.Component;
-import org.tron.trident.core.ApiWrapper;
-import org.tron.trident.core.contract.Contract;
-import org.tron.trident.core.contract.Trc20Contract;
 
-import java.math.BigDecimal;
-import java.math.BigInteger;
+import java.util.Date;
 import java.util.List;
 
 /**
@@ -33,6 +24,7 @@
  **/
 @Slf4j
 @Component
+@ConditionalOnProperty(prefix = "system", name = "chain-listener", havingValue = "true")
 public class GiveMeMoneyJob {
 
     @Autowired
@@ -41,56 +33,89 @@
     private RedisUtils redisUtils;
     @Autowired
     private DappHdRecordMapper dappHdRecordMapper;
+    @Autowired
+    private DappAchieveMapper dappAchieveMapper;
     /**
-     * 每日定时零点计算滑点
+     * 计算业绩是否失效
      */
-    @Scheduled(cron = "0 0/5 * * * ? ")
-    public void mineJob() {
-        /**
-         * 定时器循环计算每个时间跨度内增加的滑点数量
-         */
-        log.info("滑点奖励");
-        //获取滑点钱包的余额
-        BigDecimal coinCnt = ChainService.getInstance(ChainEnum.BSC_GFA.name()).balanceOf("0x1Ea392645f816BF15f1Fc87728eA010585bAAE7D").setScale(8,BigDecimal.ROUND_DOWN);
-        BigDecimal coinPrice = ChainService.getInstance(ChainEnum.BSC_GFA.name()).getPrice("0x1Ea392645f816BF15f1Fc87728eA010585bAAE7D").setScale(8,BigDecimal.ROUND_DOWN);
-        //获取上一时刻的数据
-        BigDecimal coinAmountOld =BigDecimal.ZERO;
-        DappHdRecord dappHdRecord = dappHdRecordMapper.selectNewRecord();
-        if(ObjectUtil.isNotEmpty(dappHdRecord)){
-            coinAmountOld = dappHdRecord.getCoinAmount();
-        }
 
-        //更新此刻的USDT数量
-        String existToken = redisUtils.getString(DataDicEnum.GFA_HUA_DIAN_WALLET_USDT_AMOUNT.getValue());
-        if (StrUtil.isNotBlank(existToken)) {
-            redisUtils.del(existToken);
-        }
-        //这个时间段的新增余额
-        //此刻的余额-上一次账户的余额 = 这个时间段的新增余额
-        BigDecimal subtract = coinCnt.subtract(coinAmountOld);
-        //获取这个时刻的滑点入账数量
-        BigDecimal multiply = coinPrice.multiply(subtract).multiply(new BigDecimal("0.97")).setScale(8,BigDecimal.ROUND_DOWN);
-        //更新这个时间段的滑点数量
-        redisUtils.set(DataDicEnum.GFA_HUA_DIAN_WALLET_USDT_AMOUNT.getValue(), multiply, 0);
-
-        //生成一条记录
-        DappHdRecord dappHdRecordAdd = new DappHdRecord();
-        dappHdRecordAdd.setPrice(coinPrice);
-        dappHdRecordAdd.setUsdtEvery(multiply);
-        dappHdRecordAdd.setCoinEvery(subtract);
-        dappHdRecordAdd.setCoinAmount(coinCnt);
-        dappHdRecordMapper.insert(dappHdRecordAdd);
-
-        if(BigDecimal.ZERO.compareTo(subtract) >= 0){
+    @Scheduled(cron = "0 0 1 * * ? ")
+    public void achieveJob() {
+        QueryWrapper<DappAchieve> objectQueryWrapper = new QueryWrapper<>();
+        objectQueryWrapper.eq("state",DappAchieve.STATUS_ING);
+        List<DappAchieve> dappAchieves = dappAchieveMapper.selectList(objectQueryWrapper);
+        if(CollUtil.isEmpty(dappAchieves)){
             return;
         }
-        dappSystemService.tradeProfitDistribute(1L);
+        for(DappAchieve achieve : dappAchieves){
+            Date createTime = achieve.getCreateTime();
+            DateTime dateTime = DateUtil.offsetDay(createTime, 75);//失效时间
+            if(DateUtil.compare(new Date(),dateTime) > 0){
+                achieve.setState(DappAchieve.STATUS_DONE);
+                dappAchieveMapper.updateById(achieve);
+            }
+        }
     }
 
     public static void main(String[] args) {
-//        System.out.println(ChainService.getInstance(ChainEnum.BSC_GFA.name()).totalSupply());
-//        System.out.println(ChainService.getInstance(ChainEnum.BSC_GFA.name()).balanceOf("0x1Ea392645f816BF15f1Fc87728eA010585bAAE7D"));
-        System.out.println(ChainService.getInstance(ChainEnum.BSC_GFA.name()).getPrice("0x1Ea392645f816BF15f1Fc87728eA010585bAAE7D"));
+        DateTime dateTime = DateUtil.offsetDay(new Date(), 75);
+        System.out.println(dateTime);
+        System.out.println(DateUtil.compare(new Date(),dateTime));
+        System.out.println(DateUtil.compare(new Date(),dateTime) > 0);
+
     }
+    /**
+     * 每日定时零点计算滑点
+     */
+//    @Scheduled(cron = "0 0/5 * * * ? ")
+//    public void mineJob() {
+//        /**
+//         * 定时器循环计算每个时间跨度内增加的滑点数量
+//         */
+//        log.info("滑点奖励");
+//        //获取滑点钱包的余额
+//        BigDecimal coinCnt = ChainService.getInstance(ChainEnum.BSC_GFA.name()).balanceOf("0x1Ea392645f816BF15f1Fc87728eA010585bAAE7D").setScale(8,BigDecimal.ROUND_DOWN);
+//        BigDecimal coinPrice = ChainService.getInstance(ChainEnum.BSC_GFA.name()).getPrice("0x1Ea392645f816BF15f1Fc87728eA010585bAAE7D").setScale(8,BigDecimal.ROUND_DOWN);
+//
+//        if(new BigDecimal("10").compareTo(coinCnt) >= 0){
+//            return;
+//        }
+//
+////        BigDecimal coinCnt = ChainService.getInstance(ChainEnum.BSC_GFA.name()).balanceOf("0xF6b06A30196aA5E318232a3b61319eab0FD4A3bF").setScale(8,BigDecimal.ROUND_DOWN);
+////        BigDecimal coinPrice = ChainService.getInstance(ChainEnum.BSC_GFA.name()).getPrice("0xF6b06A30196aA5E318232a3b61319eab0FD4A3bF").setScale(8,BigDecimal.ROUND_DOWN);
+//
+//        //获取上一时刻的数据
+//        BigDecimal coinAmountOld =BigDecimal.ZERO;
+//        DappHdRecord dappHdRecord = dappHdRecordMapper.selectNewRecord();
+//        if(ObjectUtil.isNotEmpty(dappHdRecord)){
+//            coinAmountOld = dappHdRecord.getCoinAmount();
+//        }
+//
+//        //更新此刻的USDT数量
+//        String existToken = redisUtils.getString(DataDicEnum.GFA_HUA_DIAN_WALLET_USDT_AMOUNT.getValue());
+//        if (StrUtil.isNotBlank(existToken)) {
+//            redisUtils.del(existToken);
+//        }
+//        //这个时间段的新增余额
+//        //此刻的余额-上一次账户的余额 = 这个时间段的新增余额
+//        BigDecimal subtract = coinCnt.subtract(coinCnt).setScale(0,BigDecimal.ROUND_DOWN);
+//
+//        if(BigDecimal.ZERO.compareTo(subtract) >= 0){
+//            return;
+//        }
+//        //获取这个时刻的滑点入账数量
+//        BigDecimal multiply = coinPrice.multiply(subtract).multiply(new BigDecimal("0.97")).setScale(8,BigDecimal.ROUND_DOWN);
+//        //更新这个时间段的滑点数量
+//        redisUtils.set(DataDicEnum.GFA_HUA_DIAN_WALLET_USDT_AMOUNT.getValue(), multiply, 0);
+//
+//        //生成一条记录
+//        DappHdRecord dappHdRecordAdd = new DappHdRecord();
+//        dappHdRecordAdd.setPrice(coinPrice);
+//        dappHdRecordAdd.setUsdtEvery(multiply);
+//        dappHdRecordAdd.setCoinEvery(subtract);
+//        dappHdRecordAdd.setCoinAmount(coinCnt);
+//        dappHdRecordMapper.insert(dappHdRecordAdd);
+//        dappSystemService.tradeProfitDistribute(1L);
+//    }
 
 }

--
Gitblit v1.9.1