From ab4f788aaba47910e3edf0fe1b001e56cdea26db Mon Sep 17 00:00:00 2001 From: Helius <wangdoubleone@gmail.com> Date: Thu, 20 May 2021 16:54:19 +0800 Subject: [PATCH] modify --- src/main/java/com/xcong/excoin/modules/otc/service/impl/OtcOrderServiceImpl.java | 158 ++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 158 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 0025b82..f0838ba 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 @@ -1,23 +1,34 @@ package com.xcong.excoin.modules.otc.service.impl; import cn.hutool.core.bean.BeanUtil; +import cn.hutool.core.util.StrUtil; +import cn.hutool.crypto.SecureUtil; import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.xcong.excoin.common.LoginUserUtils; import com.xcong.excoin.common.exception.GlobalException; +import com.xcong.excoin.common.response.Result; import com.xcong.excoin.common.system.service.CommonService; +import com.xcong.excoin.modules.member.dao.MemberDao; +import com.xcong.excoin.modules.member.dao.MemberPaymentMethodDao; import com.xcong.excoin.modules.member.dao.MemberWalletCoinDao; import com.xcong.excoin.modules.member.entity.MemberEntity; +import com.xcong.excoin.modules.member.entity.MemberPaymentMethodEntity; 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.dto.HasPayDto; import com.xcong.excoin.modules.otc.dto.OrderAddDto; import com.xcong.excoin.modules.otc.dto.OrderListDto; 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.dao.OtcOrderDao; import com.xcong.excoin.modules.otc.service.OtcOrderService; +import com.xcong.excoin.modules.otc.vo.BuyOrderDetailVo; import com.xcong.excoin.modules.otc.vo.OrderListVo; +import com.xcong.excoin.modules.otc.vo.SaleOrderDetailVo; import lombok.RequiredArgsConstructor; import lombok.extern.slf4j.Slf4j; import org.springframework.context.annotation.Bean; @@ -26,15 +37,20 @@ import java.math.BigDecimal; import java.util.Date; +import java.util.List; @Slf4j @Service @RequiredArgsConstructor public class OtcOrderServiceImpl extends ServiceImpl<OtcOrderDao, OtcOrder> implements OtcOrderService { + private final OtcMarketBussinessDao otcMarketBussinessDao; private final OtcEntrustOrderDao otcEntrustOrderDao; private final CommonService commonService; private final MemberWalletCoinDao memberWalletCoinDao; + private final MemberDao memberDao; + private final MemberPaymentMethodDao memberPaymentMethodDao; + @Override @Transactional(rollbackFor = Exception.class) @@ -93,6 +109,15 @@ throw new GlobalException("无法出售"); } + if (StrUtil.isBlank(orderAddDto.getPassword())) { + throw new GlobalException("资金密码不能为空"); + } + + MemberEntity memberEntity = memberDao.selectById(member.getId()); + if (!SecureUtil.md5(orderAddDto.getPassword()).equals(memberEntity.getTradePassword())) { + throw new GlobalException("资金密码错误"); + } + BigDecimal cny = orderAddDto.getUsdtAmount().multiply(entrustOrder.getUnitPrice()); if (cny.compareTo(orderAddDto.getCnyAmount()) != 0) { throw new GlobalException("数量与金额不符"); @@ -137,4 +162,137 @@ order.setMemberId(member.getId()); return this.baseMapper.selectOrdderListInPage(order, page); } + + @Override + public void hasPay(HasPayDto hasPayDto) { + MemberEntity member = LoginUserUtils.getAppLoginUser(); + OtcOrder otcOrder = this.baseMapper.selectById(hasPayDto.getId()); + + if (otcOrder == null) { + throw new GlobalException("订单不存在"); + } + + if (!OtcOrder.STATUS_SUBMIT.equals(otcOrder.getStatus())) { + throw new GlobalException("状态不正确"); + } + + if (!OtcEntrustOrder.ORDER_TYPE_B.equals(otcOrder.getOrderType())) { + throw new GlobalException("不是购买单"); + } + + if (StrUtil.isBlank(hasPayDto.getName())) { + MemberPaymentMethodEntity defualtMethod = memberPaymentMethodDao.selectDefualtMethod(member.getId(), 3, "1"); + hasPayDto.setName(defualtMethod.getName()); + } + + this.baseMapper.updateOrderStatusByOrderNo(OtcOrder.STATUS_PAY, hasPayDto.getName(), 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, null, otcOrder.getOrderNo()); + } + + @Override + public Result findBuyOrderDetail(Long id) { + MemberEntity member = LoginUserUtils.getAppLoginUser(); + member = memberDao.selectById(member.getId()); + OtcOrder otcOrder = this.baseMapper.selectById(id); + if (otcOrder == null) { + return Result.fail("订单不存在"); + } + + OtcOrder buyOrder = this.baseMapper.selectOrderByOrderNoAndType(otcOrder.getOrderNo(), OtcEntrustOrder.ORDER_TYPE_B); + if (buyOrder == null) { + return Result.fail("参数错误"); + } + + BuyOrderDetailVo buyDetail = new BuyOrderDetailVo(); + buyDetail.setOrderNo(buyOrder.getOrderNo()); + buyDetail.setUsdtAmount(buyOrder.getCoinAmount()); + buyDetail.setStatus(buyOrder.getStatus()); + buyDetail.setTotalAmount(buyOrder.getTotalAmount()); + buyDetail.setUnitPrice(buyOrder.getUnitPrice()); + buyDetail.setCreateTime(new Date()); + buyDetail.setIsMb(member.getIsTrader()); + + OtcOrder saleOrder = this.baseMapper.selectOrderByOrderNoAndType(otcOrder.getOrderNo(), OtcEntrustOrder.ORDER_TYPE_S); + MemberEntity saleMember = memberDao.selectById(saleOrder.getMemberId()); + + buyDetail.setSaleName(saleMember.getName()); + MemberPaymentMethodEntity defaultMethod = memberPaymentMethodDao.selectDefualtMethod(saleOrder.getMemberId(), 3, "1"); + buyDetail.setBankName(defaultMethod.getName()); + buyDetail.setBankNo(defaultMethod.getAccount()); + buyDetail.setPayName(defaultMethod.getName()); + buyDetail.setPayTime(buyDetail.getPayTime()); + + if (!buyOrder.getMemberId().equals(buyOrder.getEntrustMemberId())) { + OtcMarketBussiness otcMb = otcMarketBussinessDao.selectMarketBussinessByMemberId(buyOrder.getEntrustMemberId()); + buyDetail.setMbId(otcMb.getId()); + buyDetail.setFinishRatio(otcMb.getFinishRatio()); + buyDetail.setOrderCnt(otcMb.getBuyCnt()); + } + + return Result.ok(buyDetail); + } + + @Override + public Result findSaleOrderDetail(Long id) { + MemberEntity member = LoginUserUtils.getAppLoginUser(); + OtcOrder otcOrder = this.baseMapper.selectById(id); + if (otcOrder == null) { + return Result.fail("订单不存在"); + } + + OtcOrder saleOrder = this.baseMapper.selectOrderByOrderNoAndType(otcOrder.getOrderNo(), OtcEntrustOrder.ORDER_TYPE_S); + if (saleOrder == null) { + return Result.fail("参数错误"); + } + + SaleOrderDetailVo saleDetail = new SaleOrderDetailVo(); + saleDetail.setOrderNo(saleOrder.getOrderNo()); + saleDetail.setUsdtAmount(saleOrder.getCoinAmount()); + saleDetail.setStatus(saleOrder.getStatus()); + saleDetail.setTotalAmount(saleOrder.getTotalAmount()); + saleDetail.setUnitPrice(saleOrder.getUnitPrice()); + saleDetail.setCreateTime(new Date()); + saleDetail.setIsMb(member.getIsTrader()); + saleDetail.setPayName(saleOrder.getPayName()); + + if (!saleOrder.getMemberId().equals(saleOrder.getEntrustMemberId())) { + OtcMarketBussiness otcMb = otcMarketBussinessDao.selectMarketBussinessByMemberId(saleOrder.getEntrustMemberId()); + saleDetail.setMbId(otcMb.getId()); + saleDetail.setFinishRatio(otcMb.getFinishRatio()); + saleDetail.setOrderCnt(otcMb.getBuyCnt()); + } + + return Result.ok(saleDetail); + } } -- Gitblit v1.9.1