From ede6503c3e11c4ca71ceb1d23bc4781155e9a043 Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Sat, 09 May 2026 16:15:54 +0800
Subject: [PATCH] fix(gateApi): 修正网格交易服务日志输出和调试信息

---
 src/main/java/com/xcong/excoin/modules/gateApi/wsHandler/handler/PositionsChannelHandler.java |   16 ++++++++++++----
 1 files changed, 12 insertions(+), 4 deletions(-)

diff --git a/src/main/java/com/xcong/excoin/modules/gateApi/wsHandler/handler/PositionsChannelHandler.java b/src/main/java/com/xcong/excoin/modules/gateApi/wsHandler/handler/PositionsChannelHandler.java
index 16c26e3..d55452d 100644
--- a/src/main/java/com/xcong/excoin/modules/gateApi/wsHandler/handler/PositionsChannelHandler.java
+++ b/src/main/java/com/xcong/excoin/modules/gateApi/wsHandler/handler/PositionsChannelHandler.java
@@ -13,15 +13,17 @@
  * 仓位频道处理器。
  *
  * <h3>数据用途</h3>
- * 监控仓位数量(size)。当 size 从有变为 0 时,表示该方向被止盈条件单平仓,
- * 触发补仓(reopenLongPosition / reopenShortPosition)。
+ * 监控仓位数量(size)和入场价(entry_price)。
+ * 有仓位时(size.abs > 0):标记方向活跃,记录入场价 → 基底首次成交记录基底入场价并等待生成网格队列,
+ * 非基底成交立即设止盈条件单。无仓位时(size=0):标记方向不活跃。
  *
  * <h3>推送字段</h3>
- * contract, mode(dual_long / dual_short), size(正=持有,0=无仓位), entry_price
+ * contract, mode(dual_long / dual_short), size(正=多头,负=空头),entry_price
  *
  * <h3>注意</h3>
  * 双向持仓模式下空头 size 为负数,使用 {@code size.abs()} 判断是否有仓位。
  * 累计盈亏不由本频道计算,而是由 {@link PositionClosesChannelHandler} 独立处理。
+ * 止盈条件单由服务端自动触发平仓,本频道不负责开仓操作。
  *
  * @author Administrator
  */
@@ -55,7 +57,13 @@
                 Position.ModeEnum mode = Position.ModeEnum.fromValue(modeStr);
                 BigDecimal size = new BigDecimal(pos.getString("size"));
                 BigDecimal entryPrice = new BigDecimal(pos.getString("entry_price"));
-                log.info("[{}] 持仓更新, 模式:{}, 数量:{}, 入场价:{}", CHANNEL_NAME, modeStr, size, entryPrice);
+                log.info("[{}] 持仓更新, 合约:{}, 模式:{}, 数量:{}, 入场价:{}, 全仓杠杆上限:{}, 历史盈亏:{}, 历史点卡:{}, 最近平仓盈亏:{}, 杠杆:{}, 最大杠杆:{}, 爆仓价:{}, 维持保证金率:{}, 保证金:{}, 已实现盈亏:{}, 点卡已实现盈亏:{}, 风险限额:{}, 时间:{}, 时间ms:{}, 用户:{}, 更新ID:{}",
+                        CHANNEL_NAME, pos.getString("contract"), modeStr, size, entryPrice,
+                        pos.get("cross_leverage_limit"), pos.get("history_pnl"), pos.get("history_point"),
+                        pos.get("last_close_pnl"), pos.get("leverage"), pos.get("leverage_max"),
+                        pos.get("liq_price"), pos.get("maintenance_rate"), pos.get("margin"),
+                        pos.get("realised_pnl"), pos.get("realised_point"), pos.get("risk_limit"),
+                        pos.get("time"), pos.get("time_ms"), pos.get("user"), pos.get("update_id"));
                 if (getGridTradeService() != null) {
                     getGridTradeService().onPositionUpdate(getContract(), mode, size, entryPrice);
                 }

--
Gitblit v1.9.1