From 513e5442723f501525bf9ca6210b16561e5d3a2b Mon Sep 17 00:00:00 2001
From: zyy <zyy@email.com>
Date: Tue, 24 Mar 2026 11:41:07 +0800
Subject: [PATCH] 1

---
 trading-order-admin/src/main/java/com/yami/trading/admin/task/IcoTask.java |  154 +++++++++++++++++++++++++++++++++++++--------------
 1 files changed, 111 insertions(+), 43 deletions(-)

diff --git a/trading-order-admin/src/main/java/com/yami/trading/admin/task/IcoTask.java b/trading-order-admin/src/main/java/com/yami/trading/admin/task/IcoTask.java
index 1be2313..ac8360f 100644
--- a/trading-order-admin/src/main/java/com/yami/trading/admin/task/IcoTask.java
+++ b/trading-order-admin/src/main/java/com/yami/trading/admin/task/IcoTask.java
@@ -4,29 +4,54 @@
 import cn.hutool.core.collection.CollectionUtil;
 import cn.hutool.core.date.DateTime;
 import cn.hutool.core.lang.Console;
+import cn.hutool.core.util.ObjectUtil;
 import cn.hutool.core.util.StrUtil;
 import cn.hutool.http.HttpStatus;
 import cn.hutool.json.JSONUtil;
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
+import com.fasterxml.jackson.core.JsonProcessingException;
+import com.fasterxml.jackson.databind.ObjectMapper;
 import com.yami.trading.api.UD.*;
+import com.yami.trading.bean.data.domain.Depth;
+import com.yami.trading.bean.data.domain.Kline;
+import com.yami.trading.bean.data.domain.Realtime;
 import com.yami.trading.bean.ico.domain.Ico;
 import com.yami.trading.bean.item.domain.Item;
 import com.yami.trading.bean.model.ChannelBlockchain;
+import com.yami.trading.bean.model.User;
+import com.yami.trading.bean.model.Withdraw;
+import com.yami.trading.common.config.RequestDataHelper;
 import com.yami.trading.common.domain.Result;
-import com.yami.trading.common.util.ApplicationContextUtils;
-import com.yami.trading.common.util.StringUtils;
+import com.yami.trading.common.util.*;
+import com.yami.trading.huobi.data.DataCache;
+import com.yami.trading.huobi.data.internal.CryptosKlineService;
+import com.yami.trading.huobi.data.internal.DepthTimeObject;
 import com.yami.trading.huobi.data.internal.KlineInitService;
+import com.yami.trading.huobi.data.internal.KlineTimeObject;
+import com.yami.trading.huobi.hobi.HobiDataService;
 import com.yami.trading.security.common.enums.CryptoCurrencyEnum;
+import com.yami.trading.security.common.enums.SysTypeEnum;
+import com.yami.trading.security.common.manager.PasswordCheckManager;
 import com.yami.trading.security.common.util.SecurityUtils;
+import com.yami.trading.service.IdentifyingCodeService;
+import com.yami.trading.service.WithdrawService;
+import com.yami.trading.service.data.KlineDBService;
 import com.yami.trading.service.ico.IcoService;
 import com.yami.trading.service.item.ItemService;
+import com.yami.trading.service.user.UserService;
 import lombok.extern.slf4j.Slf4j;
 
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.data.redis.core.RedisTemplate;
 import org.springframework.scheduling.annotation.Scheduled;
 import org.springframework.stereotype.Component;
+import org.springframework.web.bind.annotation.RequestMapping;
 
+import java.io.IOException;
+import java.math.BigDecimal;
+import java.math.RoundingMode;
+import java.text.DecimalFormat;
 import java.util.*;
 import java.util.stream.Collectors;
 
@@ -53,48 +78,91 @@
     @Autowired
     RedisTemplate redisTemplate;
 
-    //@Scheduled(cron = "*/5 * * * * ?")
-    public void test() {
-        String coin = "usdt";
-        List<ChannelBlockchain> data = new ArrayList<ChannelBlockchain>();
-        Map<String, List<CryptoCurrencyEnum>> allGroupedByCoin = CryptoCurrencyEnum.getAllGroupedByCoin();
-        List<CryptoCurrencyEnum> currencyEnums = allGroupedByCoin.get(coin);
-        try {
-            String partyId = SecurityUtils.getUser().getUserId();
-            //获取u盾地址
-            //获取商户支持币种
-            List<Coin> coinList = udunClient.listSupportCoin(false);
+    @Autowired
+    WithdrawService withdrawService;
 
-            currencyEnums.forEach((currencyEnum) -> {
-                String coinName = currencyEnum.getName();
-                Coin c = coinList.stream().filter(x -> x.getName().equals(coinName)).findFirst().orElse(null);
-                if (c != null) {
-                    ChannelBlockchain rechargeAddressVo = new ChannelBlockchain();
-                    //创建地址
-                    Address address;
-                    String ress = (String)redisTemplate.opsForValue().get(partyId + coinName);
-                    if(StringUtils.isNotEmpty(ress)){
-                        rechargeAddressVo.setAddress(ress);
-                        rechargeAddressVo.setCoin(coinName);
-                        rechargeAddressVo.setBlockchain_name(coinName);
-                        rechargeAddressVo.setAuto(false);
-                        rechargeAddressVo.setImg(null);
-                    }else{
-                        address = udunClient.createAddress(c.getMainCoinType(),null,null);
-                        rechargeAddressVo.setAddress(address.getAddress());
-                        rechargeAddressVo.setCoin(coinName);
-                        rechargeAddressVo.setBlockchain_name(coinName);
-                        rechargeAddressVo.setAuto(false);
-                        rechargeAddressVo.setImg(null);
-                        redisTemplate.opsForValue().set(partyId + coinName, address.getAddress());
-                    }
-                    data.add(rechargeAddressVo);
-                }
-            });
-        }catch (Exception e){
-            e.printStackTrace();
-            log.error("获取充值地址错误:",e);
+    @Autowired
+    IdentifyingCodeService identifyingCodeService;
+    @Autowired
+    UserService userService;
+    @Autowired
+    PasswordCheckManager passwordCheckManager;
+    @Autowired
+    HobiDataService hobiDataService;
+    @Autowired
+    KlineDBService klineDBService;
+
+    @Autowired
+    DepthPushJob depthPushJob;
+
+    //@Scheduled(cron = "*/5 * * * * ?")
+    public void test() throws Exception {
+        /*String symbol ="snekusdt";
+        RequestDataHelper.set("symbol", symbol);
+        LambdaQueryWrapper<Kline> queryWrapper = new LambdaQueryWrapper<Kline>()
+                .eq(Kline::getSymbol, symbol)
+                .eq(Kline::getPeriod, "5min")
+                .ge(Kline::getTs, ts1)
+                .lt(Kline::getTs, ts2)
+                .orderByAsc(Kline::getTs);
+        List<Kline> list = klineDBService.list(queryWrapper);
+        BigDecimal tz = num.divide(BigDecimal.valueOf(list.size()), 6, RoundingMode.HALF_UP);
+        System.out.println(list.size());
+        System.out.println(tz);
+        for(int i=0;i<list.size();i++){
+            BigDecimal nums = BigDecimal.valueOf(i+1);
+            *//*BigDecimal integerPart = nums.divide(BigDecimal.valueOf(100), 0, RoundingMode.FLOOR).add(BigDecimal.valueOf(1));
+
+            System.out.printf("nums=%d, 除以100的整数部分=%d%n", nums.intValue(), integerPart.intValue());*//*
+            BigDecimal addNum = nums.multiply(tz);
+            list.get(i).setClose(list.get(i).getClose().add(addNum));
+            list.get(i).setOpen(list.get(i).getOpen().add(addNum));
+            list.get(i).setHigh(list.get(i).getHigh().add(addNum));
+            list.get(i).setLow(list.get(i).getLow().add(addNum));
         }
+        klineDBService.saveOrUpdateBatch(list);*/
+
+        /*RequestDataHelper.clear();
+        // 定义时间范围:2025-09-16 00:00:00 到 2025-09-19 16:15:00
+        LocalDateTime startTime = LocalDateTime.of(2025, 9, 16, 0, 0, 0);
+        LocalDateTime endTime = LocalDateTime.of(2025, 9, 19, 16, 15, 0);
+
+        // 转换为东八区(UTC+8)的毫秒级时间戳
+        ZoneOffset zoneOffset = ZoneOffset.of("+8");
+        long startTs = startTime.toInstant(zoneOffset).toEpochMilli();
+        long endTs = endTime.toInstant(zoneOffset).toEpochMilli();
+
+        // 存储所有时间戳
+        List<Long> timestamps = new ArrayList<>();
+        DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");
+
+        List<Kline> list = new ArrayList<>();
+        // 每5分钟 = 300000毫秒,遍历生成时间戳
+        for (long currentTs = startTs; currentTs <= endTs; currentTs += 300000) {
+            timestamps.add(currentTs);
+
+            // 打印时间和对应的时间戳(可选)
+            LocalDateTime currentTime = LocalDateTime.ofInstant(
+                    java.time.Instant.ofEpochMilli(currentTs),
+                    zoneOffset
+            );
+            System.out.printf("时间: %s  |  时间戳: %d%n",
+                    currentTime.format(formatter), currentTs);
+            Kline kline = new Kline();
+            kline.setTs(currentTs);
+            kline.setSymbol(symbol);
+            kline.setPeriod("5min");
+            list.add(kline);
+        }
+        System.out.println(list.size());
+        RequestDataHelper.set("symbol", symbol);
+        klineDBService.saveOrUpdateBatch(list);
+        RequestDataHelper.clear();*/
+        /*String symbol = "snekusdt";
+        DepthTimeObject depth = DataCache.getDepth().get(symbol);
+        Depth depthData = depth.getDepth();
+        Realtime realtime = DataCache.getRealtime(symbol);
+        depthPushJob.depthRevise(depthData, symbol, realtime.getClose().doubleValue(), true);*/
     }
     /**
      * ico转入产品
@@ -132,7 +200,7 @@
     /**
      * K线数据修正
      */
-    @Scheduled(cron = "0 */1 * * * ?")
+    //@Scheduled(cron = "0 */5 * * * ?")
     public void klineInit() {
         List<Item> items = ApplicationContextUtils.getApplicationContext().getBean(ItemService.class).list();
         if (CollectionUtil.isNotEmpty(items)) {

--
Gitblit v1.9.3