From fa0926b8af58237ca80ae95da43d29188d20b0b8 Mon Sep 17 00:00:00 2001
From: liuhaonan <31457034@qq.com>
Date: 星期三, 29 六月 2022 15:49:17 +0800
Subject: [PATCH] 充电桩

---
 ximon-admin/src/main/java/com/sandu/ximon/admin/controller/C3mOrderController.java |   39 ++++++++++++++++++++++++++++++---------
 1 files changed, 30 insertions(+), 9 deletions(-)

diff --git a/ximon-admin/src/main/java/com/sandu/ximon/admin/controller/C3mOrderController.java b/ximon-admin/src/main/java/com/sandu/ximon/admin/controller/C3mOrderController.java
index 8e416f1..16212ef 100644
--- a/ximon-admin/src/main/java/com/sandu/ximon/admin/controller/C3mOrderController.java
+++ b/ximon-admin/src/main/java/com/sandu/ximon/admin/controller/C3mOrderController.java
@@ -1,5 +1,6 @@
 package com.sandu.ximon.admin.controller;
 
+import cn.hutool.core.map.MapUtil;
 import com.sandu.common.domain.ResponseVO;
 import com.sandu.common.execption.BusinessException;
 import com.sandu.common.object.BaseConditionVO;
@@ -16,6 +17,7 @@
 import com.sandu.ximon.dao.domain.C3mOrder;
 import com.sandu.ximon.dao.enums.OrderType;
 import lombok.AllArgsConstructor;
+import me.chanjar.weixin.common.error.WxErrorException;
 import org.springframework.web.bind.annotation.*;
 
 import java.math.BigDecimal;
@@ -45,13 +47,12 @@
      */
     @PostMapping("/refond")
     public ResponseVO<Object> refond(@RequestBody PayParam params) {
-
-        if (params.getOutTradeNo().isEmpty() || params.getRefundAmount() == null) {
+        if (params.getOutTradeNo().isEmpty() || params.getOutTradeNo() == null) {
             throw new BusinessException("閫�娆惧弬鏁颁笉鑳戒负绌�");
         }
+        // 0.00 鐢ㄤ簬鍗犱綅 娌℃湁瀹為檯鐢ㄥ  閫�娆炬帴鍙eソ鍑犱釜鍦版柟璋冪敤  涓嶅お濂芥敼
         return ResponseUtil.success(c3mOrderService.orderRefund(params.getOutTradeNo(),
-                params.getRefundAmount()));
-
+                0.00));
     }
 
     /**
@@ -60,9 +61,15 @@
      * @return
      */
     @PostMapping("/advancePay")
-    public ResponseVO<Object> advancePayOrder(@RequestBody PayParam param) {
-        if (param.getTotalAmount() < 0) {
-            throw new BusinessException("閲戦蹇呴』澶т簬0");
+    public ResponseVO<Object> advancePayOrder(@RequestBody PayParam param) throws WxErrorException {
+        if (param.getWxCode().isEmpty()) {
+            throw new BusinessException("寰俊code涓嶈兘涓虹┖");
+        }
+        if (param.getPoleId() == null || param.getSubscribeChargingCapacity() == null) {
+            throw new BusinessException("鍏呯數妗﹊d鎴栧厖鐢靛閲忎笉鑳戒负绌�");
+        }
+        if (param.getSubscribeChargingCapacity() < 1) {
+            throw new BusinessException("鍏呯數瀹归噺涓嶈兘灏忎簬1Kw/h");
         }
         //  C3鍏呯數妗╁疄浣�
         C3mCharging c3m = c3mService.getC3mByPoleId(param.getPoleId());
@@ -73,8 +80,9 @@
         BigDecimal TotalAmount = c3mChargingChargeService.getCostByC3id(c3m.getC3Id(), param.getSubscribeChargingCapacity());
         //杞崲涓篸ouble绫诲瀷
         double totalAmount = TotalAmount.doubleValue();
+        //鐢熸垚璁㈠崟
         C3mOrder c3mOrderEntity = c3mOrderService.advancePayOrder(param.getPoleId(), c3m, "wxpay"
-                , totalAmount, param.getSubscribeChargingCapacity());
+                , totalAmount, param.getSubscribeChargingCapacity(), param.getWxCode());
         if (null == c3mOrderEntity) {
             throw new BusinessException("璇ュ厖鐢垫々姝h浣跨敤!");
         }
@@ -82,7 +90,8 @@
         param.setOutTradeNo(c3mOrderEntity.getOutTradeNo());
         param.setTotalAmount(c3mOrderEntity.getTotalAmount());
         String s = WxFastPayService.parseWxAmount(param.getTotalAmount().toString());
-        SortedMap<Object, Object> result = wxPayService.miniAppPay("鎵爜鍏呯數鏀粯(C3鍏呯數妗�)", param.getOutTradeNo(), Integer.valueOf(s), param.getPoleId());
+        //鐢熸垚寰俊棰勪粯璁㈠崟
+        SortedMap<Object, Object> result = wxPayService.miniAppPay("鎵爜鍏呯數鏀粯(C3鍏呯數妗�)", param.getOutTradeNo(), Integer.valueOf(s), param.getPoleId(), param.getWxCode());
         return ResponseUtil.success(result);
     }
 
@@ -121,4 +130,16 @@
         return ResponseUtil.successPage(list);
     }
 
+    /**
+     * 鑾峰彇wx鐨刼penid
+     */
+    @PostMapping("/getWxOpenId")
+    public ResponseVO<Object> getWxOpenId(@RequestBody PayParam param) throws WxErrorException {
+        if (param.getWxCode() == null || param.getPoleId() == null || param.getWxCode().isEmpty()) {
+            throw new BusinessException("鍙傛暟涓嶈兘涓虹┖");
+        }
+        String openId = wxPayService.getOpenId(param.getPoleId(), param.getWxCode());
+        return ResponseUtil.success(MapUtil.builder().put("openId", openId).build());
+    }
+
 }

--
Gitblit v1.9.3