From 6a51f45e6a00b65a9e7b0b0707b453c11311f3ef Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Mon, 11 May 2026 22:38:13 +0800
Subject: [PATCH] feat(okxApi): 添加仓位模式配置和REST客户端功能

---
 src/main/java/com/xcong/excoin/modules/okxApi/wsHandler/OkxChannelHandler.java |   44 ++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 44 insertions(+), 0 deletions(-)

diff --git a/src/main/java/com/xcong/excoin/modules/okxApi/wsHandler/OkxChannelHandler.java b/src/main/java/com/xcong/excoin/modules/okxApi/wsHandler/OkxChannelHandler.java
new file mode 100644
index 0000000..16425f3
--- /dev/null
+++ b/src/main/java/com/xcong/excoin/modules/okxApi/wsHandler/OkxChannelHandler.java
@@ -0,0 +1,44 @@
+package com.xcong.excoin.modules.okxApi.wsHandler;
+
+import com.alibaba.fastjson.JSONObject;
+import org.java_websocket.client.WebSocketClient;
+
+/**
+ * OKX WebSocket 频道处理器接口。
+ *
+ * <p>每个 OKX 频道对应一个实现类。新增频道只需实现此接口,
+ * 然后通过 {@code OkxKlineWebSocketClient.addChannelHandler()} 注册即可。
+ *
+ * <h3>实现类</h3>
+ * <ul>
+ *   <li>{@code OkxCandlestickChannelHandler} — K 线数据</li>
+ *   <li>{@code OkxPositionsChannelHandler} — 持仓更新</li>
+ *   <li>{@code OkxAccountChannelHandler} — 账户信息</li>
+ *   <li>{@code OkxOrderInfoChannelHandler} — 订单信息(止盈止损、PnL跟踪)</li>
+ * </ul>
+ *
+ * <h3>路由机制</h3>
+ * {@code handleMessage()} 返回 {@code true} 表示消息已被该 handler 处理,
+ * 路由循环会停止遍历。返回 {@code false} 表示不匹配(channel 名不相等)。
+ *
+ * @author Administrator
+ */
+public interface OkxChannelHandler {
+
+    /** 频道名称,如 {@code "candle1m"} */
+    String getChannelName();
+
+    /** 发送订阅请求 */
+    void subscribe(WebSocketClient ws);
+
+    /** 发送取消订阅请求 */
+    void unsubscribe(WebSocketClient ws);
+
+    /**
+     * 处理频道推送消息。
+     *
+     * @param response WebSocket 推送的完整 JSON
+     * @return true 表示已处理(循环停止),false 表示频道不匹配(继续遍历下一个 handler)
+     */
+    boolean handleMessage(JSONObject response);
+}

--
Gitblit v1.9.1