From 5ba662f26b836b7e9bc4e483bfe1cded5315b034 Mon Sep 17 00:00:00 2001
From: Helius <wangdoubleone@gmail.com>
Date: Tue, 11 Aug 2020 11:29:43 +0800
Subject: [PATCH] Merge branch 'follow' into whole

---
 src/main/java/com/xcong/excoin/modules/contract/service/impl/ContractHoldOrderServiceImpl.java |   91 ++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 84 insertions(+), 7 deletions(-)

diff --git a/src/main/java/com/xcong/excoin/modules/contract/service/impl/ContractHoldOrderServiceImpl.java b/src/main/java/com/xcong/excoin/modules/contract/service/impl/ContractHoldOrderServiceImpl.java
index 9fbc565..96fc875 100644
--- a/src/main/java/com/xcong/excoin/modules/contract/service/impl/ContractHoldOrderServiceImpl.java
+++ b/src/main/java/com/xcong/excoin/modules/contract/service/impl/ContractHoldOrderServiceImpl.java
@@ -22,6 +22,10 @@
 import com.xcong.excoin.modules.contract.parameter.dto.*;
 import com.xcong.excoin.modules.contract.parameter.vo.*;
 import com.xcong.excoin.modules.contract.service.ContractHoldOrderService;
+import com.xcong.excoin.modules.documentary.dao.FollowFollowerOrderRelationDao;
+import com.xcong.excoin.modules.documentary.dao.FollowTraderInfoDao;
+import com.xcong.excoin.modules.documentary.entity.FollowFollowerOrderRelationEntity;
+import com.xcong.excoin.modules.documentary.entity.FollowTraderInfoEntity;
 import com.xcong.excoin.modules.member.dao.MemberDao;
 import com.xcong.excoin.modules.member.dao.MemberLevelRateDao;
 import com.xcong.excoin.modules.member.dao.MemberWalletContractDao;
@@ -82,6 +86,11 @@
 
     @Resource
     private MemberDao memberDao;
+    
+    @Resource
+    private FollowTraderInfoDao followTraderInfoDao;
+    @Resource
+    private FollowFollowerOrderRelationDao followFollowerOrderRelationDao;
 
     @Transactional(rollbackFor = Exception.class)
     @Override
@@ -143,6 +152,16 @@
         BigDecimal forceClosingPrice = CalculateUtil.getForceSetPrice(bondAmount, openingPrice, submitOrderDto.getSymbolCnt(), lotNumber, submitOrderDto.getOrderType(), memberEntity);
         log.info("强平价:{}", forceClosingPrice);
 
+        // 判断是否开启了带单
+        boolean isOpenFollow = false;
+        FollowTraderInfoEntity tradeInfo = null;
+        if (MemberEntity.IS_TRADER_Y.equals(memberEntity.getIsTrader())) {
+            tradeInfo = followTraderInfoDao.selectTraderInfoByMemberId(memberEntity.getId());
+            if (tradeInfo.getIsOpen().equals(FollowTraderInfoEntity.ISOPEN_Y)) {
+                isOpenFollow = true;
+            }
+        }
+
         ContractHoldOrderEntity holdOrderEntity = new ContractHoldOrderEntity();
         holdOrderEntity.setMemberId(memberEntity.getId());
         holdOrderEntity.setOrderNo(commonService.generateOrderNo(memberEntity.getId()));
@@ -161,6 +180,8 @@
         holdOrderEntity.setPrePaymentAmount(prePaymentAmount);
         holdOrderEntity.setBondAmount(bondAmount.add(openFeePrice));
         holdOrderEntity.setOperateNo(1);
+        // 设置合约类型
+        holdOrderEntity.setContractType(isOpenFollow ? ContractOrderEntity.CONTRACTTYPE_DOCUMENTARY : ContractOrderEntity.CONTRACTTYPE_NORMAL);
 
         ContractOrderEntity contractOrderEntity = ContractHoldOrderEntityMapper.INSTANCE.holdOrderToOrder(holdOrderEntity);
         contractOrderEntity.setOpeningTime(new Date());
@@ -181,6 +202,21 @@
                 LogRecordUtils.insertMemberAccountFlow(memberEntity.getId(), prePaymentAmount, walletContract.getAvailableBalance().subtract(prePaymentAmount), submitOrderDto.getSymbol(), "买涨持仓", "买涨:" + submitOrderDto.getSymbol());
             } else {
                 LogRecordUtils.insertMemberAccountFlow(memberEntity.getId(), prePaymentAmount, walletContract.getAvailableBalance().subtract(prePaymentAmount), submitOrderDto.getSymbol(), "买跌持仓", "买跌:" + submitOrderDto.getSymbol());
+            }
+
+            // 若该用户为交易员且开启带单模式,则发送带单异步
+            if (isOpenFollow) {
+                FollowFollowerOrderRelationEntity relationEntity = new FollowFollowerOrderRelationEntity();
+                relationEntity.setIsShow(FollowFollowerOrderRelationEntity.IS_SHOW_Y);
+                relationEntity.setMemberId(holdOrderEntity.getMemberId());
+                relationEntity.setOrderId(holdOrderEntity.getId());
+                relationEntity.setOrderType(FollowFollowerOrderRelationEntity.ORDER_TYPE_HOLD);
+                relationEntity.setTradeId(tradeInfo.getId());
+                relationEntity.setTradeMemberId(tradeInfo.getMemberId());
+                relationEntity.setTradeOrderNo(holdOrderEntity.getOrderNo());
+                followFollowerOrderRelationDao.insert(relationEntity);
+
+                ThreadPoolUtils.sendFollowOrderTask(holdOrderEntity.getId());
             }
             return Result.ok("提交成功");
         }
@@ -203,10 +239,10 @@
     }
 
     @Override
-    public Result findHoldOrderList(String symbol) {
+    public Result findHoldOrderList(String symbol, int type) {
         MemberEntity memberEntity = LoginUserUtils.getAppLoginUser();
 
-        List<ContractHoldOrderEntity> list = contractHoldOrderDao.selectHoldOrderListByMemberIdAndSymbol(memberEntity.getId(), symbol);
+        List<ContractHoldOrderEntity> list = contractHoldOrderDao.selectHoldOrderListByMemberIdAndSymbol(memberEntity.getId(), symbol, type);
         MemberWalletContractEntity walletContractEntity = memberWalletContractDao.findWalletContractByMemberIdAndSymbol(memberEntity.getId(), CoinTypeEnum.USDT.name());
         if (CollUtil.isNotEmpty(list)) {
             BigDecimal totalProfitOrLoss = BigDecimal.ZERO;
@@ -233,7 +269,7 @@
                     if (rewardRatio.compareTo(BigDecimal.ZERO) > -1) {
                         rewardRatio = rewardRatio.multiply(BigDecimal.ONE.subtract(tradeSettingEntity.getProfitParam()));
                     } else {
-                        rewardRatio = rewardRatio.multiply(BigDecimal.ONE.add(tradeSettingEntity.getProfitParam()));
+//                        rewardRatio = rewardRatio.multiply(BigDecimal.ONE.add(tradeSettingEntity.getProfitParam()));
                     }
                 }
 
@@ -277,11 +313,13 @@
         MemberEntity memberEntity = LoginUserUtils.getAppLoginUser();
         ContractHoldOrderEntity holdOrderEntity = contractHoldOrderDao.selectHoldOrderByMemberIdAndId(memberEntity.getId(), id);
         if (holdOrderEntity == null) {
-            return Result.fail("订单不存在");
+            // 订单不存在
+            return Result.fail(MessageSourceUtils.getString("order_service_0027"));
         }
 
         if (ContractHoldOrderEntity.ORDER_CAN_CLOSING_N == holdOrderEntity.getIsCanClosing()) {
-            return Result.fail("订单暂不可平仓");
+            // 该订单暂不能平仓
+            return Result.fail(MessageSourceUtils.getString("order_service_0045"));
         }
 
         contractHoldOrderDao.updateHoldOrderIsCanClosingById(ContractHoldOrderEntity.ORDER_CAN_CLOSING_N, id);
@@ -290,13 +328,37 @@
         ids.add(id);
         producer.sendCloseTrade(JSONObject.toJSONString(ids));
 
-        return Result.ok("平仓成功");
+        // 平仓成功
+        return Result.ok(MessageSourceUtils.getString("order_service_0044"));
+    }
+
+    @Override
+    public Result cancelHoldOrder(WholeCloseOrderDto wholeCloseOrderDto) {
+        MemberEntity memberEntity = LoginUserUtils.getAppLoginUser();
+        ContractHoldOrderEntity holdOrderEntity = contractHoldOrderDao.selectHoldOrderByMemberIdAndId(memberEntity.getId(), wholeCloseOrderDto.getId());
+        if (holdOrderEntity == null) {
+            // 订单不存在
+            return Result.fail(MessageSourceUtils.getString("order_service_0027"));
+        }
+
+        if (ContractHoldOrderEntity.ORDER_CAN_CLOSING_N == holdOrderEntity.getIsCanClosing()) {
+            // 该订单暂不能平仓
+            return Result.fail(MessageSourceUtils.getString("order_service_0045"));
+        }
+
+        if (wholeCloseOrderDto.getCount() > holdOrderEntity.getSymbolCntSale()) {
+            return Result.fail("可平张数不足");
+        }
+
+        holdOrderEntity.setSymbolCntSale(holdOrderEntity.getSymbolCntSale() - wholeCloseOrderDto.getCount());
+        contractHoldOrderDao.updateById(holdOrderEntity);
+        return null;
     }
 
     @Override
     public Result cancelHoldOrderBatch(SymbolDto symbolDto) {
         MemberEntity memberEntity = LoginUserUtils.getAppLoginUser();
-        List<ContractHoldOrderEntity> holdOrderEntities = contractHoldOrderDao.selectHoldOrderListByMemberIdAndSymbol(memberEntity.getId(), symbolDto.getSymbol());
+        List<ContractHoldOrderEntity> holdOrderEntities = contractHoldOrderDao.selectHoldOrderListByMemberIdAndSymbol(memberEntity.getId(), symbolDto.getSymbol(), 1);
         if (CollUtil.isEmpty(holdOrderEntities)) {
             return Result.fail("订单不存在");
         }
@@ -643,4 +705,19 @@
         }
         producer.sendPriceOperate(JSONObject.toJSONString(model));
     }
+
+    @Override
+    public Result changePositionType() {
+        MemberEntity member = LoginUserUtils.getAppLoginUser();
+        Integer positionType = member.getContractPositionType() == ContractEntrustOrderEntity.POSITION_TYPE_ADD ? ContractEntrustOrderEntity.POSITION_TYPE_ALL : ContractEntrustOrderEntity.POSITION_TYPE_ADD;
+        MemberEntity updateEntity = new MemberEntity();
+        updateEntity.setContractPositionType(positionType);
+        updateEntity.setId(member.getId());
+        int i = memberDao.updateById(updateEntity);
+        if (i > 0) {
+            LoginUserUtils.resetAppLoginUser(member);
+            return Result.ok(MessageSourceUtils.getString("member_service_0040"));
+        }
+        return Result.fail(MessageSourceUtils.getString("member_service_0041"));
+    }
 }

--
Gitblit v1.9.1