package com.xcong.excoin.modules.okxNewPrice.okxWs; import com.alibaba.fastjson.JSONArray; import com.alibaba.fastjson.JSONObject; import com.xcong.excoin.modules.okxNewPrice.okxWs.enums.CoinEnums; import com.xcong.excoin.modules.okxNewPrice.okxpi.MallUtils; import com.xcong.excoin.modules.okxNewPrice.utils.WsMapBuild; import com.xcong.excoin.modules.okxNewPrice.utils.WsParamBuild; import lombok.extern.slf4j.Slf4j; import org.java_websocket.client.WebSocketClient; import java.math.BigDecimal; import java.util.Map; import java.util.concurrent.ConcurrentHashMap; /** * @author Administrator */ @Slf4j public class PositionsWs { public static final Map POSITIONSWSMAP = new ConcurrentHashMap<>(); public static final String POSITIONSWS_CHANNEL = "positions"; public static void subscribePositionChannel(WebSocketClient webSocketClient, String option) { try { JSONArray argsArray = new JSONArray(); JSONObject args = new JSONObject(); args.put("channel", POSITIONSWS_CHANNEL); args.put("instType", CoinEnums.INSTTYPE_SWAP.getCode()); args.put("instId", CoinEnums.HE_YUE.getCode()); argsArray.add(args); String connId = MallUtils.getOrderNum(POSITIONSWS_CHANNEL); JSONObject jsonObject = WsParamBuild.buildJsonObject(connId, option, argsArray); webSocketClient.send(jsonObject.toJSONString()); log.info("发送持仓频道频道:{}", option); } catch (Exception e) { log.error("订阅持仓频道频道构建失败", e); } } public static void handleEvent(JSONObject response) { log.info("开始执行PositionsWs......"); try { JSONArray dataArray = response.getJSONArray("data"); if (dataArray == null || dataArray.isEmpty()) { log.info("账户持仓频道数据为空,已当前价买入,并且初始化网格"); JSONObject posData = new JSONObject(); processPositionData(posData); return; } for (int i = 0; i < dataArray.size(); i++) { JSONObject posData = dataArray.getJSONObject(i); String instId = posData.getString("instId"); if (CoinEnums.HE_YUE.getCode().equals(instId)) { log.info("查询到账户{}持仓数据",CoinEnums.HE_YUE.getCode()); String mgnMode = posData.getString("mgnMode"); String posSide = posData.getString("posSide"); String pos = posData.getString("pos"); String avgPx = posData.getString("avgPx"); String upl = posData.getString("upl"); String uplRatio = posData.getString("uplRatio"); String lever = posData.getString("lever"); String liqPx = posData.getString("liqPx"); String markPx = posData.getString("markPx"); String imr = posData.getString("imr"); String mgnRatio = posData.getString("mgnRatio"); String mmr = posData.getString("mmr"); String notionalUsd = posData.getString("notionalUsd"); String ccy = posData.getString("ccy"); String last = posData.getString("last"); String idxPx = posData.getString("idxPx"); String bePx = posData.getString("bePx"); String realizedPnl = posData.getString("realizedPnl"); String settledPnl = posData.getString("settledPnl"); log.info( "账户持仓频道-产品类型: {}, 保证金模式: {}, 持仓方向: {}, 持仓数量: {}, 开仓平均价: {}, " + "未实现收益: {}, 未实现收益率: {}, 杠杆倍数: {}, 预估强平价: {}, 初始保证金: {}, " + "维持保证金率: {}, 维持保证金: {}, 以美金价值为单位的持仓数量: {}, 占用保证金的币种: {}, " + "最新成交价: {}, 最新指数价格: {}, 盈亏平衡价: {}, 已实现收益: {}, 累计已结算收益: {}" + "最新标记价格: {}", instId, mgnMode, posSide, pos, avgPx, upl, uplRatio, lever, liqPx, imr, mgnRatio, mmr, notionalUsd, ccy, last, idxPx, bePx, realizedPnl, settledPnl, markPx ); processPositionData(posData); } } } catch (Exception e) { log.error("处理持仓频道推送数据失败", e); } } private static void processPositionData(JSONObject posData) { WsMapBuild.saveBigDecimalToMap(POSITIONSWSMAP, "avgPx", WsMapBuild.parseBigDecimalSafe(posData.getString("avgPx"))); WsMapBuild.saveBigDecimalToMap(POSITIONSWSMAP, "pos", WsMapBuild.parseBigDecimalSafe(posData.getString("pos"))); WsMapBuild.saveBigDecimalToMap(POSITIONSWSMAP, "upl", WsMapBuild.parseBigDecimalSafe(posData.getString("upl"))); WsMapBuild.saveBigDecimalToMap(POSITIONSWSMAP, "imr", WsMapBuild.parseBigDecimalSafe(posData.getString("imr"))); WsMapBuild.saveBigDecimalToMap(POSITIONSWSMAP, "mgnRatio", WsMapBuild.parseBigDecimalSafe(posData.getString("mgnRatio"))); WsMapBuild.saveBigDecimalToMap(POSITIONSWSMAP, "markPx", WsMapBuild.parseBigDecimalSafe(posData.getString("markPx"))); WsMapBuild.saveBigDecimalToMap(POSITIONSWSMAP, "bePx", WsMapBuild.parseBigDecimalSafe(posData.getString("bePx"))); WsMapBuild.saveBigDecimalToMap(POSITIONSWSMAP, "realizedPnl", WsMapBuild.parseBigDecimalSafe(posData.getString("realizedPnl"))); } }