From 6c2e9ba62c418185361179e7014862c481f34e17 Mon Sep 17 00:00:00 2001 From: Helius <wangdoubleone@gmail.com> Date: Wed, 09 Mar 2022 14:22:09 +0800 Subject: [PATCH] conflect merge --- src/main/java/com/xcong/excoin/quartz/job/OtcOrderJob.java | 131 +++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 131 insertions(+), 0 deletions(-) diff --git a/src/main/java/com/xcong/excoin/quartz/job/OtcOrderJob.java b/src/main/java/com/xcong/excoin/quartz/job/OtcOrderJob.java new file mode 100644 index 0000000..669e0d4 --- /dev/null +++ b/src/main/java/com/xcong/excoin/quartz/job/OtcOrderJob.java @@ -0,0 +1,131 @@ +package com.xcong.excoin.quartz.job; + + +import cn.hutool.core.collection.CollUtil; +import cn.hutool.core.date.DateUnit; +import cn.hutool.core.date.DateUtil; +import cn.hutool.core.util.StrUtil; +import com.xcong.excoin.common.contants.AppContants; +import com.xcong.excoin.modules.member.dao.MemberWalletCoinDao; +import com.xcong.excoin.modules.member.entity.MemberWalletCoinEntity; +import com.xcong.excoin.modules.otc.dao.OtcEntrustOrderDao; +import com.xcong.excoin.modules.otc.dao.OtcMarketBussinessDao; +import com.xcong.excoin.modules.otc.dao.OtcOrderDao; +import com.xcong.excoin.modules.otc.dao.OtcSettingDao; +import com.xcong.excoin.modules.otc.entity.OtcEntrustOrder; +import com.xcong.excoin.modules.otc.entity.OtcMarketBussiness; +import com.xcong.excoin.modules.otc.entity.OtcOrder; +import com.xcong.excoin.modules.otc.entity.OtcSetting; +import com.xcong.excoin.modules.otc.service.OtcOrderService; +import com.xcong.excoin.utils.RedisUtils; +import lombok.extern.slf4j.Slf4j; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty; +import org.springframework.scheduling.annotation.Scheduled; +import org.springframework.stereotype.Component; + +import java.math.BigDecimal; +import java.util.Date; +import java.util.List; + +@Slf4j +@Component +@ConditionalOnProperty(prefix = "app", name = "otc-job", havingValue = "true") +public class OtcOrderJob { + + @Autowired + private OtcOrderDao otcOrderDao; + @Autowired + private OtcEntrustOrderDao otcEntrustOrderDao; + @Autowired + private OtcMarketBussinessDao otcMarketBussinessDao; + @Autowired + private MemberWalletCoinDao memberWalletCoinDao; + @Autowired + private OtcSettingDao otcSettingDao; + @Autowired + private RedisUtils redisUtils; + + @Scheduled(cron = "0/1 * * * * ? ") + public void autoCancelOrder() { + List<OtcOrder> otcOrders = otcOrderDao.selectOrderListWithStatusAndType(OtcEntrustOrder.ORDER_TYPE_B, OtcOrder.STATUS_SUBMIT); + if (CollUtil.isNotEmpty(otcOrders)) { + for (OtcOrder otcOrder : otcOrders) { + long between = DateUtil.between(new Date(), DateUtil.offsetMinute(otcOrder.getCreateTime(), 30), DateUnit.SECOND, false); + + if (between <= 0) { + OtcOrder saleOrder = otcOrderDao.selectOrderByOrderNoAndType(otcOrder.getOrderNo(), OtcEntrustOrder.ORDER_TYPE_S); + if (!saleOrder.getMemberId().equals(saleOrder.getEntrustMemberId())) { + MemberWalletCoinEntity wallet = memberWalletCoinDao.selectWalletCoinBymIdAndCode(saleOrder.getMemberId(), "USDT"); + memberWalletCoinDao.subFrozenBalance(saleOrder.getMemberId(), wallet.getId(), saleOrder.getCoinAmount()); + } + + otcEntrustOrderDao.updateRemainAmount(otcOrder.getEntrustOrderId(), otcOrder.getCoinAmount()); + otcOrderDao.updateOrderStatusByOrderNo(OtcOrder.STATUS_CANCEL, null, otcOrder.getOrderNo()); + + Long memberId; + if (otcOrder.getMemberId().equals(otcOrder.getEntrustMemberId())) { + memberId = otcOrder.getOppositeMemberId(); + } else { + memberId = otcOrder.getMemberId(); + } + + OtcSetting setting = otcSettingDao.selectById(1L); + String times = redisUtils.getString(AppContants.OTC_ORDER_CANCEL_TIMES + memberId); + if (StrUtil.isNotBlank(times)) { + int i = Integer.parseInt(times); + i++; + if (i >= setting.getCancellNum()) { + redisUtils.set(AppContants.OTC_ORDER_CANCEL_TIMES + memberId, i, 86400); + } else { + redisUtils.set(AppContants.OTC_ORDER_CANCEL_TIMES + memberId, i); + } + } else { + redisUtils.set(AppContants.OTC_ORDER_CANCEL_TIMES + memberId, 1, 86400); + } + } + } + } + } + +// @Scheduled(cron = "0 0/5 * * * ? ") + public void marketBussinessJob() { + List<OtcMarketBussiness> list = otcMarketBussinessDao.selectList(null); + if (CollUtil.isNotEmpty(list)) { + for (OtcMarketBussiness mb : list) { + // 服务人数 + Integer buyCnt = otcOrderDao.selectMemberCntForEntrust(mb.getMemberId()); + // 买单数 + Integer buyTotalCnt = otcOrderDao.selectTotalOrderCount(mb.getMemberId(), null, OtcEntrustOrder.ORDER_TYPE_B); + // 买单完成率 + Integer buyFinishCnt = otcOrderDao.selectTotalOrderCount(mb.getMemberId(), OtcOrder.STATUS_FINISH, OtcEntrustOrder.ORDER_TYPE_B); + if (buyTotalCnt != null && buyTotalCnt != 0) { + BigDecimal finishRatio = BigDecimal.valueOf(buyFinishCnt).divide(BigDecimal.valueOf(buyTotalCnt), 4, BigDecimal.ROUND_DOWN); + mb.setFinishRatio(finishRatio); + } + + // 买单数 + Integer saleTotalCnt = otcOrderDao.selectTotalOrderCount(mb.getMemberId(), null, OtcEntrustOrder.ORDER_TYPE_S); + // 买单完成率 + Integer saleFinishCnt = otcOrderDao.selectTotalOrderCount(mb.getMemberId(), OtcOrder.STATUS_FINISH, OtcEntrustOrder.ORDER_TYPE_S); + if (saleTotalCnt != null && saleTotalCnt != 0) { + BigDecimal finishRatio = BigDecimal.valueOf(saleFinishCnt).divide(BigDecimal.valueOf(saleTotalCnt), 4, BigDecimal.ROUND_DOWN); + mb.setSaleFinishRatio(finishRatio); + } + // 平均付款时间 + BigDecimal avgPayTime = otcOrderDao.selectMemberAvgPayTime(mb.getMemberId()); + // 平均放币时间 + BigDecimal avgCoinTime = otcOrderDao.selectMemberAvgCoinTime(mb.getMemberId()); + + mb.setBuyCnt(buyCnt); + mb.setTotalOrderCnt(buyTotalCnt); + mb.setSaleOrderCnt(saleTotalCnt); + mb.setAvgPayTime(avgPayTime.intValue()); + mb.setAvgCoinTime(avgCoinTime.intValue()); + + otcMarketBussinessDao.updateById(mb); + } + } + } + +} -- Gitblit v1.9.1