From 6b53b5915b10b0568bb5b44ee35679ece3c476ce Mon Sep 17 00:00:00 2001
From: puzhibing <393733352@qq.com>
Date: 星期三, 21 八月 2024 17:05:21 +0800
Subject: [PATCH] Merge branch 'master' of http://120.76.84.145:10101/gitblit/r/java/mx_charging_pile

---
 ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/TChargingOrderController.java |  104 +++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 103 insertions(+), 1 deletions(-)

diff --git a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/TChargingOrderController.java b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/TChargingOrderController.java
index eac5cd5..d8c37ed 100644
--- a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/TChargingOrderController.java
+++ b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/TChargingOrderController.java
@@ -4,6 +4,7 @@
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.ruoyi.chargingPile.api.vo.SiteVO;
 import com.ruoyi.common.core.domain.R;
+import com.ruoyi.common.redis.service.RedisService;
 import com.ruoyi.common.security.service.TokenService;
 import com.ruoyi.common.core.web.domain.AjaxResult;
 import com.ruoyi.common.core.web.page.BasePage;
@@ -17,15 +18,21 @@
 import com.ruoyi.order.dto.MyChargingOrderInfo;
 import com.ruoyi.order.dto.MyChargingOrderList;
 import com.ruoyi.order.dto.OrderEvaluateVo;
+import com.ruoyi.order.dto.*;
 import com.ruoyi.order.service.TChargingOrderService;
 import com.ruoyi.order.service.TOrderEvaluateService;
 import com.ruoyi.order.service.TOrderEvaluateTagService;
+import com.ruoyi.payment.api.feignClient.WxPaymentClient;
 import io.swagger.annotations.Api;
+import io.swagger.annotations.ApiImplicitParam;
+import io.swagger.annotations.ApiImplicitParams;
 import org.springframework.beans.factory.annotation.Autowired;
 import io.swagger.annotations.ApiOperation;
 import org.springframework.web.bind.annotation.*;
 
 import javax.annotation.Resource;
+import javax.servlet.http.HttpServletRequest;
+import javax.servlet.http.HttpServletResponse;
 import java.util.List;
 import java.util.Map;
 import java.util.List;
@@ -51,6 +58,15 @@
     private TOrderEvaluateService orderEvaluateService;
     @Autowired
     private TOrderEvaluateTagService orderEvaluateTagService;
+    
+    @Resource
+    private WxPaymentClient wxPaymentClient;
+    
+    @Resource
+    private RedisService redisService;
+    
+    
+    
 
     @ResponseBody
     @PostMapping(value = "/chargingOrder")
@@ -150,10 +166,96 @@
     @ResponseBody
     @GetMapping(value = "/getNoInvoicedOrder")
     @ApiOperation(value = "获取未开票的订单数据", tags = {"小程序-充电发票"})
-    public AjaxResult<List<MyChargingOrderList>> getNoInvoicedOrder(@RequestBody GetNoInvoicedOrder query){
+    public AjaxResult<List<MyChargingOrderList>> getNoInvoicedOrder(GetNoInvoicedOrder query){
         List<MyChargingOrderList> list = chargingOrderService.getNoInvoicedOrder(query);
         return AjaxResult.success(list);
     }
     
+    
+    
+    @ResponseBody
+    @PostMapping(value = "/paymentChargingOrder")
+    @ApiOperation(value = "支付充电充值费用", tags = {"小程序-扫一扫"})
+    public AjaxResult paymentChargingOrder(AddChargingOrder addChargingOrder){
+        return chargingOrderService.paymentChargingOrder(addChargingOrder);
+    }
+    
+    /**
+     * 充电充值支付回调
+     * @param request
+     */
+    @ResponseBody
+    @PostMapping(value = "/chargingOrderWXCallback")
+    public void chargingOrderWXCallback(HttpServletRequest request){
+        Map<String, Object> data = wxPaymentClient.payNotify(request).getData();
+        if(null != data){
+            String out_trade_no = data.get("out_trade_no").toString();
+            String transaction_id = data.get("transaction_id").toString();
+            String attach = data.get("attach").toString();
+            AjaxResult ajaxResult = chargingOrderService.chargingOrderCallback(1, out_trade_no, transaction_id, attach);
+            if(ajaxResult.isSuccess()){
+                wxPaymentClient.ack();
+            }
+        }
+    }
+    
+    
+    /**
+     * 支付宝支付成功后的回调
+     * @param request
+     */
+    @ResponseBody
+    @PostMapping(value = "/chargingOrderALICallback")
+    public void chargingOrderALICallback(HttpServletRequest request){
+        Map<String, Object> data = wxPaymentClient.payNotify(request).getData();
+        if(null != data){
+            String out_trade_no = data.get("out_trade_no").toString();
+            String transaction_id = data.get("transaction_id").toString();
+            String attach = data.get("attach").toString();
+            AjaxResult ajaxResult = chargingOrderService.chargingOrderCallback(2, out_trade_no, transaction_id, attach);
+            if(ajaxResult.isSuccess()){
+            
+            }
+        }
+    }
+    
+    
+    
+    @ResponseBody
+    @GetMapping(value = "/preChargeCheck/{id}")
+    @ApiOperation(value = "获取安全检测数据", tags = {"小程序-扫一扫"})
+    @ApiImplicitParams({
+            @ApiImplicitParam(name = "id", value = "充电枪id", required = true)
+    })
+    public AjaxResult<PreChargeCheck> preChargeCheck(@PathVariable Integer id){
+        String key = "AQJC_" + id;
+        Object cacheObject = redisService.getCacheObject(key);
+        return AjaxResult.success(cacheObject);
+    }
+    
+    
+    
+    @ResponseBody
+    @GetMapping(value = "/getChargingDetails/{id}")
+    @ApiOperation(value = "获取充电中页面数据", tags = {"小程序-扫一扫"})
+    @ApiImplicitParams({
+            @ApiImplicitParam(name = "id", value = "充电枪id", required = true)
+    })
+    public AjaxResult<ChargingDetails> getChargingDetails(@PathVariable Integer id){
+        ChargingDetails chargingDetails = chargingOrderService.getChargingDetails(id);
+        return AjaxResult.success(chargingDetails);
+    }
+    
+    
+    
+    @ResponseBody
+    @PutMapping(value = "/stopCharging/{id}")
+    @ApiOperation(value = "手动停止充电", tags = {"小程序-扫一扫"})
+    @ApiImplicitParams({
+            @ApiImplicitParam(name = "id", value = "订单id", required = true)
+    })
+    public AjaxResult stopCharging(@PathVariable String id){
+        return chargingOrderService.stopCharging(id);
+    }
 }
 

--
Gitblit v1.7.1