Helius
2020-06-08 a53b79219e1f05c4871165804d799a08aa66f4d1
add tow new job
7 files modified
1 files added
128 ■■■■■ changed files
src/main/java/com/xcong/excoin/modules/contract/entity/ContractHoldOrderEntity.java 5 ●●●●● patch | view | raw | blame | history
src/main/java/com/xcong/excoin/modules/contract/service/ContractHoldOrderService.java 2 ●●●●● patch | view | raw | blame | history
src/main/java/com/xcong/excoin/modules/contract/service/impl/ContractHoldOrderServiceImpl.java 57 ●●●●● patch | view | raw | blame | history
src/main/java/com/xcong/excoin/modules/home/dao/MemberQuickBuySaleDao.java 2 ●●●●● patch | view | raw | blame | history
src/main/java/com/xcong/excoin/quartz/job/LoopExecutorJob.java 54 ●●●●● patch | view | raw | blame | history
src/main/resources/application-test.yml 1 ●●●● patch | view | raw | blame | history
src/main/resources/application.yml 1 ●●●● patch | view | raw | blame | history
src/main/resources/mapper/home/MemberQuickBuySaleDao.xml 6 ●●●●● 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>