From a53b79219e1f05c4871165804d799a08aa66f4d1 Mon Sep 17 00:00:00 2001
From: Helius <wangdoubleone@gmail.com>
Date: Mon, 08 Jun 2020 19:26:04 +0800
Subject: [PATCH] add tow new job

---
 src/main/java/com/xcong/excoin/modules/contract/service/impl/ContractHoldOrderServiceImpl.java |   57 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 57 insertions(+), 0 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 7a7014c..fb05a19 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,7 @@
 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.member.dao.MemberDao;
 import com.xcong.excoin.modules.member.dao.MemberLevelRateDao;
 import com.xcong.excoin.modules.member.dao.MemberWalletContractDao;
 import com.xcong.excoin.modules.member.entity.AgentReturnEntity;
@@ -78,6 +79,9 @@
 
     @Resource
     private OrderProducer producer;
+
+    @Resource
+    private MemberDao memberDao;
 
     @Transactional(rollbackFor = Exception.class)
     @Override
@@ -561,4 +565,57 @@
         OrderDetailVo orderDetailVo = ContractOrderEntityMapper.INSTANCE.entityToDetailVo(contractOrderEntity);
         return Result.ok(orderDetailVo);
     }
+
+    @Transactional(rollbackFor = Exception.class)
+    @Override
+    public void calHoldOrderHoldFeeAmount() {
+        List<ContractHoldOrderEntity> list = contractHoldOrderDao.selectAllHoldOrder();
+        PlatformTradeSettingEntity tradeSettingEntity = cacheSettingUtils.getTradeSetting();
+
+        if (CollUtil.isNotEmpty(list)) {
+            for (ContractHoldOrderEntity holdOrderEntity : list) {
+                BigDecimal holdAmount = holdOrderEntity.getHoldAmount();
+                if (holdAmount == null) {
+                    holdAmount = BigDecimal.ZERO;
+                }
+
+                BigDecimal thisTimeHold = holdOrderEntity.getBondAmount().multiply(tradeSettingEntity.getDoingRatio());
+                log.info("订单编号:{}, 持仓费:{}", holdOrderEntity.getOrderNo(), thisTimeHold);
+                MemberWalletContractEntity walletContractEntity = memberWalletContractDao.findWalletContractByMemberIdAndSymbol(holdOrderEntity.getMemberId(), CoinTypeEnum.USDT.name());
+
+                // 判断当前可用余额是否大于目前持仓费,若大于则扣可用余额,若小于则扣保证金中的金额
+                if (thisTimeHold.compareTo(walletContractEntity.getAvailableBalance()) < 0) {
+                    memberWalletContractDao.increaseWalletContractBalanceById(thisTimeHold.negate(), thisTimeHold.negate(), null, walletContractEntity.getId());
+
+                    holdOrderEntity.setHoldAmount(holdAmount.add(thisTimeHold));
+                    contractHoldOrderDao.updateById(holdOrderEntity);
+                } else {
+                    BigDecimal available = walletContractEntity.getAvailableBalance();
+                    BigDecimal lessAmount = thisTimeHold.subtract(available);
+                    MemberEntity memberEntity = memberDao.selectById(holdOrderEntity.getId());
+                    memberWalletContractDao.increaseWalletContractBalanceById(available.negate(), available.negate(), null, walletContractEntity.getId());
+
+                    BigDecimal newBondAmount = holdOrderEntity.getBondAmount().subtract(lessAmount);
+
+                    BigDecimal newForcePrice = CalculateUtil.getForceSetPrice(newBondAmount.subtract(holdOrderEntity.getOpeningFeeAmount()), holdOrderEntity.getOpeningPrice(), holdOrderEntity.getSymbolCnt(), holdOrderEntity.getSymbolSku(), holdOrderEntity.getOpeningType(), memberEntity);
+
+                    holdOrderEntity.setHoldAmount(holdAmount.add(thisTimeHold));
+                    holdOrderEntity.setBondAmount(newBondAmount);
+                    holdOrderEntity.setForceClosingPrice(newForcePrice);
+                    holdOrderEntity.setOperateNo(holdOrderEntity.getOperateNo() + 1);
+                    contractHoldOrderDao.updateById(holdOrderEntity);
+
+                    OrderModel model = null;
+                    // 开多
+                    if (ContractHoldOrderEntity.OPENING_TYPE_MORE == holdOrderEntity.getOpeningType()) {
+                        model = new OrderModel(holdOrderEntity.getId(), RabbitPriceTypeEnum.CLOSE_MORE_BOMB.getValue(), newForcePrice.setScale(8, RoundingMode.HALF_UP).toPlainString(), holdOrderEntity.getSymbol());
+                        // 开空
+                    } else {
+                        model = new OrderModel(holdOrderEntity.getId(), RabbitPriceTypeEnum.CLOSE_LESS_BOMB.getValue(), newForcePrice.setScale(8, RoundingMode.HALF_UP).toPlainString(), holdOrderEntity.getSymbol());
+                    }
+                    producer.sendPriceOperate(JSONObject.toJSONString(model));
+                }
+            }
+        }
+    }
 }

--
Gitblit v1.9.1