From f2c1b2853b2f0d0a0efb95a9c8df95ec1da908ad Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Wed, 07 Jan 2026 11:13:36 +0800
Subject: [PATCH] fix(trading): 修复交易系统中的计算错误和日志级别问题

---
 src/main/java/com/xcong/excoin/modules/okxNewPrice/OkxWebSocketClientManager.java              |    2 
 src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/enums/CoinEnums.java                  |    4 
 src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/wanggeList/WangGeListEnum.java        |   15 ++-
 src/main/java/com/xcong/excoin/modules/okxNewPrice/OkxQuantWebSocketClient.java                |   25 ++++-
 src/main/java/com/xcong/excoin/modules/okxNewPrice/celue/CaoZuoServiceImpl.java                |   35 +++---
 src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/PositionsWs.java                      |   51 +++++++++
 src/main/java/com/xcong/excoin/modules/okxNewPrice/celue/CaoZuoService.java                    |    2 
 src/main/resources/logback-spring.xml                                                          |    2 
 src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/TradeOrderWs.java                     |   80 ++++++++++++++++
 src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/AccountWs.java                        |    1 
 src/main/java/com/xcong/excoin/modules/okxNewPrice/OkxNewPriceWebSocketClient.java             |   17 ---
 src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/enums/ExchangeInfoEnum.java           |   14 +-
 src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/wanggeList/WangGeListServiceImpl.java |    4 
 13 files changed, 188 insertions(+), 64 deletions(-)

diff --git a/src/main/java/com/xcong/excoin/modules/okxNewPrice/OkxNewPriceWebSocketClient.java b/src/main/java/com/xcong/excoin/modules/okxNewPrice/OkxNewPriceWebSocketClient.java
index 99e2ffc..ef8b749 100644
--- a/src/main/java/com/xcong/excoin/modules/okxNewPrice/OkxNewPriceWebSocketClient.java
+++ b/src/main/java/com/xcong/excoin/modules/okxNewPrice/OkxNewPriceWebSocketClient.java
@@ -312,23 +312,6 @@
             for (OkxQuantWebSocketClient client : clientManager.getAllClients()) {
                 String accountName = client.getAccountName();
                 if (accountName != null) {
-                    /**
-                     * 处理历史网格的订单
-                     * 根据历史网格的开单方向,是否需要止损处理
-                     *      如果方向一致就不需要处理
-                     *      如果不一致则需要处理
-                     */
-                    String fangXiang = gridByPriceNew.getFang_xiang();
-                    String fangXiangOld = CoinEnums.POSSIDE_LONG.getCode().equals(fangXiang) ? CoinEnums.POSSIDE_SHORT.getCode() : CoinEnums.POSSIDE_LONG.getCode();
-                    if (!fangXiang.equals(fangXiangOld)){
-                        log.info("历史网格方向为:{}", fangXiangOld);
-                        TradeRequestParam tradeRequestParamOld = caoZuoService.caoZuoZhiSunEvent(accountName, markPx, fangXiangOld);
-                        TradeOrderWs.orderEvent(client.getWebSocketClient(), tradeRequestParamOld);
-                    }
-
-                    /**
-                     * 处理当前网格的订单,触发量化操作
-                     */
                     log.info("当前价格{}属于网格: {}-{}({}-{})", markPx, gridByPriceNew.getName(),gridByPriceNew.getFang_xiang(), gridByPriceNew.getJiage_xiaxian(), gridByPriceNew.getJiage_shangxian());
                     wangGeListService.initWangGe(markPx);
                     TradeRequestParam tradeRequestParam = caoZuoService.caoZuoHandler(accountName, markPx, gridByPriceNew.getFang_xiang());
diff --git a/src/main/java/com/xcong/excoin/modules/okxNewPrice/OkxQuantWebSocketClient.java b/src/main/java/com/xcong/excoin/modules/okxNewPrice/OkxQuantWebSocketClient.java
index 3324b87..3a37a34 100644
--- a/src/main/java/com/xcong/excoin/modules/okxNewPrice/OkxQuantWebSocketClient.java
+++ b/src/main/java/com/xcong/excoin/modules/okxNewPrice/OkxQuantWebSocketClient.java
@@ -1,11 +1,13 @@
 package com.xcong.excoin.modules.okxNewPrice;
 
+import cn.hutool.core.collection.CollUtil;
 import com.alibaba.fastjson.JSON;
 import com.alibaba.fastjson.JSONObject;
 import com.xcong.excoin.modules.okxNewPrice.celue.CaoZuoService;
 import com.xcong.excoin.modules.okxNewPrice.okxWs.*;
 import com.xcong.excoin.modules.okxNewPrice.okxWs.enums.ExchangeInfoEnum;
 import com.xcong.excoin.modules.okxNewPrice.okxWs.param.TradeRequestParam;
+import com.xcong.excoin.modules.okxNewPrice.okxWs.wanggeList.WangGeListService;
 import com.xcong.excoin.modules.okxNewPrice.utils.SSLConfig;
 import com.xcong.excoin.modules.okxNewPrice.wangge.WangGeService;
 import com.xcong.excoin.utils.RedisUtils;
@@ -20,6 +22,7 @@
 import javax.annotation.PreDestroy;
 import java.net.URI;
 import java.net.URISyntaxException;
+import java.util.List;
 import java.util.concurrent.*;
 import java.util.concurrent.atomic.AtomicBoolean;
 import java.util.concurrent.atomic.AtomicReference;
@@ -34,6 +37,9 @@
 public class OkxQuantWebSocketClient {
     private final RedisUtils redisUtils;
     private final ExchangeInfoEnum account;
+
+    private final CaoZuoService caoZuoService;
+    private final WangGeListService wangGeListService;
 
     private WebSocketClient webSocketClient;
     private ScheduledExecutorService heartbeatExecutor;
@@ -60,10 +66,16 @@
         return account.name();
     }
     
-    public OkxQuantWebSocketClient(ExchangeInfoEnum account,
-                                   RedisUtils redisUtils) {
+    public OkxQuantWebSocketClient(
+            ExchangeInfoEnum account,
+            RedisUtils redisUtils,
+            CaoZuoService caoZuoService,
+            WangGeListService wangGeListService
+    ) {
         this.account = account;
         this.redisUtils = redisUtils;
+        this.caoZuoService = caoZuoService;
+        this.wangGeListService = wangGeListService;
     }
 
     private static final String WS_URL_MONIPAN = "wss://wspap.okx.com:8443/ws/v5/private";
@@ -382,15 +394,18 @@
         // 注意:当前实现中,OrderInfoWs等类使用静态Map存储数据
         // 这会导致多账号之间的数据冲突。需要进一步修改这些类的设计,让数据存储与特定账号关联
         if (OrderInfoWs.ORDERINFOWS_CHANNEL.equals(channel)) {
+
             TradeRequestParam tradeRequestParam = OrderInfoWs.handleEvent(response, redisUtils, account.name());
             TradeOrderWs.orderZhiYingEvent(webSocketClient, tradeRequestParam);
         }else if (AccountWs.ACCOUNTWS_CHANNEL.equals(channel)) {
+
             AccountWs.handleEvent(response, account.name());
-//            String side = caoZuoService.caoZuo(account.name());
-//            TradeOrderWs.orderEvent(webSocketClient, side, account.name());
         } else if (PositionsWs.POSITIONSWS_CHANNEL.equals(channel)) {
-            PositionsWs.handleEvent(response, account.name());
+
+            List<TradeRequestParam> tradeRequestParams = PositionsWs.handleEvent(response, account.name());
+            TradeOrderWs.orderZhiSunEvent(webSocketClient, tradeRequestParams);
         } else if (BalanceAndPositionWs.CHANNEL_NAME.equals(channel)) {
+
             BalanceAndPositionWs.handleEvent(response);
         }
     }
diff --git a/src/main/java/com/xcong/excoin/modules/okxNewPrice/OkxWebSocketClientManager.java b/src/main/java/com/xcong/excoin/modules/okxNewPrice/OkxWebSocketClientManager.java
index be64554..21b96ab 100644
--- a/src/main/java/com/xcong/excoin/modules/okxNewPrice/OkxWebSocketClientManager.java
+++ b/src/main/java/com/xcong/excoin/modules/okxNewPrice/OkxWebSocketClientManager.java
@@ -59,7 +59,7 @@
         // 为每个账号创建一个WebSocket客户端实例
         for (ExchangeInfoEnum account : accounts) {
             try {
-                OkxQuantWebSocketClient client = new OkxQuantWebSocketClient(account, redisUtils);
+                OkxQuantWebSocketClient client = new OkxQuantWebSocketClient(account, redisUtils, caoZuoService, wangGeListService);
                 quantClientMap.put(account.name(), client);
                 client.init();
                 log.info("已初始化账号 {} 的WebSocket客户端", account.name());
diff --git a/src/main/java/com/xcong/excoin/modules/okxNewPrice/celue/CaoZuoService.java b/src/main/java/com/xcong/excoin/modules/okxNewPrice/celue/CaoZuoService.java
index e53aa38..de5e342 100644
--- a/src/main/java/com/xcong/excoin/modules/okxNewPrice/celue/CaoZuoService.java
+++ b/src/main/java/com/xcong/excoin/modules/okxNewPrice/celue/CaoZuoService.java
@@ -2,6 +2,8 @@
 
 import com.xcong.excoin.modules.okxNewPrice.okxWs.param.TradeRequestParam;
 
+import java.util.List;
+
 /**
  * @author Administrator
  */
diff --git a/src/main/java/com/xcong/excoin/modules/okxNewPrice/celue/CaoZuoServiceImpl.java b/src/main/java/com/xcong/excoin/modules/okxNewPrice/celue/CaoZuoServiceImpl.java
index 04808fb..1adb9fd 100644
--- a/src/main/java/com/xcong/excoin/modules/okxNewPrice/celue/CaoZuoServiceImpl.java
+++ b/src/main/java/com/xcong/excoin/modules/okxNewPrice/celue/CaoZuoServiceImpl.java
@@ -1,5 +1,6 @@
 package com.xcong.excoin.modules.okxNewPrice.celue;
 
+import cn.hutool.core.collection.CollUtil;
 import cn.hutool.core.util.ObjectUtil;
 import cn.hutool.core.util.StrUtil;
 import com.xcong.excoin.modules.okxNewPrice.okxWs.*;
@@ -20,6 +21,7 @@
 
 import java.math.BigDecimal;
 import java.math.RoundingMode;
+import java.util.List;
 import java.util.Map;
 import java.util.concurrent.PriorityBlockingQueue;
 
@@ -53,7 +55,6 @@
         tradeRequestParam.setPosSide(posSide);
         tradeRequestParam.setOrdType(CoinEnums.ORDTYPE_MARKET.getCode());
 
-        log.info("操作账户:{},当前价格: {},仓位方向: {}", accountName,markPx,posSide);
         /**
          * 准备工作
          * 1、准备好下单的基本信息
@@ -70,26 +71,23 @@
          * 判断止损抗压
          */
         BigDecimal realKuiSunAmount = WsMapBuild.parseBigDecimalSafe(AccountWs.getAccountMap(accountName).get("upl"));
-        log.info("实际盈亏金额: {}", realKuiSunAmount);
-        String zhiSunPercent = InstrumentsWs.getAccountMap(accountName).get(CoinEnums.ZHI_SUN.name());
-        BigDecimal zhiSunAmount = cashBal.multiply(new BigDecimal(zhiSunPercent));
-        log.info("预期亏损金额: {}", zhiSunAmount);
-        String kangYaPercent = InstrumentsWs.getAccountMap(accountName).get(CoinEnums.KANG_CANG.name());
-        BigDecimal  kangYaAmount = cashBal.multiply(new BigDecimal(kangYaPercent));
-        log.info("预期抗仓金额: {}", kangYaAmount);
-
         if (realKuiSunAmount.compareTo(BigDecimal.ZERO) < 0){
+            String kangYaPercent = InstrumentsWs.getAccountMap(accountName).get(CoinEnums.KANG_CANG.name());
+            BigDecimal  kangYaAmount = cashBal.multiply(new BigDecimal(kangYaPercent));
+            String zhiSunPercent = InstrumentsWs.getAccountMap(accountName).get(CoinEnums.ZHI_SUN.name());
+            BigDecimal zhiSunAmount = cashBal.multiply(new BigDecimal(zhiSunPercent));
+            log.info("实际盈亏金额: {},预期抗仓金额: {},预期亏损金额: {}", realKuiSunAmount, kangYaAmount, zhiSunAmount);
             realKuiSunAmount = realKuiSunAmount.multiply(new BigDecimal("-1"));
             // 账户预期亏损金额比这个还小时,立即止损
             if (realKuiSunAmount.compareTo(zhiSunAmount) > 0){
-                log.error("账户冷静止损......");
+                log.warn("账户冷静止损......");
                 WsMapBuild.saveStringToMap(InstrumentsWs.getAccountMap(accountName), CoinEnums.OUT.name(),  OrderParamEnums.OUT_YES.getValue());
                 tradeRequestParam.setTradeType(OrderParamEnums.TRADE_YES.getValue());
                 return caoZuoZhiSunEvent(accountName, markPx, posSide);
             }
             // 判断抗压
             if (realKuiSunAmount.compareTo(kangYaAmount) > 0 && realKuiSunAmount.compareTo(zhiSunAmount) <= 0){
-                log.error("账户紧张扛仓......");
+                log.warn("账户紧张扛仓......");
                 tradeRequestParam.setTradeType(OrderParamEnums.TRADE_NO.getValue());
                 return chooseEvent(tradeRequestParam);
             }
@@ -98,27 +96,26 @@
         String positionAccountName = PositionsWs.initAccountName(accountName, posSide);
         // 判断是否保证金超标
         if (PositionsWs.getAccountMap(positionAccountName).get("imr") == null){
-            log.error("没有获取到持仓信息,等待初始化......");
+            log.warn("没有获取到持仓信息,等待初始化......");
             tradeRequestParam.setTradeType(OrderParamEnums.TRADE_NO.getValue());
             return chooseEvent(tradeRequestParam);
         }
         BigDecimal ordFrozImr = PositionsWs.getAccountMap(positionAccountName).get("imr");
-        BigDecimal totalOrderUsdt = WsMapBuild.parseBigDecimalSafe(AccountWs.getAccountMap(accountName).get(CoinEnums.TOTAL_ORDER_USDT.name()))
-                .divide(new BigDecimal("2"), RoundingMode.DOWN);
+        BigDecimal totalOrderUsdt = WsMapBuild.parseBigDecimalSafe(AccountWs.getAccountMap(accountName).get(CoinEnums.TOTAL_ORDER_USDT.name()));
         if (ordFrozImr.compareTo(totalOrderUsdt) >= 0){
-            log.error("已满仓......");
+            log.warn("已满仓......");
             tradeRequestParam.setTradeType(OrderParamEnums.TRADE_NO.getValue());
             return chooseEvent(tradeRequestParam);
         }
 
         if (PositionsWs.getAccountMap(positionAccountName).get("pos") == null){
-            log.error("没有获取到持仓信息,等待初始化......");
+            log.warn("没有获取到持仓信息,等待初始化......");
             tradeRequestParam.setTradeType(OrderParamEnums.TRADE_NO.getValue());
             return chooseEvent(tradeRequestParam);
         }
         BigDecimal pos = PositionsWs.getAccountMap(positionAccountName).get("pos");
         if (BigDecimal.ZERO.compareTo( pos) >= 0) {
-            log.error("持仓数量为零,进行初始化订单");
+            log.warn("持仓数量为零,进行初始化订单");
             return caoZuoInitEvent(accountName, markPx, posSide);
         }
 
@@ -129,7 +126,6 @@
     @Override
     public TradeRequestParam caoZuoZhiSunEvent(String accountName, String markPx, String posSide) {
 
-        log.info("历史网格:操作账户:{},当前价格: {},仓位方向: {}", accountName,markPx,posSide);
         /**
          * 初始化订单请求参数
          *      获取仓位数量
@@ -162,6 +158,7 @@
             tradeRequestParam.setTradeType(OrderParamEnums.TRADE_NO.getValue());
         }
         tradeRequestParam.setSz(String.valueOf( pos));
+        log.info("止损订单:{},方向:{}-{},数量:{}",clOrdId,posSide, side, pos);
         return tradeRequestParam;
 
     }
@@ -221,7 +218,7 @@
 
     @Override
     public TradeRequestParam caoZuoLong(TradeRequestParam tradeRequestParam) {
-        log.info("开始做{}执行操作CaoZuoServiceImpl......",tradeRequestParam.getPosSide());
+        log.info("开始做{}......",tradeRequestParam.getPosSide());
 
         String accountName = tradeRequestParam.getAccountName();
         String markPxStr = tradeRequestParam.getMarkPx();
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 3d5fe77..1ccae82 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
@@ -141,6 +141,7 @@
         String total_order_usdtpecent = InstrumentsWs.getAccountMap(accountName).get(CoinEnums.TOTAL_ORDER_USDTPECENT.name());
         BigDecimal total_order_usdt_factor = WsMapBuild.parseBigDecimalSafe(total_order_usdtpecent);
         BigDecimal totalOrderUsdt = cashBalDecimal.multiply(total_order_usdt_factor).setScale(2, RoundingMode.DOWN);
+        totalOrderUsdt = totalOrderUsdt.divide(new BigDecimal("2"), RoundingMode.DOWN);
         WsMapBuild.saveStringToMap(accountMap, CoinEnums.TOTAL_ORDER_USDT.name(), String.valueOf(totalOrderUsdt));
 
         /**
diff --git a/src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/PositionsWs.java b/src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/PositionsWs.java
index f1a8d12..afcf78e 100644
--- a/src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/PositionsWs.java
+++ b/src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/PositionsWs.java
@@ -4,6 +4,9 @@
 import com.alibaba.fastjson.JSONObject;
 import com.xcong.excoin.modules.okxNewPrice.okxWs.enums.CoinEnums;
 import com.xcong.excoin.modules.okxNewPrice.okxWs.enums.OrderParamEnums;
+import com.xcong.excoin.modules.okxNewPrice.okxWs.param.TradeRequestParam;
+import com.xcong.excoin.modules.okxNewPrice.okxWs.wanggeList.WangGeListEnum;
+import com.xcong.excoin.modules.okxNewPrice.okxWs.wanggeList.WangGeListService;
 import com.xcong.excoin.modules.okxNewPrice.okxpi.MallUtils;
 import com.xcong.excoin.modules.okxNewPrice.utils.WsMapBuild;
 import com.xcong.excoin.modules.okxNewPrice.utils.WsParamBuild;
@@ -12,6 +15,8 @@
 
 import java.math.BigDecimal;
 import java.math.RoundingMode;
+import java.util.ArrayList;
+import java.util.List;
 import java.util.Map;
 import java.util.concurrent.ConcurrentHashMap;
 
@@ -60,7 +65,7 @@
         initParam(arg, accountName,CoinEnums.POSSIDE_SHORT.getCode());
     }
 
-    public static void handleEvent(JSONObject response, String accountName) {
+    public static List<TradeRequestParam> handleEvent(JSONObject response, String accountName) {
 
 
         log.info("开始执行PositionsWs......");
@@ -68,8 +73,10 @@
             JSONArray dataArray = response.getJSONArray("data");
             if (dataArray == null || dataArray.isEmpty()) {
                 log.info("账户持仓频道数据为空,等待更新");
-                return;
+                return null;
             }
+
+            List<TradeRequestParam> tradeRequestParamList = new ArrayList<>();
 
             for (int i = 0; i < dataArray.size(); i++) {
                 JSONObject posData = dataArray.getJSONObject(i);
@@ -109,15 +116,50 @@
                             last, idxPx, bePx, realizedPnl, settledPnl,
                             markPx,fee,fundingFee
                     );
-                    initParam(posData, accountName,posSide);
+                    //先更新缓存
+                    Map<String, BigDecimal> stringBigDecimalMap = initParam(posData, accountName, posSide);
+                    //构建止损参数
+                    if (stringBigDecimalMap.get("pos").compareTo(BigDecimal.ZERO) > 0){
+                        TradeRequestParam tradeRequestParam = new TradeRequestParam();
+                        // 1. 判断当前价格属于哪个网格
+                        WangGeListEnum gridByPriceNew = WangGeListEnum.getGridByPrice(new BigDecimal(avgPx));
+                        if (gridByPriceNew != null) {
+                            String zhiSunDian = gridByPriceNew.getZhi_sun_dian();
+                            String fangXiang = gridByPriceNew.getFang_xiang();
+                            BigDecimal fangXiangNow = stringBigDecimalMap.get("posSide");
+                            if (fangXiangNow.equals(fangXiang)){
+                                tradeRequestParam.setOrdType(CoinEnums.ORDTYPE_LIMIT.getCode());
+                                tradeRequestParam.setMarkPx(String.valueOf(zhiSunDian));
+                            }else{
+                                tradeRequestParam.setOrdType(CoinEnums.ORDTYPE_MARKET.getCode());
+                                tradeRequestParam.setMarkPx(String.valueOf(markPx));
+                            }
+                        }else{
+                            tradeRequestParam.setOrdType(CoinEnums.ORDTYPE_MARKET.getCode());
+                            tradeRequestParam.setMarkPx(String.valueOf(markPx));
+                        }
+
+
+                        tradeRequestParam.setAccountName(accountName);
+                        tradeRequestParam.setInstId(CoinEnums.HE_YUE.getCode());
+                        tradeRequestParam.setTdMode(CoinEnums.CROSS.getCode());
+                        tradeRequestParam.setPosSide(posSide);
+                        tradeRequestParam.setTradeType(OrderParamEnums.TRADE_YES.getValue());
+                        tradeRequestParam.setSide(CoinEnums.POSSIDE_LONG.getCode().equals(posSide) ? CoinEnums.SIDE_SELL.getCode() : CoinEnums.SIDE_BUY.getCode());
+                        tradeRequestParam.setClOrdId(WsParamBuild.getOrderNum(tradeRequestParam.getSide()));
+                        tradeRequestParam.setSz(String.valueOf(stringBigDecimalMap.get("pos")));
+                        tradeRequestParamList.add(tradeRequestParam);
+                    }
                 }
             }
+            return tradeRequestParamList;
         } catch (Exception e) {
             log.error("处理持仓频道推送数据失败", e);
         }
+        return null;
     }
 
-    private static void initParam(JSONObject posData, String accountName,String posSide) {
+    private static Map<String, BigDecimal> initParam(JSONObject posData, String accountName,String posSide) {
         String accountNamePositons = initAccountName(accountName, posSide);
         Map<String, BigDecimal> accountMap = getAccountMap(accountNamePositons);
         WsMapBuild.saveBigDecimalToMap(accountMap, "avgPx", WsMapBuild.parseBigDecimalSafe(posData.getString("avgPx")));
@@ -137,5 +179,6 @@
         if (ordFrozImr.compareTo(totalOrderUsdt) <= 0){
             WsMapBuild.saveBigDecimalToMap(accountMap, CoinEnums.READY_STATE.name(), WsMapBuild.parseBigDecimalSafe(CoinEnums.READY_STATE_YES.getCode()));
         }
+        return accountMap;
     }
 }
diff --git a/src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/TradeOrderWs.java b/src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/TradeOrderWs.java
index 6c1961b..5586822 100644
--- a/src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/TradeOrderWs.java
+++ b/src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/TradeOrderWs.java
@@ -1,6 +1,8 @@
 package com.xcong.excoin.modules.okxNewPrice.okxWs;
 
+import cn.hutool.core.collection.CollUtil;
 import cn.hutool.core.util.StrUtil;
+import cn.hutool.json.JSONUtil;
 import com.alibaba.fastjson.JSONArray;
 import com.alibaba.fastjson.JSONObject;
 import com.xcong.excoin.modules.okxNewPrice.okxWs.enums.CoinEnums;
@@ -12,6 +14,7 @@
 import org.java_websocket.client.WebSocketClient;
 
 import java.math.BigDecimal;
+import java.util.List;
 import java.util.Map;
 import java.util.concurrent.ConcurrentHashMap;
 
@@ -207,6 +210,83 @@
         }
     }
 
+    public static void orderZhiSunEvent(WebSocketClient webSocketClient, List<TradeRequestParam> tradeRequestParams) {
+
+        log.info("开始止损......");
+        if (CollUtil.isEmpty(tradeRequestParams)){
+            log.error("止损下单{}参数缺失,取消发送", JSONUtil.parse(tradeRequestParams));
+            return;
+        }
+        for (TradeRequestParam tradeRequestParam : tradeRequestParams){
+            String accountName = tradeRequestParam.getAccountName();
+            String markPx = tradeRequestParam.getMarkPx();
+            String instId = tradeRequestParam.getInstId();
+            String tdMode = tradeRequestParam.getTdMode();
+            String posSide = tradeRequestParam.getPosSide();
+            String ordType = tradeRequestParam.getOrdType();
+
+            String tradeType = tradeRequestParam.getTradeType();
+
+            String clOrdId = tradeRequestParam.getClOrdId();
+            String side = tradeRequestParam.getSide();
+            String sz = tradeRequestParam.getSz();
+            /**
+             * 校验必要参数
+             * 验证下单参数是否存在空值
+             */
+            if (
+                    StrUtil.isBlank(accountName)
+                            || StrUtil.isBlank(instId)
+                            || StrUtil.isBlank(tdMode)
+                            || StrUtil.isBlank(posSide)
+                            || StrUtil.isBlank(ordType)
+                            || StrUtil.isBlank(clOrdId)
+                            || StrUtil.isBlank(side)
+                            || StrUtil.isBlank(sz)
+                            || StrUtil.isBlank(markPx)
+
+            ){
+                log.error("止损下单参数缺失,取消发送");
+                return;
+            }
+            log.info("止损账户:{},触发价格:{},币种:{},方向:{},买卖:{},数量:{},是否允许下单:{},编号:{},",
+                    accountName, markPx, instId, posSide,side,  sz, tradeType, clOrdId);
+            //验证是否允许下单
+            if (StrUtil.isNotEmpty(tradeType) && OrderParamEnums.TRADE_NO.getValue().equals(tradeType)) {
+                log.error("止损账户{}不允许下单,取消发送", accountName);
+                return;
+            }
+            /**
+             * 检验账户和仓位是否准备就绪
+             * 开多:买入开多(side 填写 buy; posSide 填写 long )
+             * 开空:卖出开空(side 填写 sell; posSide 填写 short ) 需要检验账户通道是否准备就绪
+             * 平多:卖出平多(side 填写 sell;posSide 填写 long )
+             * 平空:买入平空(side 填写 buy; posSide 填写 short ) 需要检验仓位通道是否准备就绪
+             */
+            try {
+                JSONArray argsArray = new JSONArray();
+                JSONObject args = new JSONObject();
+                args.put("instId", instId);
+                args.put("tdMode", tdMode);
+                args.put("clOrdId", clOrdId);
+                args.put("side", side);
+
+                args.put("posSide", posSide);
+                args.put("ordType", ordType);
+                args.put("sz", sz);
+                args.put("px", markPx);
+                argsArray.add(args);
+
+                String connId = WsParamBuild.getOrderNum(ORDERWS_CHANNEL);
+                JSONObject jsonObject = WsParamBuild.buildJsonObject(connId, ORDERWS_CHANNEL, argsArray);
+                webSocketClient.send(jsonObject.toJSONString());
+                log.info("止损已发送......");
+            } catch (Exception e) {
+                log.error("下单构建失败", e);
+            }
+        }
+    }
+
 
 
     /**
diff --git a/src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/enums/CoinEnums.java b/src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/enums/CoinEnums.java
index 49aab7b..2c0ae65 100644
--- a/src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/enums/CoinEnums.java
+++ b/src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/enums/CoinEnums.java
@@ -47,8 +47,8 @@
     //下单的总保障金为账户总金额cashBal * TOTAL_ORDER_USDT用来做保证金
     TOTAL_ORDER_USDTPECENT("总保证金比例total_order_usdtpecent","0.1"),
     TOTAL_ORDER_USDT("总保证金totalOrderUsdt","0"),
-    KANG_CANG("抗压比例KANG_CANG","0.9"),
-    ZHI_SUN("止损比例ZHI_SUN","0.8"),
+    KANG_CANG("抗压比例KANG_CANG","0.1"),
+    ZHI_SUN("止损比例ZHI_SUN","0.2"),
     //每次下单的张数
     BUY_CNT("每次开仓的张数buyCnt","0.1"),
     BUY_CNT_INIT("每次初始化开仓张数的基础值buyCntInit","0.1"),
diff --git a/src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/enums/ExchangeInfoEnum.java b/src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/enums/ExchangeInfoEnum.java
index eee3fdf..42a1d83 100644
--- a/src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/enums/ExchangeInfoEnum.java
+++ b/src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/enums/ExchangeInfoEnum.java
@@ -13,14 +13,14 @@
      * 模拟盘账户1信息
      * 存储了模拟盘交易所需的API密钥、秘钥和通过码
      */
-    OKX_PRD_xiao("f512673b-2685-4fcb-9bb1-2ae8db745d62",
-            "B0C1CC8F39625B41140D93DC25039E33",
-            "Aa12345678@",
-            true);
-//    OKX_UAT_ceshi("ffb4e79f-fcf5-4afb-82c5-2fbb64123f61",
-//            "AA06C5ED1D7C7F5AFE6484052E231C55",
+//    OKX_PRD_xiao("f512673b-2685-4fcb-9bb1-2ae8db745d62",
+//            "B0C1CC8F39625B41140D93DC25039E33",
 //            "Aa12345678@",
-//            false);
+//            true);
+    OKX_UAT_ceshi("ffb4e79f-fcf5-4afb-82c5-2fbb64123f61",
+            "AA06C5ED1D7C7F5AFE6484052E231C55",
+            "Aa12345678@",
+            false);
 //
 //    /**
 //     * 模拟盘账户2信息
diff --git a/src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/wanggeList/WangGeListEnum.java b/src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/wanggeList/WangGeListEnum.java
index ae0822c..9680933 100644
--- a/src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/wanggeList/WangGeListEnum.java
+++ b/src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/wanggeList/WangGeListEnum.java
@@ -11,11 +11,16 @@
  */
 @Getter
 public enum WangGeListEnum {
-    UP_ONE("上层做空", "2", "3500", "3300", "4", "long", "3500"),
-    UP("上层做空", "2", "3300", "3000", "4", "short", "3300"),
-    CENTER("中间做空", "2", "3000", "2700", "4", "short", "3000"),
-    DOWN("下层做空", "2", "2700", "2200", "4", "short", "2700"),
-    DOWN_ONE("下层做多", "2", "2200", "1800", "4", "long", "1800");
+//    UP_ONE("上层做空", "2", "3500", "3300", "4", "long", "3500"),
+//    UP("上层做空", "2", "3300", "3000", "4", "short", "3300"),
+//    CENTER("中间做空", "2", "3000", "2700", "4", "short", "3000"),
+//    DOWN("下层做空", "2", "2700", "2200", "4", "short", "2700"),
+//    DOWN_ONE("下层做多", "2", "2200", "1800", "4", "long", "1800");
+    UP_ONE("上层做long", "2", "3450", "3400", "4", "long", "3380"),
+    UP("上层做short", "2", "3400", "3350", "4", "short", "3420"),
+    CENTER("中间做long", "2", "3350", "3300", "4", "long", "3280"),
+    DOWN("下层做空", "2", "3300", "3250", "4", "short", "3320"),
+    DOWN_ONE("下层做多", "2", "3250", "3200", "4", "long", "3180");
 
     private String name;
     private String xiaoshu_weishu;
diff --git a/src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/wanggeList/WangGeListServiceImpl.java b/src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/wanggeList/WangGeListServiceImpl.java
index 6b3b1d6..17a74be 100644
--- a/src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/wanggeList/WangGeListServiceImpl.java
+++ b/src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/wanggeList/WangGeListServiceImpl.java
@@ -28,13 +28,11 @@
      */
     @Override
     public PriorityBlockingQueue<AscBigDecimal> initWangGe(String markPx) {
-        log.info("网格初始化中");
         PriorityBlockingQueue<AscBigDecimal> queueAsc = WangGeListQueue.getQueueAsc();
         queueAsc.clear();
 
         //获取WangGeListEnum全部网格参数
         WangGeListEnum gridByPrice = WangGeListEnum.getGridByPrice(new BigDecimal(markPx));
-        log.info("获取的网格参数: {}", gridByPrice);
         if (gridByPrice == null){
             log.error("没有获取到网格参数......");
             return null;
@@ -69,7 +67,7 @@
             }
 
             if (queueAsc.isEmpty()) {
-                log.info("网格初始化失败");
+                log.error("网格初始化失败");
                 return null;
             }
 
diff --git a/src/main/resources/logback-spring.xml b/src/main/resources/logback-spring.xml
index da4d449..0d0bf1b 100644
--- a/src/main/resources/logback-spring.xml
+++ b/src/main/resources/logback-spring.xml
@@ -141,7 +141,7 @@
         <logger name="java.sql" level="DEBUG" />
     </springProfile>
 
-    <root level="error">
+    <root level="info">
         <appender-ref ref="CONSOLE" />
         <appender-ref ref="DEBUG_FILE" />
         <appender-ref ref="INFO_FILE" />

--
Gitblit v1.9.1