From 39252ec46c56c2f444b18af97180a9c07519bff6 Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Tue, 06 Jan 2026 16:20:15 +0800
Subject: [PATCH] refactor(okxNewPrice): 重构交易订单处理逻辑

---
 src/main/java/com/xcong/excoin/modules/okxNewPrice/OkxKlineWebSocketClient.java |  106 +++++++++++-----------------------------------------
 1 files changed, 23 insertions(+), 83 deletions(-)

diff --git a/src/main/java/com/xcong/excoin/modules/okxNewPrice/OkxKlineWebSocketClient.java b/src/main/java/com/xcong/excoin/modules/okxNewPrice/OkxKlineWebSocketClient.java
index 1983e8a..cf5c9fd 100644
--- a/src/main/java/com/xcong/excoin/modules/okxNewPrice/OkxKlineWebSocketClient.java
+++ b/src/main/java/com/xcong/excoin/modules/okxNewPrice/OkxKlineWebSocketClient.java
@@ -22,6 +22,7 @@
 import com.xcong.excoin.modules.okxNewPrice.okxpi.config.ExchangeInfoEnum;
 import com.xcong.excoin.modules.okxNewPrice.okxpi.config.ExchangeLoginService;
 import com.xcong.excoin.modules.okxNewPrice.utils.SSLConfig;
+import com.xcong.excoin.modules.okxNewPrice.utils.WsMapBuild;
 import com.xcong.excoin.modules.okxNewPrice.utils.WsParamBuild;
 import com.xcong.excoin.utils.RedisUtils;
 import lombok.extern.slf4j.Slf4j;
@@ -344,10 +345,8 @@
                  */
                 String confirm = data.getString(8);
                 if ("1".equals(confirm)){
-                    log.info("{}开仓{}:{}",time,closePx,instId);
                     //调用策略
                     // 创建策略实例
-//                    MacdMaStrategy strategy = new MacdMaStrategy();
                     MacdEmaStrategy strategy = new MacdEmaStrategy();
 
                     // 生成200个1m价格数据点
@@ -356,14 +355,7 @@
                             .map(Kline::getC)
                             .collect(Collectors.toList());
 
-                    // 生成200个1D价格数据点
-//                    List<Kline> kline1DayData = getKlineDataByInstIdAndBar(instId, "1D");
-//                    List<BigDecimal> historicalPrices1D = kline1DayData.stream()
-//                            .map(Kline::getC)
-//                            .collect(Collectors.toList());
-//                    log.info("1D:{}", JSONUtil.parse( historicalPrices1D));
                     // 使用策略分析最新价格数据
-//                    MacdMaStrategy.TradingOrder tradingOrderOpenOpen = strategy.generateTradingOrder(historicalPrices1M,historicalPrices1D,MacdMaStrategy.OperationType.open.name());
                     MacdEmaStrategy.TradingOrder tradingOrderOpenOpen = strategy.generateTradingOrder(historicalPrices1M, MacdMaStrategy.OperationType.open.name());
                     if (tradingOrderOpenOpen == null){
                         return;
@@ -379,80 +371,8 @@
                         String accountName = client.getAccountName();
                         if (accountName != null) {
                             if (ObjectUtil.isNotEmpty(tradingOrderOpenOpen)){
-                                // 根据信号执行交易操作
-                                TradeRequestParam tradeRequestParam = new TradeRequestParam();
-
-                                String posSide = tradingOrderOpenOpen.getPosSide();
-                                tradeRequestParam.setPosSide(posSide);
-                                String currentPrice = String.valueOf(closePx);
-                                tradeRequestParam = caoZuoService.caoZuoStrategy(accountName, currentPrice, posSide);
-
-                                String side = tradingOrderOpenOpen.getSide();
-                                tradeRequestParam.setSide(side);
-
-                                String clOrdId = WsParamBuild.getOrderNum(side);
-                                tradeRequestParam.setClOrdId(clOrdId);
-
-                                String sz = InstrumentsWs.getAccountMap(accountName).get(CoinEnums.BUY_CNT_INIT.name());
-                                tradeRequestParam.setSz(sz);
-                                TradeOrderWs.orderEvent(client.getWebSocketClient(), tradeRequestParam);
-                            }
-                        }
-                    }
-                }else{
-                    log.info("{}平仓{}:{}",time,closePx,instId);
-                    //调用策略
-                    // 创建策略实例
-                    MacdMaStrategy strategy = new MacdMaStrategy();
-
-                    // 生成200个1m价格数据点
-                    List<Kline> kline1MinuteData = getKlineDataByInstIdAndBar(instId, "1m");
-                    List<BigDecimal> historicalPrices1M = kline1MinuteData.stream()
-                            .map(Kline::getC)
-                            .collect(Collectors.toList());
-
-
-                    // 生成200个1D价格数据点
-                    List<Kline> kline1DayData = getKlineDataByInstIdAndBar(instId, "1D");
-                    List<BigDecimal> historicalPrices1D = kline1DayData.stream()
-                            .map(Kline::getC)
-                            .collect(Collectors.toList());
-                    // 使用策略分析最新价格数据
-                    MacdMaStrategy.TradingOrder tradingOrderOpenClose = strategy.generateTradingOrder(historicalPrices1M,historicalPrices1D,MacdMaStrategy.OperationType.close.name());
-                    if (tradingOrderOpenClose == null){
-                        return;
-                    }
-
-                    Collection<OkxQuantWebSocketClient> allClients = clientManager.getAllClients();
-                    //如果为空,则直接返回
-                    if (allClients.isEmpty()) {
-                        return;
-                    }
-                    // 获取所有OkxQuantWebSocketClient实例
-                    for (OkxQuantWebSocketClient client : clientManager.getAllClients()) {
-                        String accountName = client.getAccountName();
-                        if (accountName != null) {
-                            if (ObjectUtil.isNotEmpty(tradingOrderOpenClose)){
-                                // 根据信号执行交易操作
-                                TradeRequestParam tradeRequestParam = new TradeRequestParam();
-                                tradeRequestParam.setAccountName(accountName);
-                                tradeRequestParam.setMarkPx(String.valueOf(closePx));
-                                tradeRequestParam.setInstId(CoinEnums.HE_YUE.getCode());
-                                tradeRequestParam.setTdMode(CoinEnums.CROSS.getCode());
-                                tradeRequestParam.setOrdType(CoinEnums.ORDTYPE_MARKET.getCode());
-                                String posSide = tradingOrderOpenClose.getPosSide();
-                                tradeRequestParam.setPosSide(posSide);
-
-                                String side = tradingOrderOpenClose.getSide();
-                                tradeRequestParam.setSide(side);
-
-                                String clOrdId = WsParamBuild.getOrderNum(side);
-                                tradeRequestParam.setClOrdId(clOrdId);
-
-                                String positionAccountName = PositionsWs.initAccountName(accountName, posSide);
-                                BigDecimal pos = PositionsWs.getAccountMap(positionAccountName).get("pos");
-                                tradeRequestParam.setSz(String.valueOf(pos));
-                                TradeOrderWs.orderZhiYingZhiSunEventNoState(client.getWebSocketClient(), tradeRequestParam);
+                                log.info("{}开仓{}:{}",instId,tradingOrderOpenOpen.getPosSide(),tradingOrderOpenOpen.getSide());
+                                doOpen(client.getWebSocketClient(),accountName, tradingOrderOpenOpen, closePx);
                             }
                         }
                     }
@@ -463,6 +383,26 @@
         }
     }
 
+    private void doOpen(WebSocketClient webSocketClient, String accountName, MacdEmaStrategy.TradingOrder tradingOrderOpenOpen, BigDecimal closePx) {
+        // 根据信号执行交易操作
+        TradeRequestParam tradeRequestParam = new TradeRequestParam();
+
+        String posSide = tradingOrderOpenOpen.getPosSide();
+        tradeRequestParam.setPosSide(posSide);
+        String currentPrice = String.valueOf(closePx);
+        tradeRequestParam = caoZuoService.caoZuoStrategy(accountName, currentPrice, posSide);
+
+        String side = tradingOrderOpenOpen.getSide();
+        tradeRequestParam.setSide(side);
+
+        String clOrdId = WsParamBuild.getOrderNum(side);
+        tradeRequestParam.setClOrdId(clOrdId);
+
+        String sz = InstrumentsWs.getAccountMap(accountName).get(CoinEnums.BUY_CNT_INIT.name());
+        tradeRequestParam.setSz(sz);
+        TradeOrderWs.orderEvent(webSocketClient, tradeRequestParam);
+    }
+
     private List<Kline> getKlineDataByInstIdAndBar(String instId, String bar) {
         List<Kline> klineList = new ArrayList<>();
         try {

--
Gitblit v1.9.1