src/main/java/com/xcong/excoin/modules/otc/controller/OtcOrderController.java
@@ -3,12 +3,17 @@ import com.baomidou.mybatisplus.core.metadata.IPage; import com.xcong.excoin.common.response.Result; 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.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 io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; import io.swagger.annotations.ApiResponse; import io.swagger.annotations.ApiResponses; import lombok.RequiredArgsConstructor; import lombok.extern.slf4j.Slf4j; import org.apache.ibatis.annotations.Param; @@ -47,21 +52,27 @@ } @ApiOperation(value = "买单 - 订单详情") @ApiResponses({ @ApiResponse(code = 200, message = "success", response = BuyOrderDetailVo.class) }) @GetMapping(value = "/buyOrderDetail/{id}") public Result buyOrderDetail(@PathVariable("id") Long id) { return null; return otcOrderService.findBuyOrderDetail(id); } @ApiOperation(value = "卖单 - 订单详情") @GetMapping(value = "/saleOrderDetail") @ApiResponses({ @ApiResponse(code = 200, message = "success", response = SaleOrderDetailVo.class) }) @GetMapping(value = "/saleOrderDetail/{id}") public Result saleOrderDetail(@PathVariable("id") Long id) { return null; return otcOrderService.findSaleOrderDetail(id); } @ApiOperation(value = "已付款,请放币") @PostMapping(value = "/hasPay/{id}") public Result hasPay(@PathVariable("id") Long id) { otcOrderService.hasPay(id); @PostMapping(value = "/hasPay") public Result hasPay(@RequestBody HasPayDto hasPayDto) { otcOrderService.hasPay(hasPayDto); return Result.ok("操作成功"); } src/main/java/com/xcong/excoin/modules/otc/dao/OtcOrderDao.java
@@ -15,7 +15,7 @@ IPage<OrderListVo> selectOrdderListInPage(@Param("record") OtcOrder order, Page<OrderListVo> page); int updateOrderStatusByOrderNo(@Param("status") Integer status, @Param("orderNo") String orderNo); int updateOrderStatusByOrderNo(@Param("status") Integer status, @Param("payName") String payName, @Param("orderNo") String orderNo); OtcOrder selectOrderByOrderNoAndType(String orderNo, String orderType); } src/main/java/com/xcong/excoin/modules/otc/dto/HasPayDto.java
New file @@ -0,0 +1,16 @@ package com.xcong.excoin.modules.otc.dto; import io.swagger.annotations.ApiModel; import io.swagger.annotations.ApiModelProperty; import lombok.Data; @Data @ApiModel(value = "HasPayDto", description = "已付款接口接收参数类") public class HasPayDto { @ApiModelProperty(value = "订单ID", example = "1") private Long id; @ApiModelProperty(value = "姓名", example = "张三") private String name; } src/main/java/com/xcong/excoin/modules/otc/service/OtcEntrustOrderService.java
@@ -24,4 +24,5 @@ void cancelEntrustOrder(Long id); Result findEntrustOrderDetail(Long id); } src/main/java/com/xcong/excoin/modules/otc/service/OtcOrderService.java
@@ -2,6 +2,8 @@ import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.extension.service.IService; import com.xcong.excoin.common.response.Result; 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.OtcOrder; @@ -15,7 +17,11 @@ IPage<OrderListVo> findOrderListInPage(OrderListDto orderListDto); void hasPay(Long id); void hasPay(HasPayDto hasPayDto); void finishOrder(Long id); Result findBuyOrderDetail(Long id); Result findSaleOrderDetail(Long id); } src/main/java/com/xcong/excoin/modules/otc/service/impl/OtcOrderServiceImpl.java
@@ -8,19 +8,27 @@ 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; @@ -36,10 +44,13 @@ @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) @@ -153,8 +164,9 @@ } @Override public void hasPay(Long id) { OtcOrder otcOrder = this.baseMapper.selectById(id); public void hasPay(HasPayDto hasPayDto) { MemberEntity member = LoginUserUtils.getAppLoginUser(); OtcOrder otcOrder = this.baseMapper.selectById(hasPayDto.getId()); if (otcOrder == null) { throw new GlobalException("订单不存在"); @@ -168,7 +180,12 @@ throw new GlobalException("不是购买单"); } this.baseMapper.updateOrderStatusByOrderNo(OtcOrder.STATUS_PAY, otcOrder.getOrderNo()); 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 @@ -200,6 +217,82 @@ // 出售者钱包冻结减少币 memberWalletCoinDao.reduceFrozenBalance(saleWallet.getId(), buyOrder.getCoinAmount()); this.baseMapper.updateOrderStatusByOrderNo(OtcOrder.STATUS_PAY, otcOrder.getOrderNo()); 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); } } src/main/java/com/xcong/excoin/modules/otc/vo/BuyOrderDetailVo.java
File was renamed from src/main/java/com/xcong/excoin/modules/otc/vo/OrderDetailVo.java @@ -11,7 +11,7 @@ @Data @ApiModel(value = "OtcOrderDetailVo", description = "otc订单详情") public class OrderDetailVo { public class BuyOrderDetailVo { @ApiModelProperty(value = "交易总额") private BigDecimal totalAmount; @@ -53,4 +53,10 @@ @ApiModelProperty(value = "完成率") private BigDecimal finishRatio; @ApiModelProperty(value = "是否市商 1是 2否") private Integer isMb; @ApiModelProperty(value = "订单状态 1-已提交 2-已付款 3-完成") private Integer status; } src/main/java/com/xcong/excoin/modules/otc/vo/SaleOrderDetailVo.javacopy from src/main/java/com/xcong/excoin/modules/otc/vo/OrderDetailVo.java copy to src/main/java/com/xcong/excoin/modules/otc/vo/SaleOrderDetailVo.java
File was copied from src/main/java/com/xcong/excoin/modules/otc/vo/OrderDetailVo.java @@ -11,7 +11,7 @@ @Data @ApiModel(value = "OtcOrderDetailVo", description = "otc订单详情") public class OrderDetailVo { public class SaleOrderDetailVo { @ApiModelProperty(value = "交易总额") private BigDecimal totalAmount; @@ -29,11 +29,8 @@ @ApiModelProperty("下单时间") private Date createTime; @ApiModelProperty(value = "银行名称") private String bankName; @ApiModelProperty(value = "银行卡号") private String bankNo; @ApiModelProperty(value = "订单状态 1-已提交 2-已付款 3-完成") private Integer status; @ApiModelProperty(value = "姓名") private String payName; @@ -53,4 +50,7 @@ @ApiModelProperty(value = "完成率") private BigDecimal finishRatio; @ApiModelProperty(value = "是否市商 1是 2否") private Integer isMb; } src/main/resources/mapper/otc/OtcEntrustOrderDao.xml
@@ -24,6 +24,7 @@ </if> </if> </where> order by create_time desc </select> <select id="selectEntrustOrderByOrderType" resultType="com.xcong.excoin.modules.otc.entity.OtcEntrustOrder"> @@ -60,6 +61,7 @@ and status == #{record.status} </if> </where> order by create_time desc </select> <update id="updateRemainAmount"> src/main/resources/mapper/otc/OtcOrderDao.xml
@@ -41,6 +41,9 @@ <update id="updateOrderStatusByOrderNo"> update otc_order set status=#{status} <if test="payName != null and payName != ''"> , pay_name = #{payName} </if> where order_no=#{orderNo} </update>