From 435c37fdd40fbb65b8c0b0eacb7590942c512be3 Mon Sep 17 00:00:00 2001
From: zyy <zyy@email.com>
Date: Mon, 29 Sep 2025 15:43:59 +0800
Subject: [PATCH] kline

---
 trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/CryptosKlineServiceImpl.java |   39 +++++++++++++++++++++++++++++++++++----
 trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/CryptosKlineService.java     |    2 ++
 2 files changed, 37 insertions(+), 4 deletions(-)

diff --git a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/CryptosKlineService.java b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/CryptosKlineService.java
index 75967a3..50c7df3 100644
--- a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/CryptosKlineService.java
+++ b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/CryptosKlineService.java
@@ -13,6 +13,8 @@
 
     public void saveOne(String symbol, String line);
 
+    public void saveOneByHuoBi(String symbol, String line);
+
     public List<Kline> find(String symbol, String line, int pageSie);
 
     public void delete(String line, int days);
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 bf74cac..3bcb03f 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
@@ -131,7 +131,8 @@
 
     @Override
     public void saveOne(String symbol, String line) {
-        RequestDataHelper.set("symbol", symbol);
+        saveOneByHuoBi(symbol, line);
+        /*RequestDataHelper.set("symbol", symbol);
         Realtime realtime = DataCache.getRealtime(symbol);
         if (realtime == null) {
             logger.error("saveOne error, realtime is null,symbol [" + symbol + "]");
@@ -147,11 +148,11 @@
 
         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, null, line);
         kline.setPeriod(line);
@@ -166,10 +167,40 @@
         timeObject.getKline().add(kline);
         timeObject.setLastTime(new Date());
         DataCache.putKline(symbol, line, timeObject);
-        RequestDataHelper.clear();
+        RequestDataHelper.clear();*/
 
     }
 
+    @Override
+    public void saveOneByHuoBi(String symbol, String line) {
+        RequestDataHelper.set("symbol", symbol);
+        List<Kline> list = hobiDataService.kline(itemService.findBySymbol(symbol).getSymbol(), line, 1,
+                0);
+        if (list == null || list.isEmpty()) {
+            return;
+        }
+        Kline kline = list.get(0);
+        BigDecimal currentValue = AdjustmentValueCache.getCurrentValue().get(symbol);
+        if (currentValue != null && currentValue.compareTo(BigDecimal.ZERO) > 0) {
+            if (!kline.isAdjusted()){
+                kline.setClose(kline.getClose().add(currentValue));
+                kline.setOpen(kline.getOpen().add(currentValue));
+                kline.setLow(kline.getLow().add(currentValue));
+                kline.setHigh(kline.getHigh().add(currentValue));
+                kline.setAdjusted(true);
+            }
+        }
+        klineDBService.save(kline);
+        KlineTimeObject timeObject = DataCache.getKline(symbol, line);
+        if (timeObject == null) {
+            timeObject = new KlineTimeObject();
+        }
+        timeObject.getKline().add(kline);
+        timeObject.setLastTime(new Date());
+        DataCache.putKline(symbol, line, timeObject);
+        RequestDataHelper.clear();
+    }
+
     public Kline bulidKline(Realtime realtime, Kline lastOne, Kline hobiOne, String line) {
         Kline kline = new Kline();
         kline.setSymbol(realtime.getSymbol());

--
Gitblit v1.9.3