Administrator
3 days ago bc75ca90df5b470aa71a8e05226ddccf0df43c1f
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
package com.xcong.excoin.modules.gateApi.wsHandler;
 
import com.alibaba.fastjson.JSONObject;
import org.java_websocket.client.WebSocketClient;
 
/**
 * WebSocket 频道处理器接口。
 *
 * <p>每个 Gate 频道对应一个实现类。新增频道只需实现此接口,
 * 然后通过 {@code GateKlineWebSocketClient.addChannelHandler()} 注册即可。
 *
 * <h3>实现类</h3>
 * <ul>
 *   <li>{@code CandlestickChannelHandler} — 公开频道,K 线数据</li>
 *   <li>{@code AbstractPrivateChannelHandler} — 私有频道抽象基类(签名+认证)</li>
 *   <li>{@code PositionsChannelHandler} — 私有频道,仓位更新</li>
 *   <li>{@code PositionClosesChannelHandler} — 私有频道,平仓推送</li>
 * </ul>
 *
 * <h3>路由机制</h3>
 * {@code handleMessage()} 返回 {@code true} 表示消息已被该 handler 处理,
 * 路由循环会停止遍历。返回 {@code false} 表示不匹配(channel 名不相等)。
 *
 * @author Administrator
 */
public interface GateChannelHandler {
 
    /** 频道名称,如 {@code "futures.candlesticks"} */
    String getChannelName();
 
    /** 发送订阅请求 */
    void subscribe(WebSocketClient ws);
 
    /** 发送取消订阅请求 */
    void unsubscribe(WebSocketClient ws);
 
    /**
     * 处理频道推送消息。
     *
     * @param response WebSocket 推送的完整 JSON
     * @return true 表示已处理(循环停止),false 表示频道不匹配(继续遍历下一个 handler)
     */
    boolean handleMessage(JSONObject response);
}