From bfe3af2d95418b326d707834be6c6ba91f86ecb5 Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Fri, 08 May 2026 13:20:58 +0800
Subject: [PATCH] refactor(gateApi): 重构 Gate API 模块代码结构

---
 src/main/java/com/xcong/excoin/modules/gateApi/wsHandler/handler/CandlestickChannelHandler.java |   87 ++++++++++++++++++++-----------------------
 1 files changed, 41 insertions(+), 46 deletions(-)

diff --git a/src/main/java/com/xcong/excoin/modules/gateApi/wsHandler/handler/CandlestickChannelHandler.java b/src/main/java/com/xcong/excoin/modules/gateApi/wsHandler/handler/CandlestickChannelHandler.java
index c445e49..cf44e10 100644
--- a/src/main/java/com/xcong/excoin/modules/gateApi/wsHandler/handler/CandlestickChannelHandler.java
+++ b/src/main/java/com/xcong/excoin/modules/gateApi/wsHandler/handler/CandlestickChannelHandler.java
@@ -11,8 +11,21 @@
 import java.math.BigDecimal;
 
 /**
- * K 线频道处理器。
- * 公开频道,无需认证。订阅 1m K 线,解析后回调 {@link GateGridTradeService#onKline}。
+ * K 线(Candlestick)频道处理器。
+ *
+ * <h3>特点</h3>
+ * 公开频道,无需 HMAC-SHA512 认证签名。订阅 1m 周期的 K 线数据。
+ *
+ * <h3>数据流</h3>
+ * <pre>
+ *   WebSocket 推送 update event
+ *     → handleMessage() → 解析 OHLCV → log 打印 → gridTradeService.onKline(closePx)
+ *       → 首次 K 线触发双开
+ *       → 后续 K 线仅缓存 lastKlinePrice 供补仓参考
+ * </pre>
+ *
+ * <h3>订阅格式</h3>
+ * payload: {@code ["1m", contract]}
  *
  * @author Administrator
  */
@@ -31,73 +44,55 @@
     }
 
     @Override
-    public String getChannelName() {
-        return CHANNEL_NAME;
-    }
+    public String getChannelName() { return CHANNEL_NAME; }
 
     @Override
     public void subscribe(WebSocketClient ws) {
-        JSONObject subscribeMsg = new JSONObject();
-        subscribeMsg.put("time", System.currentTimeMillis() / 1000);
-        subscribeMsg.put("channel", CHANNEL_NAME);
-        subscribeMsg.put("event", "subscribe");
+        JSONObject msg = new JSONObject();
+        msg.put("time", System.currentTimeMillis() / 1000);
+        msg.put("channel", CHANNEL_NAME);
+        msg.put("event", "subscribe");
         JSONArray payload = new JSONArray();
         payload.add(INTERVAL);
         payload.add(contract);
-        subscribeMsg.put("payload", payload);
-        ws.send(subscribeMsg.toJSONString());
-        log.info("[{}] 已发送订阅请求,合约: {}, 周期: {}", CHANNEL_NAME, contract, INTERVAL);
+        msg.put("payload", payload);
+        ws.send(msg.toJSONString());
+        log.info("[{}] subscribed, contract:{}, interval:{}", CHANNEL_NAME, contract, INTERVAL);
     }
 
     @Override
     public void unsubscribe(WebSocketClient ws) {
-        JSONObject unsubscribeMsg = new JSONObject();
-        unsubscribeMsg.put("time", System.currentTimeMillis() / 1000);
-        unsubscribeMsg.put("channel", CHANNEL_NAME);
-        unsubscribeMsg.put("event", "unsubscribe");
+        JSONObject msg = new JSONObject();
+        msg.put("time", System.currentTimeMillis() / 1000);
+        msg.put("channel", CHANNEL_NAME);
+        msg.put("event", "unsubscribe");
         JSONArray payload = new JSONArray();
         payload.add(INTERVAL);
         payload.add(contract);
-        unsubscribeMsg.put("payload", payload);
-        ws.send(unsubscribeMsg.toJSONString());
-        log.info("[{}] 已发送取消订阅请求,合约: {}, 周期: {}", CHANNEL_NAME, contract, INTERVAL);
+        msg.put("payload", payload);
+        ws.send(msg.toJSONString());
+        log.info("[{}] unsubscribed", CHANNEL_NAME);
     }
 
     @Override
     public boolean handleMessage(JSONObject response) {
-        String channel = response.getString("channel");
-        if (!CHANNEL_NAME.equals(channel)) {
-            return false;
-        }
+        if (!CHANNEL_NAME.equals(response.getString("channel"))) return false;
         try {
             JSONArray resultArray = response.getJSONArray("result");
-            if (resultArray == null || resultArray.isEmpty()) {
-                log.warn("[{}] 数据为空", CHANNEL_NAME);
-                return true;
-            }
+            if (resultArray == null || resultArray.isEmpty()) { log.warn("[{}] empty", CHANNEL_NAME); return true; }
             JSONObject data = resultArray.getJSONObject(0);
             BigDecimal closePx = new BigDecimal(data.getString("c"));
-            long t = data.getLong("t");
-            boolean windowClosed = data.getBooleanValue("w");
 
-            log.info("========== Gate K线数据 ==========");
-            log.info("名称(n): {}", data.getString("n"));
-            log.info("时间  : {}", DateUtil.TimeStampToDateTime(t));
-            log.info("开盘(o): {}", data.getString("o"));
-            log.info("最高(h): {}", data.getString("h"));
-            log.info("最低(l): {}", data.getString("l"));
-            log.info("收盘(c): {}", data.getString("c"));
-            log.info("成交量(v): {}", data.getString("v"));
-            log.info("成交额(a): {}", data.getString("a"));
-            log.info("K线完结(w): {}", windowClosed);
-            log.info("==================================");
+            log.info("========== Gate K线 ==========");
+            log.info("n:{} t:{} o:{} h:{} l:{} c:{} v:{} a:{} w:{}",
+                    data.getString("n"), DateUtil.TimeStampToDateTime(data.getLong("t")),
+                    data.getString("o"), data.getString("h"), data.getString("l"),
+                    data.getString("c"), data.getString("v"), data.getString("a"),
+                    data.getBooleanValue("w"));
+            log.info("==============================");
 
-            if (gridTradeService != null) {
-                gridTradeService.onKline(closePx);
-            }
-        } catch (Exception e) {
-            log.error("[{}] 处理数据失败", CHANNEL_NAME, e);
-        }
+            if (gridTradeService != null) gridTradeService.onKline(closePx);
+        } catch (Exception e) { log.error("[{}] handle fail", CHANNEL_NAME, e); }
         return true;
     }
 }

--
Gitblit v1.9.1