src/main/java/com/xcong/excoin/modules/contract/entity/ContractHoldOrderEntity.java | ●●●●● patch | view | raw | blame | history | |
src/main/java/com/xcong/excoin/modules/contract/service/ContractHoldOrderService.java | ●●●●● patch | view | raw | blame | history | |
src/main/java/com/xcong/excoin/modules/contract/service/impl/ContractHoldOrderServiceImpl.java | ●●●●● patch | view | raw | blame | history | |
src/main/java/com/xcong/excoin/modules/home/dao/MemberQuickBuySaleDao.java | ●●●●● patch | view | raw | blame | history | |
src/main/java/com/xcong/excoin/quartz/job/LoopExecutorJob.java | ●●●●● patch | view | raw | blame | history | |
src/main/resources/application-test.yml | ●●●●● patch | view | raw | blame | history | |
src/main/resources/application.yml | ●●●●● patch | view | raw | blame | history | |
src/main/resources/mapper/home/MemberQuickBuySaleDao.xml | ●●●●● patch | view | raw | blame | history |
src/main/java/com/xcong/excoin/modules/contract/entity/ContractHoldOrderEntity.java
@@ -146,4 +146,9 @@ * 批次号 队列平仓时使用,避免重复 */ public String batchNo; /** * 持仓费 */ private BigDecimal holdAmount; } src/main/java/com/xcong/excoin/modules/contract/service/ContractHoldOrderService.java
@@ -42,4 +42,6 @@ public Result findOrderDetailById(Long id); public void calHoldOrderHoldFeeAmount(); } 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)); } } } } } src/main/java/com/xcong/excoin/modules/home/dao/MemberQuickBuySaleDao.java
@@ -9,4 +9,6 @@ MemberQuickBuySaleEntity selectByIdAndMemberId(@Param("memberId")Long memberId,@Param("id")Long id); int updateQuickBuySaleTimeOut(); } src/main/java/com/xcong/excoin/quartz/job/LoopExecutorJob.java
New file @@ -0,0 +1,54 @@ package com.xcong.excoin.quartz.job; import com.xcong.excoin.modules.contract.service.ContractHoldOrderService; import com.xcong.excoin.modules.home.dao.MemberQuickBuySaleDao; import lombok.extern.slf4j.Slf4j; import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty; import org.springframework.scheduling.annotation.Scheduled; import org.springframework.stereotype.Component; import org.springframework.transaction.annotation.Transactional; import javax.annotation.Resource; /** * @author wzy * @date 2020-06-08 **/ @Slf4j @Component @ConditionalOnProperty(prefix = "app", name = "loop-job", havingValue = "true") public class LoopExecutorJob { @Resource private MemberQuickBuySaleDao memberQuickBuySaleDao; @Resource private ContractHoldOrderService contractHoldOrderService; /** * 更新快捷充值超时状态 */ @Scheduled(cron = "0/5 * * * * ? ") @Transactional(rollbackFor = Exception.class) public void updateChargeUsdt() { try { memberQuickBuySaleDao.updateQuickBuySaleTimeOut(); } catch (Exception e) { log.error("更新快捷充值超时状态", e); } } /** * 持仓费计算 */ @Scheduled(cron = "0 0 0 */1 * ?") public void updateDoingPrice() { log.info("#持仓费计算#"); try { contractHoldOrderService.calHoldOrderHoldFeeAmount(); } catch (Exception e) { log.error("#持仓费计算错误#", e); } } } src/main/resources/application-test.yml
@@ -96,6 +96,7 @@ kline-update-job: false newest-price-update-job: true other-job: true loop-job: true rabbit-consumer: true aliyun: src/main/resources/application.yml
@@ -99,6 +99,7 @@ newest-price-update-job: false #其他任务控制 other-job: false loop-job: false rabbit-consumer: false aliyun: src/main/resources/mapper/home/MemberQuickBuySaleDao.xml
@@ -6,4 +6,10 @@ <select id="selectByIdAndMemberId" resultType="com.xcong.excoin.modules.home.entity.MemberQuickBuySaleEntity"> SELECT a.* FROM member_quick_buy_sale a WHERE a.id = #{id} AND a.member_id = #{memberId} </select> <update id="updateQuickBuySaleTimeOut"> update member_quick_buy_sale set order_status = 5 where order_type = 'B' and order_status=1 </update> </mapper>