From c44e660304d6599d90e23da0e52f2c734a81c2ec Mon Sep 17 00:00:00 2001
From: puzhibing <393733352@qq.com>
Date: 星期日, 29 九月 2024 18:00:51 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/TShoppingOrderServiceImpl.java |   53 ++++++++++++-----------------------------------------
 1 files changed, 12 insertions(+), 41 deletions(-)

diff --git a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/TShoppingOrderServiceImpl.java b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/TShoppingOrderServiceImpl.java
index 4cba3df..a0a8fb9 100644
--- a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/TShoppingOrderServiceImpl.java
+++ b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/TShoppingOrderServiceImpl.java
@@ -364,6 +364,9 @@
         shoppingOrderRefund.setRefundRemark("全额退款");
         shoppingOrderRefund.setRefundTotalAmount(refundAmount.add(bigDecimal));
         shoppingOrderRefund.setPayAmount(shoppingOrder.getPaymentAmount());
+    
+        shoppingOrder.setCancellationTime(LocalDateTime.now());
+        shoppingOrder.setCancellationId(shoppingOrder.getAppUserId());
         if(1 == paymentType){
             WxPaymentRefundModel model = new WxPaymentRefundModel();
             model.setOut_trade_no(shoppingOrder.getCode());
@@ -378,6 +381,7 @@
             model.setAmount(amount);
             R<String> orderR = wxPaymentClient.refundOrderR(model);
             if(200 == orderR.getCode()){
+                this.updateById(shoppingOrder);
                 shoppingOrderRefundService.save(shoppingOrderRefund);
             }
         }
@@ -389,49 +393,9 @@
             dto.setRefundReason("取消订单");
             RefundResp resp = aliPaymentClient.refund(dto).getData();
             if(null != resp){
+                this.updateById(shoppingOrder);
                 SimpleDateFormat sdf1 = new SimpleDateFormat("yyyy-MM-DDTHH:mm:ss+TIMEZONE");
                 AjaxResult success = cancelShoppingOrderWxRefund(resp.getOutTradeNo(), resp.getTradeNo(), "SUCCESS", sdf1.format(new Date()));
-                if(success.isSuccess()){
-                    shoppingOrderRefundService.save(shoppingOrderRefund);
-                    //商品
-                    if(shoppingOrder.getOrderType() == 1){
-                        //redis锁 和支付使用同一个锁
-                        RedisLock redisLock = new RedisLock(redisTemplate, "SHOPPING_GOODS_LOCK", 5, 30000);
-                        try {
-                            redisLock.lock();
-                            TGoods goods = goodsClient.getGoodsById(shoppingOrder.getGoodsId()).getData();
-                            Integer inventory = goods.getInventory();
-                            if(-1 != inventory){
-                                goods.setInventory(inventory + shoppingOrder.getPurchaseQuantity());
-                                goodsClient.updateGoods(goods);
-                            }
-                        }catch (Exception e){
-                            e.printStackTrace();
-                        }finally {
-                            //解锁
-                            redisLock.unlock();
-                        }
-                    }
-                    //优惠券
-                    if(shoppingOrder.getOrderType() == 2){
-                        //redis锁 和支付使用同一个锁
-                        RedisLock redisLock = new RedisLock(redisTemplate, "SHOPPING_COUPON_LOCK", 5, 30000);
-                        try {
-                            redisLock.lock();
-                            TCoupon coupon = couponClient.getCouponById1(shoppingOrder.getCouponId()).getData();
-                            Integer inventory = coupon.getInventoryQuantity();
-                            if(-1 != inventory){
-                                coupon.setInventoryQuantity(inventory + shoppingOrder.getPurchaseQuantity());
-                                couponClient.updateCoupon(coupon);
-                            }
-                        }catch (Exception e){
-                            e.printStackTrace();
-                        }finally {
-                            //解锁
-                            redisLock.unlock();
-                        }
-                    }
-                }
             }
         }
         return AjaxResult.success();
@@ -457,6 +421,13 @@
             shoppingOrderRefundService.updateById(one);
             //判断是否需要回退库存
             TShoppingOrder shoppingOrder = this.getById(one.getShoppingOrderId());
+            shoppingOrder.setStatus(4);
+            shoppingOrder.setRefundCode(one.getRefundSerialNumber());
+            shoppingOrder.setRefundAmount(one.getRefundAmount());
+            shoppingOrder.setRefundStatus(2);
+            shoppingOrder.setRefundTime(one.getRefundTime());
+            this.updateById(shoppingOrder);
+            
             //商品
             if(shoppingOrder.getOrderType() == 1){
                 //redis锁 和支付使用同一个锁

--
Gitblit v1.7.1