From fa1b970c8fa7772ce123ab84e8cc4240065bcd26 Mon Sep 17 00:00:00 2001
From: zyy <zyy@email.com>
Date: Fri, 06 Feb 2026 17:43:42 +0800
Subject: [PATCH] 提现

---
 trading-order-huobi/src/main/java/com.yami.trading.huobi/hobi/internal/HobiDataServiceImpl.java |  152 +++++++++++++++++++++++++++++++++++++++-----------
 1 files changed, 117 insertions(+), 35 deletions(-)

diff --git a/trading-order-huobi/src/main/java/com.yami.trading.huobi/hobi/internal/HobiDataServiceImpl.java b/trading-order-huobi/src/main/java/com.yami.trading.huobi/hobi/internal/HobiDataServiceImpl.java
index 51cde5f..61dfeeb 100644
--- a/trading-order-huobi/src/main/java/com.yami.trading.huobi/hobi/internal/HobiDataServiceImpl.java
+++ b/trading-order-huobi/src/main/java/com.yami.trading.huobi/hobi/internal/HobiDataServiceImpl.java
@@ -203,6 +203,7 @@
                         kline.setHigh(realtimeJson.getBigDecimal("high"));
                         kline.setLow(realtimeJson.getBigDecimal("low"));
                         kline.setVolume(realtimeJson.getBigDecimal("vol"));
+                        kline.setAmount(realtimeJson.getBigDecimal("amount"));
                         list.add(kline);
                     }
 
@@ -220,6 +221,83 @@
         return list;
     }
 
+    @Override
+    public List<Kline> kline(String symbol, String period, Integer num) {
+        List<Kline> list = new ArrayList<Kline>();
+        Item item = itemService.findBySymbol(symbol);
+        if (item == null) {
+            return list;
+        }
+        try {
+            Map<String, Object> param = new HashMap<String, Object>();
+            param.put("symbol", symbol);
+            param.put("period", period);
+            if (num == null) {
+                if (Kline.PERIOD_1MIN.equals(period)) {
+                    param.put("size", 1440);
+                }
+                if (Kline.PERIOD_5MIN.equals(period)) {
+                    param.put("size", 576);
+                }
+                if (Kline.PERIOD_15MIN.equals(period)) {
+                    param.put("size", 576);
+                }
+                if (Kline.PERIOD_30MIN.equals(period)) {
+                    param.put("size", 576);
+                }
+                if (Kline.PERIOD_60MIN.equals(period)) {
+                    param.put("size", 576);
+                }
+
+                if (Kline.PERIOD_4HOUR.equals(period)) {
+                    param.put("size", 576);
+                }
+                if (Kline.PERIOD_1DAY.equals(period)) {
+                    param.put("size", 500);
+                }
+                if (Kline.PERIOD_1MON.equals(period)) {
+                    param.put("size", 500);
+                }
+                if (Kline.PERIOD_1WEEK.equals(period)) {
+                    param.put("size", 500);
+                }
+
+            } else {
+                param.put("size", num);
+            }
+
+            String result = HttpHelper.getJSONFromHttp(Config.url + Config.kline, param, HttpMethodType.GET);
+            JSONObject resultJson = JSON.parseObject(result);
+            String status = resultJson.getString("status");
+            if ("ok".equals(status)) {
+                JSONArray dataArray = resultJson.getJSONArray("data");
+                /**
+                 * 丢弃第一行数据
+                 */
+                int start = 1;
+                if (num != null && num == 1) start = 0;
+                for (int i = start; i < dataArray.size(); i++) {
+                    JSONObject realtimeJson = dataArray.getJSONObject(i);
+                    Kline kline = new Kline();
+                    kline.setSymbol(item.getSymbol());
+                    kline.setPeriod(period);
+                    kline.setTs(Long.valueOf(realtimeJson.getString("id") + "000"));
+                    kline.setOpen(realtimeJson.getBigDecimal("open"));
+                    kline.setClose(realtimeJson.getBigDecimal("close"));
+                    kline.setHigh(realtimeJson.getBigDecimal("high"));
+                    kline.setLow(realtimeJson.getBigDecimal("low"));
+                    kline.setVolume(realtimeJson.getBigDecimal("vol"));
+                    kline.setAmount(realtimeJson.getBigDecimal("amount"));
+                    list.add(kline);
+                }
+
+            }
+        } catch (Exception e) {
+            logger.error("error", e);
+        }
+        return list;
+    }
+
     /**
      * 市场深度数据(20档),包装,数据本地化处理
      */
@@ -229,36 +307,38 @@
         if ((depth == null || item.getAdjustmentValue() == null || item.getAdjustmentValue().intValue() == 0) && (item.getMultiple().intValue() == 0 || item.getMultiple().intValue() == 1)) {
             return depth;
         }
+        if(depth != null && CollectionUtil.isNotEmpty(depth.getAsks()) ){
+            List<DepthEntry> asks = depth.getAsks();
+            for (int i = 0; i < asks.size(); i++) {
+                DepthEntry depthEntry = asks.get(i);
 
-        List<DepthEntry> asks = depth.getAsks();
-        for (int i = 0; i < asks.size(); i++) {
-            DepthEntry depthEntry = asks.get(i);
-
-            /**
-             * 调整交易量倍数和 行情值
-             */
-            if (item.getMultiple().doubleValue() > 0) {
-                depthEntry.setAmount(Arith.mul(depthEntry.getAmount(), item.getMultiple().doubleValue()));
-            } else {
-                depthEntry.setAmount(depthEntry.getAmount());
+                /**
+                 * 调整交易量倍数和 行情值
+                 */
+                if (item.getMultiple().doubleValue() > 0) {
+                    depthEntry.setAmount(Arith.mul(depthEntry.getAmount(), item.getMultiple().doubleValue()));
+                } else {
+                    depthEntry.setAmount(depthEntry.getAmount());
+                }
+                depthEntry.setPrice(Arith.add(depthEntry.getPrice(), item.getAdjustmentValue().doubleValue()));
             }
-            depthEntry.setPrice(Arith.add(depthEntry.getPrice(), item.getAdjustmentValue().doubleValue()));
         }
 
-        List<DepthEntry> bids = depth.getBids();
-        for (int i = 0; i < bids.size(); i++) {
-            DepthEntry depthEntry = bids.get(i);
-            /**
-             * 调整交易量倍数和 行情值
-             */
-            if (item.getMultiple().doubleValue() > 0) {
-                depthEntry.setAmount(Arith.mul(depthEntry.getAmount(), item.getMultiple().doubleValue()));
-            } else {
-                depthEntry.setAmount(depthEntry.getAmount());
+        if(depth != null && CollectionUtil.isNotEmpty(depth.getBids())){
+            List<DepthEntry> bids = depth.getBids();
+            for (int i = 0; i < bids.size(); i++) {
+                DepthEntry depthEntry = bids.get(i);
+                /**
+                 * 调整交易量倍数和 行情值
+                 */
+                if (item.getMultiple().doubleValue() > 0) {
+                    depthEntry.setAmount(Arith.mul(depthEntry.getAmount(), item.getMultiple().doubleValue()));
+                } else {
+                    depthEntry.setAmount(depthEntry.getAmount());
+                }
+                depthEntry.setPrice(Arith.add(depthEntry.getPrice(), item.getAdjustmentValue().doubleValue()));
             }
-            depthEntry.setPrice(Arith.add(depthEntry.getPrice(), item.getAdjustmentValue().doubleValue()));
         }
-
         return depth;
     }
 
@@ -372,19 +452,21 @@
         if ((trade == null || item.getAdjustmentValue() == null || item.getAdjustmentValue().doubleValue() == 0) && (item.getMultiple().doubleValue() == 0 || item.getMultiple().doubleValue() == 1)) {
             return trade;
         }
-        List<TradeEntry> data = trade.getData();
-        for (int i = 0; i < data.size(); i++) {
-            TradeEntry tradeEntry = data.get(i);
+        if(trade != null && CollectionUtil.isNotEmpty(trade.getData())){
+            List<TradeEntry> data = trade.getData();
+            for (int i = 0; i < data.size(); i++) {
+                TradeEntry tradeEntry = data.get(i);
 
-            /**
-             * 调整交易量倍数和 行情值
-             */
-            if (item.getMultiple().doubleValue() > 0) {
-                tradeEntry.setAmount(Arith.mul(tradeEntry.getAmount(), item.getMultiple().doubleValue()));
-            } else {
-                tradeEntry.setAmount(tradeEntry.getAmount());
+                /**
+                 * 调整交易量倍数和 行情值
+                 */
+                if (item.getMultiple().doubleValue() > 0) {
+                    tradeEntry.setAmount(Arith.mul(tradeEntry.getAmount(), item.getMultiple().doubleValue()));
+                } else {
+                    tradeEntry.setAmount(tradeEntry.getAmount());
+                }
+                tradeEntry.setPrice(Arith.add(tradeEntry.getPrice(), item.getAdjustmentValue().doubleValue()));
             }
-            tradeEntry.setPrice(Arith.add(tradeEntry.getPrice(), item.getAdjustmentValue().doubleValue()));
         }
         return trade;
 

--
Gitblit v1.9.3