From 75f0bffc3d1aea9764406dc6be4b73f36c9ebb6c Mon Sep 17 00:00:00 2001 From: Helius <wangdoubleone@gmail.com> Date: Wed, 19 May 2021 17:19:52 +0800 Subject: [PATCH] modify --- src/main/java/com/xcong/excoin/modules/otc/service/impl/OtcOrderServiceImpl.java | 127 ++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 127 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 94640c5..0025b82 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,13 +1,140 @@ package com.xcong.excoin.modules.otc.service.impl; +import cn.hutool.core.bean.BeanUtil; +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.system.service.CommonService; +import com.xcong.excoin.modules.member.dao.MemberWalletCoinDao; +import com.xcong.excoin.modules.member.entity.MemberEntity; +import com.xcong.excoin.modules.member.entity.MemberWalletCoinEntity; +import com.xcong.excoin.modules.otc.dao.OtcEntrustOrderDao; +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.OtcOrder; import com.xcong.excoin.modules.otc.dao.OtcOrderDao; import com.xcong.excoin.modules.otc.service.OtcOrderService; +import com.xcong.excoin.modules.otc.vo.OrderListVo; import lombok.RequiredArgsConstructor; +import lombok.extern.slf4j.Slf4j; +import org.springframework.context.annotation.Bean; import org.springframework.stereotype.Service; +import org.springframework.transaction.annotation.Transactional; +import java.math.BigDecimal; +import java.util.Date; + +@Slf4j @Service @RequiredArgsConstructor public class OtcOrderServiceImpl extends ServiceImpl<OtcOrderDao, OtcOrder> implements OtcOrderService { + + private final OtcEntrustOrderDao otcEntrustOrderDao; + private final CommonService commonService; + private final MemberWalletCoinDao memberWalletCoinDao; + + @Override + @Transactional(rollbackFor = Exception.class) + public void buyOrder(OrderAddDto orderAddDto) { + MemberEntity member = LoginUserUtils.getAppLoginUser(); + OtcEntrustOrder entrustOrder = otcEntrustOrderDao.selectById(orderAddDto.getId()); + if (entrustOrder == null) { + throw new GlobalException("委托单不存在"); + } + + if (!OtcEntrustOrder.ORDER_TYPE_S.equals(entrustOrder.getOrderType())) { + throw new GlobalException("无法购买"); + } + + if (orderAddDto.getUsdtAmount().compareTo(entrustOrder.getRemainCoinAmount()) > 0) { + throw new GlobalException("无足够的USDT"); + } + + BigDecimal cny = orderAddDto.getUsdtAmount().multiply(entrustOrder.getUnitPrice()); + log.info("--->{}", cny); + if (cny.compareTo(orderAddDto.getCnyAmount()) != 0) { + throw new GlobalException("数量与金额不符"); + } + + OtcOrder otcOrder = new OtcOrder(); + otcOrder.setOrderNo(commonService.generateOrderNo(member.getId())); + otcOrder.setUnitPrice(entrustOrder.getUnitPrice()); + otcOrder.setEntrustOrderId(entrustOrder.getId()); + otcOrder.setCoinAmount(orderAddDto.getUsdtAmount()); + otcOrder.setTotalAmount(orderAddDto.getCnyAmount()); + otcOrder.setMemberId(member.getId()); + otcOrder.setStatus(OtcOrder.STATUS_SUBMIT); + otcOrder.setPayTime(new Date()); + otcOrder.setEntrustMemberId(entrustOrder.getMemberId()); + otcOrder.setOrderType(OtcEntrustOrder.ORDER_TYPE_B); + + OtcOrder sale = new OtcOrder(); + BeanUtil.copyProperties(otcOrder, sale); + sale.setMemberId(entrustOrder.getMemberId()); + sale.setOrderType(OtcEntrustOrder.ORDER_TYPE_S); + otcEntrustOrderDao.updateRemainAmount(entrustOrder.getId(), orderAddDto.getUsdtAmount().negate()); + this.baseMapper.insert(otcOrder); + this.baseMapper.insert(sale); + } + + @Override + @Transactional(rollbackFor = Exception.class) + public void saleOrder(OrderAddDto orderAddDto) { + MemberEntity member = LoginUserUtils.getAppLoginUser(); + OtcEntrustOrder entrustOrder = otcEntrustOrderDao.selectById(orderAddDto.getId()); + if (entrustOrder == null) { + throw new GlobalException("委托单不存在"); + } + + if (!OtcEntrustOrder.ORDER_TYPE_B.equals(entrustOrder.getOrderType())) { + throw new GlobalException("无法出售"); + } + + BigDecimal cny = orderAddDto.getUsdtAmount().multiply(entrustOrder.getUnitPrice()); + if (cny.compareTo(orderAddDto.getCnyAmount()) != 0) { + throw new GlobalException("数量与金额不符"); + } + + MemberWalletCoinEntity wallet = memberWalletCoinDao.selectWalletCoinBymIdAndCode(member.getId(), "USDT"); + if (wallet.getAvailableBalance().compareTo(orderAddDto.getUsdtAmount()) < 0) { + throw new GlobalException("钱包余额不足"); + } + + OtcOrder otcOrder = new OtcOrder(); + otcOrder.setOrderNo(commonService.generateOrderNo(member.getId())); + otcOrder.setUnitPrice(entrustOrder.getUnitPrice()); + otcOrder.setEntrustOrderId(entrustOrder.getId()); + otcOrder.setCoinAmount(orderAddDto.getUsdtAmount()); + otcOrder.setTotalAmount(orderAddDto.getCnyAmount()); + otcOrder.setMemberId(member.getId()); + otcOrder.setStatus(OtcOrder.STATUS_SUBMIT); + otcOrder.setPayTime(new Date()); + otcOrder.setEntrustMemberId(entrustOrder.getMemberId()); + otcOrder.setOrderType(OtcEntrustOrder.ORDER_TYPE_S); + + OtcOrder buy = new OtcOrder(); + BeanUtil.copyProperties(otcOrder, buy); + buy.setMemberId(entrustOrder.getMemberId()); + buy.setOrderType(OtcEntrustOrder.ORDER_TYPE_B); + + otcEntrustOrderDao.updateRemainAmount(entrustOrder.getId(), orderAddDto.getUsdtAmount().negate()); + this.baseMapper.insert(otcOrder); + this.baseMapper.insert(buy); + + memberWalletCoinDao.updateFrozenBalance(member.getId(), wallet.getId(), orderAddDto.getUsdtAmount()); + } + + @Override + public IPage<OrderListVo> findOrderListInPage(OrderListDto orderListDto) { + MemberEntity member = LoginUserUtils.getAppLoginUser(); + Page<OrderListVo> page = new Page<>(orderListDto.getPageNum(), orderListDto.getPageSize()); + + OtcOrder order = new OtcOrder(); + order.setStatus(orderListDto.getStatus()); + order.setMemberId(member.getId()); + return this.baseMapper.selectOrdderListInPage(order, page); + } } -- Gitblit v1.9.1