From d23645e976981bc9b670eea1d469fe8a36be309c Mon Sep 17 00:00:00 2001 From: KKSU <15274802129@163.com> Date: Wed, 17 Apr 2024 17:19:53 +0800 Subject: [PATCH] 55测试环境 --- src/main/java/com/xcong/excoin/modules/contract/service/impl/OrderWebsocketServiceImpl.java | 33 +++++++++++++++++++++------------ 1 files changed, 21 insertions(+), 12 deletions(-) diff --git a/src/main/java/com/xcong/excoin/modules/contract/service/impl/OrderWebsocketServiceImpl.java b/src/main/java/com/xcong/excoin/modules/contract/service/impl/OrderWebsocketServiceImpl.java index c7afd75..b7304af 100644 --- a/src/main/java/com/xcong/excoin/modules/contract/service/impl/OrderWebsocketServiceImpl.java +++ b/src/main/java/com/xcong/excoin/modules/contract/service/impl/OrderWebsocketServiceImpl.java @@ -19,6 +19,7 @@ import com.xcong.excoin.modules.contract.service.ContractEntrustOrderService; import com.xcong.excoin.modules.contract.service.ContractHoldOrderService; import com.xcong.excoin.modules.contract.service.ContractOrderService; +import com.xcong.excoin.modules.contract.service.RabbitOrderService; import com.xcong.excoin.modules.documentary.common.NoticeConstant; import com.xcong.excoin.modules.documentary.dao.FollowFollowerOrderRelationDao; import com.xcong.excoin.modules.documentary.dao.FollowFollowerProfitDao; @@ -179,19 +180,19 @@ } } - private void closingFollowerOrders(MemberEntity memberEntity, ContractHoldOrderEntity holdOrderEntity) { + private void closingFollowerOrders(MemberEntity memberEntity, ContractHoldOrderEntity holdOrderEntity, ContractOrderEntity contractOrderEntity) { // 判断当前持仓是否为跟单订单 -// if (ContractOrderEntity.CONTRACTTYPE_DOCUMENTARY == holdOrderEntity.getContractType()) { -// updateFollowOrderRelation(holdOrderEntity.getId(), contractOrderEntity.getId()); -// -// // 若为交易员,则平仓跟随者订单 -// if (MemberEntity.IS_TRADER_Y.equals(memberEntity.getIsTrader())) { -// followOrderOperationService.closingFollowOrders(holdOrderEntity.getOrderNo()); -// } else { -// //followFollowerProfitDao.updateFollowerProfitByTradeMemberId(holdOrderEntity.getBondAmount(), profitOrLoss, traderInfoEntity.getMemberId(), memberEntity.getId()); -// LogRecordUtils.insertFollowerNotice(memberEntity.getId(), NoticeConstant.CLOSE_ORDER_TITLE, StrUtil.format(NoticeConstant.CLOSE_ORDER_CONTENT, contractOrderEntity.getSymbol(), contractOrderEntity.getClosingPrice().setScale(2, BigDecimal.ROUND_HALF_UP).toString(), profitOrLoss.setScale(2, BigDecimal.ROUND_HALF_UP).toString(), traderInfoEntity.getNickname())); -// } -// } + if (ContractOrderEntity.CONTRACTTYPE_DOCUMENTARY == holdOrderEntity.getContractType()) { + FollowTraderInfoEntity traderInfoEntity = followTraderInfoDao.selectTraderInfoByOrderId(holdOrderEntity.getId()); + updateFollowOrderRelation(holdOrderEntity.getId(), contractOrderEntity.getId()); + + // 若为交易员,则平仓跟随者订单 + if (MemberEntity.IS_TRADER_Y.equals(memberEntity.getIsTrader())) { + followOrderOperationService.closingFollowOrders(holdOrderEntity.getOrderNo()); + } else { + LogRecordUtils.insertFollowerNotice(memberEntity.getId(), NoticeConstant.CLOSE_ORDER_TITLE, StrUtil.format(NoticeConstant.CLOSE_ORDER_CONTENT, contractOrderEntity.getSymbol(), contractOrderEntity.getClosingPrice().setScale(2, BigDecimal.ROUND_HALF_UP).toString(), contractOrderEntity.getRewardAmount().setScale(2, BigDecimal.ROUND_HALF_UP).toString(), traderInfoEntity.getNickname())); + } + } } @@ -288,6 +289,8 @@ if (ContractEntrustOrderEntity.POSITION_TYPE_ALL == order.getPositionType()) { ThreadPoolUtils.sendWholePrice(memberId); deleteEntrustCloseOrder(order.getOrderNo()); + } else { + closingFollowerOrders(memberEntity, order, contractOrderEntity); } } } @@ -389,6 +392,8 @@ if (ContractEntrustOrderEntity.POSITION_TYPE_ALL == order.getPositionType()) { ThreadPoolUtils.sendWholePrice(memberId); deleteEntrustCloseOrder(order.getOrderNo()); + } else { + closingFollowerOrders(memberEntity, order, contractOrderEntity); } } } @@ -488,6 +493,8 @@ if (ContractEntrustOrderEntity.POSITION_TYPE_ALL == order.getPositionType()) { ThreadPoolUtils.sendWholePrice(memberId); deleteEntrustCloseOrder(order.getOrderNo()); + } else { + closingFollowerOrders(memberEntity, order, contractOrderEntity); } } } @@ -586,6 +593,8 @@ if (ContractEntrustOrderEntity.POSITION_TYPE_ALL == order.getPositionType()) { ThreadPoolUtils.sendWholePrice(memberId); deleteEntrustCloseOrder(order.getOrderNo()); + } else { + closingFollowerOrders(memberEntity, order, contractOrderEntity); } } } -- Gitblit v1.9.1