From 1d5f689f34d827ac4be67fd84212a5cb7fc80d57 Mon Sep 17 00:00:00 2001
From: KKSU <15274802129@163.com>
Date: Tue, 16 Apr 2024 16:17:14 +0800
Subject: [PATCH] 滑点自动发放

---
 src/main/java/cc/mrbird/febs/job/GiveMeMoneyJob.java |   59 +++++++++++++++++++++++++++++++++++++++++++++++++----------
 1 files changed, 49 insertions(+), 10 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/job/GiveMeMoneyJob.java b/src/main/java/cc/mrbird/febs/job/GiveMeMoneyJob.java
index 7dc855c..01f2fe3 100644
--- a/src/main/java/cc/mrbird/febs/job/GiveMeMoneyJob.java
+++ b/src/main/java/cc/mrbird/febs/job/GiveMeMoneyJob.java
@@ -3,12 +3,18 @@
 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.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 lombok.extern.slf4j.Slf4j;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.scheduling.annotation.Scheduled;
@@ -33,25 +39,58 @@
     private DappSystemService dappSystemService;
     @Autowired
     private RedisUtils redisUtils;
+    @Autowired
+    private DappHdRecordMapper dappHdRecordMapper;
     /**
      * 每日定时零点计算滑点
      */
-    @Scheduled(cron = "0 0 0 * * ?")
+    @Scheduled(cron = "0 0/5 * * * ? ")
     public void mineJob() {
+        /**
+         * 定时器循环计算每个时间跨度内增加的滑点数量
+         */
         log.info("滑点奖励");
-        BigDecimal usdtAmount = new BigDecimal(
-                redisUtils.getString(DataDicEnum.GFA_HUA_DIAN_WALLET_USDT_AMOUNT.getValue())
-        ).setScale(2,BigDecimal.ROUND_DOWN);
-        BigDecimal coinAmount = new BigDecimal(
-                redisUtils.getString(DataDicEnum.GFA_HUA_DIAN_WALLET_COIN_AMOUNT.getValue())
-        ).setScale(2,BigDecimal.ROUND_DOWN);
-        if(BigDecimal.ZERO.compareTo(usdtAmount) > 0){
-            return;
+        //获取滑点钱包的余额
+        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();
         }
-        if(BigDecimal.ZERO.compareTo(coinAmount) > 0){
+
+        //更新此刻的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){
             return;
         }
         dappSystemService.tradeProfitDistribute(1L);
     }
 
+    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"));
+    }
+
 }

--
Gitblit v1.9.1