From 61a2275faa5bdbee04eb8a4322d57b59b16651ad Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Thu, 18 Dec 2025 18:08:56 +0800
Subject: [PATCH] refactor(okxWs): 简化账户就绪状态检查逻辑

---
 src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/AccountWs.java |   18 +++++++++++++++---
 1 files changed, 15 insertions(+), 3 deletions(-)

diff --git a/src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/AccountWs.java b/src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/AccountWs.java
index bca358b..3d5fe77 100644
--- a/src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/AccountWs.java
+++ b/src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/AccountWs.java
@@ -96,6 +96,9 @@
                     for (int j = 0; j < detailsArray.size(); j++) {
                         JSONObject detail = detailsArray.getJSONObject(j);
                         initParam(detail, accountName);
+
+                        Map<String, String> accountMap = getAccountMap(accountName);
+                        WsMapBuild.saveStringToMap(accountMap, CoinEnums.READY_STATE.name(), CoinEnums.READY_STATE_YES.getCode());
                     }
                 } catch (Exception innerEx) {
                     log.warn("处理账户频道数据失败", innerEx);
@@ -112,6 +115,7 @@
     public static final String cashBalKey = "cashBal";
     public static final String eqKey = "eq";
     public static final String uplKey = "upl";
+    public static final String imrKey = "imr";
     private static void initParam(JSONObject detail, String accountName) {
         Map<String, String> accountMap = getAccountMap(accountName);
 
@@ -130,6 +134,8 @@
         String upl = WsMapBuild.parseStringSafe(detail.getString(uplKey));
         WsMapBuild.saveStringToMap(accountMap, uplKey, upl);
 
+        String imr = WsMapBuild.parseStringSafe(detail.getString(imrKey));
+        WsMapBuild.saveStringToMap(accountMap, imrKey, imr);
         BigDecimal cashBalDecimal = WsMapBuild.parseBigDecimalSafe(cashBal);
         // 根据可用余额计算下单总保证金
         String total_order_usdtpecent = InstrumentsWs.getAccountMap(accountName).get(CoinEnums.TOTAL_ORDER_USDTPECENT.name());
@@ -137,11 +143,17 @@
         BigDecimal totalOrderUsdt = cashBalDecimal.multiply(total_order_usdt_factor).setScale(2, RoundingMode.DOWN);
         WsMapBuild.saveStringToMap(accountMap, CoinEnums.TOTAL_ORDER_USDT.name(), String.valueOf(totalOrderUsdt));
 
-        WsMapBuild.saveStringToMap(accountMap, CoinEnums.READY_STATE.name(), CoinEnums.READY_STATE_YES.getCode());
+        /**
+         * 当前账户未满仓,并且账户余额不为0,才更新为已就绪
+         */
+        BigDecimal imrDecimal = WsMapBuild.parseBigDecimalSafe(imr);
+        if (BigDecimal.ZERO.compareTo(cashBalDecimal) < 0 && imrDecimal.compareTo(totalOrderUsdt) < 0){
+            WsMapBuild.saveStringToMap(accountMap, CoinEnums.READY_STATE.name(), CoinEnums.READY_STATE_YES.getCode());
+        }
 
         log.info(
-                "{}: 账户详情-币种: {}, 可用余额: {}, 现金余额: {}, 余额: {}, 全仓未实现盈亏: {}, 下单总保证金: {}",
-                accountName, ccy, availBal, cashBal, eq, upl, totalOrderUsdt
+                "{}: 账户详情-币种: {}, 可用余额: {}, 现金余额: {}, 余额: {}, 全仓未实现盈亏: {}, 下单总保证金: {},已使用保证金:{}",
+                accountName, ccy, availBal, cashBal, eq, upl, totalOrderUsdt,imr
         );
     }
 }

--
Gitblit v1.9.1