From 69adba5ed84906ed740dcda038fea34c819f27e2 Mon Sep 17 00:00:00 2001
From: zyy <zyy@email.com>
Date: Thu, 11 Sep 2025 18:30:32 +0800
Subject: [PATCH] k线初始化

---
 trading-order-admin/src/main/java/com/yami/trading/admin/task/IcoTask.java |   52 ++++++++++++++++++++++++++++++++++++++++------------
 1 files changed, 40 insertions(+), 12 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 6c295ab..8820c3e 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
@@ -1,13 +1,15 @@
 package com.yami.trading.admin.task;
 
 
+import cn.hutool.core.collection.CollectionUtil;
 import cn.hutool.core.date.DateTime;
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.yami.trading.bean.ico.domain.Ico;
 import com.yami.trading.bean.item.domain.Item;
+import com.yami.trading.common.util.ApplicationContextUtils;
+import com.yami.trading.huobi.data.internal.KlineInitService;
 import com.yami.trading.service.ico.IcoService;
 import com.yami.trading.service.item.ItemService;
-import lombok.Data;
 import lombok.extern.slf4j.Slf4j;
 
 import org.springframework.beans.factory.annotation.Autowired;
@@ -16,6 +18,7 @@
 
 import java.util.ArrayList;
 import java.util.List;
+import java.util.Optional;
 import java.util.stream.Collectors;
 
 
@@ -29,29 +32,54 @@
     @Autowired
     ItemService itemService;
 
+    @Autowired
+    InitHandle initHandle;
+
+    @Autowired
+    private KlineInitService klineInitService;
+
     /**
      * ico转入产品
      */
-    @Scheduled(cron = "0 */5 * * * ?")
+    @Scheduled(cron = "0 */1 * * * ?")
     public void icoToItem() {
         QueryWrapper<Ico> query  = new QueryWrapper<>();
         query.lt("market_date", DateTime.now());
         List<Ico> icoList = icoService.list(query);
-        if (icoList != null && !icoList.isEmpty()) {
-            List<String> symbolList = icoList.stream().map(Ico::getSymbol).collect(Collectors.toList());
-
+        if (icoList == null || icoList.isEmpty()) {
+            return;
+        }
+        List<Item> addItemList = new ArrayList<>();
+        for (Ico ico : icoList) {
+            //是否已存在币
             QueryWrapper<Item> iQuery  = new QueryWrapper<>();
-            iQuery.in("SYMBOL", symbolList);
-            iQuery.eq("currency_type", 1);
-
-            List<Item> itemList = itemService.list(iQuery);
-            List<Item> addItemList = new ArrayList<>();
-            for (Ico ico : icoList) {
-                Item item = itemList.stream().filter(x -> x.getSymbol().equals(ico.getSymbol())).findFirst().orElse(new Item());
+            iQuery.eq("SYMBOL", ico.getSymbol());
+            iQuery.eq("SYMBOL_DATA", ico.getSymbolData());
+            Item item = itemService.getOne(iQuery);
+            if (item == null) {
+                item = new Item();
                 item =icoService.icoToItem(item, ico);
                 addItemList.add(item);
             }
+        }
+        if (!addItemList.isEmpty()) {
+            log.info("ico转入产品 数据 Start>>");
             itemService.saveOrUpdateBatch(addItemList);
+            initHandle.init();
+            log.info("成功ico转入产品 数据 End {}", icoList.size());
+        }
+    }
+
+
+    /**
+     * K线数据修正
+     */
+    @Scheduled(cron = "0 */1 * * * ?")
+    public void klineInit() {
+        List<Item> items = ApplicationContextUtils.getApplicationContext().getBean(ItemService.class).list();
+        if (CollectionUtil.isNotEmpty(items)) {
+            String symbols = items.stream().map(Item::getSymbol).collect(Collectors.joining(","));
+            klineInitService.klineInit(symbols);
         }
     }
 }

--
Gitblit v1.9.3