From 0b4c87807860c0bfff0759a5cdc736c80e5f5772 Mon Sep 17 00:00:00 2001
From: zyy <zyy@email.com>
Date: Thu, 25 Sep 2025 15:50:48 +0800
Subject: [PATCH] 1

---
 trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/CryptosKlineServiceImpl.java |   53 +++++++++++++++++++++++++++++++++++++++++++++++------
 1 files changed, 47 insertions(+), 6 deletions(-)

diff --git a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/CryptosKlineServiceImpl.java b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/CryptosKlineServiceImpl.java
index fb05daa..8a28e75 100644
--- a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/CryptosKlineServiceImpl.java
+++ b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/CryptosKlineServiceImpl.java
@@ -7,6 +7,7 @@
 import com.yami.trading.common.config.RequestDataHelper;
 import com.yami.trading.common.constants.Constants;
 import com.yami.trading.common.util.DateUtils;
+import com.yami.trading.huobi.data.AdjustmentValueCache;
 import com.yami.trading.huobi.data.DataCache;
 import com.yami.trading.huobi.hobi.HobiDataService;
 import com.yami.trading.service.data.KlineDBService;
@@ -18,6 +19,7 @@
 import org.springframework.jdbc.core.namedparam.NamedParameterJdbcOperations;
 import org.springframework.stereotype.Component;
 
+import java.math.BigDecimal;
 import java.util.*;
 
 @Component
@@ -34,6 +36,19 @@
     private SysparaService sysparaService;
     @Autowired
     private NamedParameterJdbcOperations namedParameterJdbcTemplate;
+
+    @Override
+    public void init(String symbol) {
+        this.bulid(symbol, Kline.PERIOD_1MIN);
+        this.bulid(symbol, Kline.PERIOD_5MIN);
+        this.bulid(symbol, Kline.PERIOD_15MIN);
+        this.bulid(symbol, Kline.PERIOD_30MIN);
+        this.bulid(symbol, Kline.PERIOD_60MIN);
+        this.bulid(symbol, Kline.PERIOD_4HOUR);
+        this.bulid(symbol, Kline.PERIOD_1DAY);
+        this.bulid(symbol, Kline.PERIOD_1MON);
+        this.bulid(symbol, Kline.PERIOD_1WEEK);
+    }
 
     @Override
     public void saveInit(String symbol) {
@@ -55,6 +70,19 @@
 
     }
 
+    public void bulid(String symbol, String line) {
+        RequestDataHelper.set("symbol", symbol);
+        List<Kline> list = hobiDataService.kline(itemService.findBySymbol(symbol).getSymbol(), line, null,
+                0);
+        KlineTimeObject model = new KlineTimeObject();
+        Collections.sort(list); // 按时间升序
+        model.setKline(list);
+        model.setLastTime(new Date());
+        DataCache.putKline(symbol, line, model);
+        RequestDataHelper.clear();
+
+    }
+
     public void bulidInit(String symbol, String line) {
         RequestDataHelper.set("symbol", symbol);
         List<Kline> list = hobiDataService.kline(itemService.findBySymbol(symbol).getSymbol(), line, null,
@@ -68,6 +96,8 @@
         RequestDataHelper.clear();
 
     }
+
+
 
     @Override
     public void saveOne(String symbol, String line) {
@@ -87,12 +117,13 @@
 
         String key = symbol + "_" + line;
         Kline hobiOne = DataCache.getKline_hobi().get(key);
-        if (hobiOne == null || lastOne == null) {
+        /*if (hobiOne == null || lastOne == null) {
+            logger.error("saveOne error, hobiOne is null,symbol [" + symbol + "]");
             // 取不到远程数据,直接退出
             return;
-        }
+        }*/
         RequestDataHelper.set("symbol", symbol);
-        Kline kline = this.bulidKline(realtime, lastOne, hobiOne, line);
+        Kline kline = this.bulidKline(realtime, lastOne, null, line);
         kline.setPeriod(line);
         klineDBService.save(kline);
 
@@ -124,8 +155,17 @@
 
         if (lastOne != null) {
             kline.setOpen(lastOne.getClose());
+            kline.setHigh(lastOne.getHigh());
+            kline.setLow(lastOne.getLow());
+
+            if (realtime.getClose().compareTo(kline.getHigh()) > 0) {
+                kline.setHigh(realtime.getClose());
+            }
+            if (realtime.getClose().compareTo(kline.getOpen()) < 0) {
+                kline.setLow(realtime.getClose());
+            }
         }
-        int interval = this.sysparaService.find("data_interval").getInteger().intValue() / 1000;
+        /*int interval = this.sysparaService.find("data_interval").getInteger().intValue() / 1000;
 
         HighLow highLow = null;
         switch (line) {
@@ -169,9 +209,10 @@
         }
         if (highLow != null && highLow.getLow() != null) {
             kline.setLow(highLow.getLow());
-        }
+        }*/
 
-        kline.setVolume(hobiOne.getVolume());
+
+        //kline.setVolume(hobiOne.getVolume());
 
         return kline;
     }

--
Gitblit v1.9.3