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