From 57cddad3c7841774720eb3112259b0d5b64d3059 Mon Sep 17 00:00:00 2001 From: Helius <wangdoubleone@gmail.com> Date: Thu, 20 May 2021 10:17:37 +0800 Subject: [PATCH] modify --- src/main/java/com/xcong/excoin/modules/otc/service/impl/OtcOrderServiceImpl.java | 45 +++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 45 insertions(+), 0 deletions(-) diff --git a/src/main/java/com/xcong/excoin/modules/otc/service/impl/OtcOrderServiceImpl.java b/src/main/java/com/xcong/excoin/modules/otc/service/impl/OtcOrderServiceImpl.java index 23c9c20..b58f507 100644 --- a/src/main/java/com/xcong/excoin/modules/otc/service/impl/OtcOrderServiceImpl.java +++ b/src/main/java/com/xcong/excoin/modules/otc/service/impl/OtcOrderServiceImpl.java @@ -29,6 +29,7 @@ import java.math.BigDecimal; import java.util.Date; +import java.util.List; @Slf4j @Service @@ -155,6 +156,50 @@ public void hasPay(Long id) { OtcOrder otcOrder = this.baseMapper.selectById(id); + if (otcOrder == null) { + throw new GlobalException("订单不存在"); + } + + if (OtcOrder.STATUS_PAY.equals(otcOrder.getStatus())) { + throw new GlobalException("状态不正确"); + } + + if (OtcEntrustOrder.ORDER_TYPE_B.equals(otcOrder.getOrderType())) { + throw new GlobalException("不是购买单"); + } + + this.baseMapper.updateOrderStatusByOrderNo(OtcOrder.STATUS_PAY, otcOrder.getOrderNo()); + } + + @Override + @Transactional(rollbackFor = Exception.class) + public void finishOrder(Long id) { + MemberEntity member = LoginUserUtils.getAppLoginUser(); + OtcOrder otcOrder = this.baseMapper.selectById(id); + + if (otcOrder == null) { + throw new GlobalException("订单不存在"); + } + + if (OtcOrder.STATUS_PAY.equals(otcOrder.getStatus())) { + throw new GlobalException("状态不正确"); + } + + if (OtcEntrustOrder.ORDER_TYPE_S.equals(otcOrder.getOrderType())) { + throw new GlobalException("不是购买单"); + } + + OtcOrder buyOrder = this.baseMapper.selectOrderByOrderNoAndType(otcOrder.getOrderNo(), OtcEntrustOrder.ORDER_TYPE_B); + OtcOrder saleOrder = this.baseMapper.selectOrderByOrderNoAndType(otcOrder.getOrderNo(), OtcEntrustOrder.ORDER_TYPE_S); + MemberWalletCoinEntity buyWallet = memberWalletCoinDao.selectWalletCoinBymIdAndCode(buyOrder.getMemberId(), "USDT"); + MemberWalletCoinEntity saleWallet = memberWalletCoinDao.selectWalletCoinBymIdAndCode(saleOrder.getMemberId(), "USDT"); + + // 购买者钱包可用新增币 + memberWalletCoinDao.updateBlockBalance(buyWallet.getId(), buyOrder.getCoinAmount(), BigDecimal.ZERO, 0); + + // 出售者钱包冻结减少币 + memberWalletCoinDao.reduceFrozenBalance(saleWallet.getId(), buyOrder.getCoinAmount()); + this.baseMapper.updateOrderStatusByOrderNo(OtcOrder.STATUS_PAY, otcOrder.getOrderNo()); } } -- Gitblit v1.9.1