From cd55aff7eea06f77a8f712cef1ad2744c44d0f8a Mon Sep 17 00:00:00 2001 From: mitao <2763622819@qq.com> Date: 星期四, 20 六月 2024 18:56:16 +0800 Subject: [PATCH] 1.修改bug --- ruoyi-modules/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/OrderAuctionBondServiceImpl.java | 129 ++++++++++++++++++++++++++++++++++-------- 1 files changed, 104 insertions(+), 25 deletions(-) diff --git a/ruoyi-modules/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/OrderAuctionBondServiceImpl.java b/ruoyi-modules/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/OrderAuctionBondServiceImpl.java index f3eebc8..9ec9827 100644 --- a/ruoyi-modules/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/OrderAuctionBondServiceImpl.java +++ b/ruoyi-modules/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/OrderAuctionBondServiceImpl.java @@ -2,30 +2,39 @@ import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.toolkit.Wrappers; +import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.ruoyi.common.core.constant.SecurityConstants; import com.ruoyi.common.core.domain.R; import com.ruoyi.common.core.enums.AuctionOrderTypeEnum; import com.ruoyi.common.core.enums.BondStatusEnum; import com.ruoyi.common.core.enums.PaymentMethodEnum; +import com.ruoyi.common.core.utils.StringUtils; +import com.ruoyi.order.domain.Paylog; +import com.ruoyi.order.mapper.OrderAuctionBondMapper; +import com.ruoyi.order.service.IOrderAuctionBondService; +import com.ruoyi.order.service.IPaylogService; import com.ruoyi.order.util.OrderUtil; +import com.ruoyi.order.util.SinataUtil; import com.ruoyi.system.api.domain.AuctionGoods; import com.ruoyi.system.api.domain.AuctionSalesroom; import com.ruoyi.system.api.domain.OrderAuctionBond; -import com.ruoyi.order.domain.pojo.Paylog; -import com.ruoyi.order.mapper.OrderAuctionBondMapper; -import com.ruoyi.order.service.IOrderAuctionBondService; -import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; -import com.ruoyi.order.service.IPaylogService; -import com.ruoyi.order.util.SinataUtil; import com.ruoyi.system.api.domain.dto.MemberAuctionSalesroomBondDTO; import com.ruoyi.system.api.domain.dto.OrderAuctionBondDTO; +import com.ruoyi.system.api.domain.dto.RefundDTO; import com.ruoyi.system.api.domain.vo.PayInfoVO; import com.ruoyi.system.api.feignClient.AuctionClient; +import java.util.ArrayList; +import java.util.List; +import java.util.Map; +import java.util.Objects; +import java.util.Set; +import java.util.stream.Collectors; +import javax.annotation.Resource; +import lombok.extern.slf4j.Slf4j; import org.apache.poi.ss.formula.functions.T; import org.springframework.stereotype.Service; - -import javax.annotation.Resource; -import java.util.List; +import org.springframework.transaction.annotation.Propagation; +import org.springframework.transaction.annotation.Transactional; /** * <p> @@ -35,11 +44,9 @@ * @author mitao * @since 2024-05-16 */ +@Slf4j @Service public class OrderAuctionBondServiceImpl extends ServiceImpl<OrderAuctionBondMapper, OrderAuctionBond> implements IOrderAuctionBondService { - - @Resource - private IOrderAuctionBondService iOrderAuctionBondService; @Resource private IPaylogService iPaylogService; @@ -59,7 +66,7 @@ wrapper.notIn(OrderAuctionBond::getMemberId, orderAuctionBondDTO.getUserList()); wrapper.eq(OrderAuctionBond::getDelFlag, 0); wrapper.eq(OrderAuctionBond::getAuctionSalesroomId, orderAuctionBondDTO.getAuctionSalesroomId()); - List<OrderAuctionBond> orderAuctionBondList = iOrderAuctionBondService.list(wrapper); + List<OrderAuctionBond> orderAuctionBondList = this.list(wrapper); for (OrderAuctionBond orderAuctionBond : orderAuctionBondList) { LambdaQueryWrapper<Paylog> wrapper1 = Wrappers.lambdaQuery(); wrapper1.eq(Paylog::getOutTradeNo, orderAuctionBond.getOrderNo()); @@ -85,20 +92,53 @@ return R.ok(); } + /** + * 查询保证金订单列表 + * + * @param id 拍卖商品id + * @param auctionOrderTypeEnum 拍卖类型: 普通拍品 拍卖会拍品 + * @param bondStatusEnum 保证金状态 待支付 已支付 已退款 为null则查询所有 + * @return List<OrderAuctionBond> + */ + @Override + public List<OrderAuctionBond> getOrderAuctionBondList(Long id, + AuctionOrderTypeEnum auctionOrderTypeEnum, BondStatusEnum bondStatusEnum) { + return this.lambdaQuery().eq(OrderAuctionBond::getAuctionGoodsId, id) + .eq(OrderAuctionBond::getBondType, auctionOrderTypeEnum).eq( + StringUtils.isNotNull(bondStatusEnum), OrderAuctionBond::getBoundStatus, + bondStatusEnum).list(); + } + + /** + * 批量更新保证金订单状态 + * + * @param ids 保证金订单id列表 + * @param bondStatusEnum 保证金状态 + */ + @Override + @Transactional(propagation = Propagation.REQUIRES_NEW) + public void updateOrderAuctionBondStatus(List<Long> ids, BondStatusEnum bondStatusEnum) { + for (Long id:ids){ + OrderAuctionBond byId = this.getById(id); + byId.setBoundStatus(bondStatusEnum); + this.updateById(byId); + } + } + @Override public PayInfoVO SaveOrderAuctionBond(MemberAuctionSalesroomBondDTO memberAuctionSalesroomBondDTO) { PayInfoVO payInfoVO = new PayInfoVO(); - if (memberAuctionSalesroomBondDTO.getBondType() == 2) { - AuctionSalesroom data = auctionClient.getauctionSalesroomOne(memberAuctionSalesroomBondDTO.getAuctionSalesroomId(), SecurityConstants.INNER).getData(); - if (data.getBound().intValue() == 0) { + if (memberAuctionSalesroomBondDTO.getBondType() == 1) { + AuctionGoods data = auctionClient.getauctionGoodsOne(memberAuctionSalesroomBondDTO, SecurityConstants.INNER).getData(); + if (data.getBond().intValue() == 0) { OrderAuctionBond orderAuctionBond = new OrderAuctionBond(); orderAuctionBond.setOrderNo(OrderUtil.getOrderNoForPrefix("BO")); - orderAuctionBond.setAuctionSalesroomId(memberAuctionSalesroomBondDTO.getAuctionSalesroomId()); + orderAuctionBond.setAuctionGoodsId(memberAuctionSalesroomBondDTO.getAuctionGoodsId()); orderAuctionBond.setMemberId(memberAuctionSalesroomBondDTO.getMemberId()); - orderAuctionBond.setBond(data.getBound()); + orderAuctionBond.setBond(data.getBond()); orderAuctionBond.setBoundStatus(BondStatusEnum.PAID); orderAuctionBond.setBondType(AuctionOrderTypeEnum.AUCTION_ITEMS); - iOrderAuctionBondService.save(orderAuctionBond); + this.save(orderAuctionBond); payInfoVO.setOrderNO(orderAuctionBond.getOrderNo()); payInfoVO.setType(0); payInfoVO.setSubject("保证金"); @@ -107,9 +147,9 @@ } else { OrderAuctionBond orderAuctionBond = new OrderAuctionBond(); orderAuctionBond.setOrderNo(OrderUtil.getOrderNoForPrefix("BO")); - orderAuctionBond.setAuctionSalesroomId(memberAuctionSalesroomBondDTO.getAuctionSalesroomId()); + orderAuctionBond.setAuctionGoodsId(memberAuctionSalesroomBondDTO.getAuctionGoodsId()); orderAuctionBond.setMemberId(memberAuctionSalesroomBondDTO.getMemberId()); - orderAuctionBond.setBond(data.getBound()); + orderAuctionBond.setBond(data.getBond()); orderAuctionBond.setBoundStatus(BondStatusEnum.TO_PLAY); orderAuctionBond.setBondType(AuctionOrderTypeEnum.AUCTION_ITEMS); if (memberAuctionSalesroomBondDTO.getPaymentMethod() == 1) { @@ -118,7 +158,7 @@ orderAuctionBond.setPaymentMethod(PaymentMethodEnum.ALIPAY); } - iOrderAuctionBondService.save(orderAuctionBond); + this.save(orderAuctionBond); payInfoVO.setOrderNO(orderAuctionBond.getOrderNo()); if (memberAuctionSalesroomBondDTO.getPaymentMethod() == 1) { @@ -131,7 +171,8 @@ payInfoVO.setBody("保证金"); } } else { - AuctionGoods data = auctionClient.getauctionGoodsOne(memberAuctionSalesroomBondDTO.getAuctionGoodsId(), SecurityConstants.INNER).getData(); + AuctionSalesroom data = auctionClient.getauctionSalesroomOne(memberAuctionSalesroomBondDTO, SecurityConstants.INNER).getData(); + if (data.getBond().intValue() == 0) { OrderAuctionBond orderAuctionBond = new OrderAuctionBond(); orderAuctionBond.setOrderNo(OrderUtil.getOrderNoForPrefix("BO")); @@ -140,7 +181,7 @@ orderAuctionBond.setBond(data.getBond()); orderAuctionBond.setBoundStatus(BondStatusEnum.PAID); orderAuctionBond.setBondType(AuctionOrderTypeEnum.AUCTION_ITEMS); - iOrderAuctionBondService.save(orderAuctionBond); + this.save(orderAuctionBond); payInfoVO.setOrderNO(orderAuctionBond.getOrderNo()); payInfoVO.setType(0); payInfoVO.setSubject("保证金"); @@ -159,7 +200,7 @@ } else { orderAuctionBond.setPaymentMethod(PaymentMethodEnum.ALIPAY); } - iOrderAuctionBondService.save(orderAuctionBond); + this.save(orderAuctionBond); payInfoVO.setOrderNO(orderAuctionBond.getOrderNo()); if (memberAuctionSalesroomBondDTO.getPaymentMethod() == 1) { payInfoVO.setType(2); @@ -173,4 +214,42 @@ } return payInfoVO; } + + @Override + @Transactional(rollbackFor = Exception.class, propagation = Propagation.REQUIRES_NEW) + public void returnBondByAuctionGoodsId(Long id) { + List<OrderAuctionBond> list = this.lambdaQuery().eq(OrderAuctionBond::getAuctionGoodsId, id) + .eq(OrderAuctionBond::getBoundStatus, BondStatusEnum.PAID).list(); + Set<String> orderNoSet = list.stream().map(OrderAuctionBond::getOrderNo) + .collect(Collectors.toSet()); + List<RefundDTO> refundDTOList = list.stream().map(item -> { + RefundDTO refundDTO = new RefundDTO(); + refundDTO.setAmount(item.getBond()); + refundDTO.setOrderNo(item.getOrderNo()); + return refundDTO; + }).collect(Collectors.toList()); + Map<String, Object> data = iPaylogService.refund(refundDTOList); + // 处理退款返回结果 + List<String> successfulOrders = new ArrayList<>(); + List<String> failedOrders = new ArrayList<>(); + + data.forEach((key, value) -> { + if ((boolean) value) { + successfulOrders.add(key); + } else { + failedOrders.add(key); + } + }); + log.info("订单号:{},退款失败", failedOrders); + // 退款成功的订单修改状态 + List<OrderAuctionBond> collect = list.stream().map(bond -> { + if (successfulOrders.contains(bond.getOrderNo())) { + bond.setBoundStatus(BondStatusEnum.REFUNDED); + return bond; + } + return null; + }).filter(Objects::nonNull).collect(Collectors.toList()); + this.updateBatchById(collect); + } + } -- Gitblit v1.7.1