From 884f5c68ac8c738f90f1ca257605cfbb5d7f12db Mon Sep 17 00:00:00 2001
From: mitao <2763622819@qq.com>
Date: 星期三, 26 六月 2024 09:09:27 +0800
Subject: [PATCH] 提交【管理后台】-工作台接口

---
 ruoyi-modules/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/OrderAuctionBondServiceImpl.java |   50 ++++++++++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 48 insertions(+), 2 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 7d1f2cc..c99179a 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
@@ -20,10 +20,17 @@
 import com.ruoyi.system.api.domain.OrderAuctionBond;
 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 org.springframework.transaction.annotation.Propagation;
@@ -37,6 +44,7 @@
  * @author mitao
  * @since 2024-05-16
  */
+@Slf4j
 @Service
 public class OrderAuctionBondServiceImpl extends ServiceImpl<OrderAuctionBondMapper, OrderAuctionBond> implements IOrderAuctionBondService {
 
@@ -149,15 +157,14 @@
                 } else {
                     orderAuctionBond.setPaymentMethod(PaymentMethodEnum.ALIPAY);
                 }
-
                 this.save(orderAuctionBond);
-
                 payInfoVO.setOrderNO(orderAuctionBond.getOrderNo());
                 if (memberAuctionSalesroomBondDTO.getPaymentMethod() == 1) {
                     payInfoVO.setType(2);
                 } else {
                     payInfoVO.setType(1);
                 }
+                payInfoVO.setOrderNO(orderAuctionBond.getOrderNo());
                 payInfoVO.setSubject("保证金");
                 payInfoVO.setMemberId(memberAuctionSalesroomBondDTO.getMemberId());
                 payInfoVO.setBody("保证金");
@@ -199,6 +206,7 @@
                 } else {
                     payInfoVO.setType(1);
                 }
+                payInfoVO.setOrderNO(orderAuctionBond.getOrderNo());
                 payInfoVO.setSubject("保证金");
                 payInfoVO.setMemberId(memberAuctionSalesroomBondDTO.getMemberId());
                 payInfoVO.setBody("保证金");
@@ -206,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