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/entity/ContractHoldOrderEntity.java | 5 + src/main/java/com/xcong/excoin/modules/contract/service/impl/ContractHoldOrderServiceImpl.java | 57 +++++++++++++++++++ src/main/java/com/xcong/excoin/quartz/job/LoopExecutorJob.java | 54 ++++++++++++++++++ src/main/resources/mapper/home/MemberQuickBuySaleDao.xml | 6 ++ src/main/java/com/xcong/excoin/modules/contract/service/ContractHoldOrderService.java | 2 src/main/resources/application-test.yml | 1 src/main/java/com/xcong/excoin/modules/home/dao/MemberQuickBuySaleDao.java | 2 src/main/resources/application.yml | 1 8 files changed, 128 insertions(+), 0 deletions(-) diff --git a/src/main/java/com/xcong/excoin/modules/contract/entity/ContractHoldOrderEntity.java b/src/main/java/com/xcong/excoin/modules/contract/entity/ContractHoldOrderEntity.java index 52166a3..7da4069 100644 --- a/src/main/java/com/xcong/excoin/modules/contract/entity/ContractHoldOrderEntity.java +++ b/src/main/java/com/xcong/excoin/modules/contract/entity/ContractHoldOrderEntity.java @@ -146,4 +146,9 @@ * 批次号 队列平仓时使用,避免重复 */ public String batchNo; + + /** + * 持仓费 + */ + private BigDecimal holdAmount; } diff --git a/src/main/java/com/xcong/excoin/modules/contract/service/ContractHoldOrderService.java b/src/main/java/com/xcong/excoin/modules/contract/service/ContractHoldOrderService.java index 9294a72..c480514 100644 --- a/src/main/java/com/xcong/excoin/modules/contract/service/ContractHoldOrderService.java +++ b/src/main/java/com/xcong/excoin/modules/contract/service/ContractHoldOrderService.java @@ -42,4 +42,6 @@ public Result findOrderDetailById(Long id); + public void calHoldOrderHoldFeeAmount(); + } 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)); + } + } + } + } } diff --git a/src/main/java/com/xcong/excoin/modules/home/dao/MemberQuickBuySaleDao.java b/src/main/java/com/xcong/excoin/modules/home/dao/MemberQuickBuySaleDao.java index 5f084f8..9f0f27f 100644 --- a/src/main/java/com/xcong/excoin/modules/home/dao/MemberQuickBuySaleDao.java +++ b/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(); + } diff --git a/src/main/java/com/xcong/excoin/quartz/job/LoopExecutorJob.java b/src/main/java/com/xcong/excoin/quartz/job/LoopExecutorJob.java new file mode 100644 index 0000000..eda6f7f --- /dev/null +++ b/src/main/java/com/xcong/excoin/quartz/job/LoopExecutorJob.java @@ -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); + } + } +} diff --git a/src/main/resources/application-test.yml b/src/main/resources/application-test.yml index 74aa15a..849fecd 100644 --- a/src/main/resources/application-test.yml +++ b/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: diff --git a/src/main/resources/application.yml b/src/main/resources/application.yml index cf1a6f1..9b7adbf 100644 --- a/src/main/resources/application.yml +++ b/src/main/resources/application.yml @@ -99,6 +99,7 @@ newest-price-update-job: false #其他任务控制 other-job: false + loop-job: false rabbit-consumer: false aliyun: diff --git a/src/main/resources/mapper/home/MemberQuickBuySaleDao.xml b/src/main/resources/mapper/home/MemberQuickBuySaleDao.xml index 4af7288..36e68e0 100644 --- a/src/main/resources/mapper/home/MemberQuickBuySaleDao.xml +++ b/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> \ No newline at end of file -- Gitblit v1.9.1