|
|
@@ -0,0 +1,101 @@
|
|
|
+package com.java110.boot.controller.app.charge;
|
|
|
+
|
|
|
+import com.alibaba.fastjson.JSONObject;
|
|
|
+import com.java110.core.base.controller.BaseController;
|
|
|
+import com.java110.core.log.LoggerFactory;
|
|
|
+import com.java110.dto.chargeMachineOrder.NotifyChargeOrderDto;
|
|
|
+import com.java110.intf.common.INotifyChargeV1InnerServiceSMO;
|
|
|
+import com.java110.utils.cache.MappingCache;
|
|
|
+import org.slf4j.Logger;
|
|
|
+import org.springframework.beans.factory.annotation.Autowired;
|
|
|
+import org.springframework.http.HttpStatus;
|
|
|
+import org.springframework.http.ResponseEntity;
|
|
|
+import org.springframework.web.bind.annotation.*;
|
|
|
+
|
|
|
+import javax.crypto.Mac;
|
|
|
+import javax.crypto.SecretKey;
|
|
|
+import javax.crypto.spec.SecretKeySpec;
|
|
|
+import javax.servlet.http.HttpServletRequest;
|
|
|
+import java.util.Base64;
|
|
|
+
|
|
|
+@RestController
|
|
|
+@RequestMapping(path = "/app/charge")
|
|
|
+public class NotifyCommonChargeController extends BaseController {
|
|
|
+
|
|
|
+ private final static Logger logger = LoggerFactory.getLogger(NotifyCommonChargeController.class);
|
|
|
+
|
|
|
+ public static final String DING_DING_DOMAIN = "DING_DING_CHARGE";
|
|
|
+
|
|
|
+
|
|
|
+ public static final String DING_DING_APP_ID = "APP_ID";
|
|
|
+ public static final String DING_DING_APP_SECURE = "APP_SECURE";
|
|
|
+ @Autowired
|
|
|
+ private INotifyChargeV1InnerServiceSMO notifyChargeV1InnerServiceSMOImpl;
|
|
|
+
|
|
|
+ /**
|
|
|
+ * <p>支付回调Api</p>
|
|
|
+ *
|
|
|
+ * @param request
|
|
|
+ * @throws Exception
|
|
|
+ */
|
|
|
+ @RequestMapping(path = "/{id}/{port}/finish", method = RequestMethod.POST)
|
|
|
+ public ResponseEntity<String> finishCharge(
|
|
|
+ @PathVariable String id,
|
|
|
+ @PathVariable String port,
|
|
|
+ @RequestBody String postInfo,
|
|
|
+ HttpServletRequest request) {
|
|
|
+
|
|
|
+ JSONObject param = JSONObject.parseObject(postInfo);
|
|
|
+ NotifyChargeOrderDto notifyChargeOrderDto = new NotifyChargeOrderDto();
|
|
|
+ notifyChargeOrderDto.setOrderId(param.getString("chargeId"));
|
|
|
+ notifyChargeOrderDto.setMachineCode(id);
|
|
|
+ notifyChargeOrderDto.setPortCode(port);
|
|
|
+ notifyChargeOrderDto.setBodyParam(postInfo);
|
|
|
+
|
|
|
+ return notifyChargeV1InnerServiceSMOImpl.finishCharge(notifyChargeOrderDto);
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * <p>支付回调Api</p>
|
|
|
+ *
|
|
|
+ * @param request
|
|
|
+ * @throws Exception
|
|
|
+ */
|
|
|
+ @RequestMapping(path = "/{id}/event", method = RequestMethod.POST)
|
|
|
+ public ResponseEntity<String> heartbeat(
|
|
|
+ @PathVariable String id,
|
|
|
+ @RequestBody String postInfo,
|
|
|
+ HttpServletRequest request) {
|
|
|
+ NotifyChargeOrderDto notifyChargeOrderDto = new NotifyChargeOrderDto();
|
|
|
+ notifyChargeOrderDto.setMachineCode(id);
|
|
|
+ notifyChargeOrderDto.setBodyParam(postInfo);
|
|
|
+
|
|
|
+ return notifyChargeV1InnerServiceSMOImpl.heartbeat(notifyChargeOrderDto);
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * <p>支付回调Api</p>
|
|
|
+ *
|
|
|
+ * @param request
|
|
|
+ * @throws Exception
|
|
|
+ */
|
|
|
+ @RequestMapping(path = "/{id}/{port}/event", method = RequestMethod.POST)
|
|
|
+ public ResponseEntity<String> chargeHeartbeat(
|
|
|
+ @PathVariable String id,
|
|
|
+ @PathVariable String port,
|
|
|
+ @RequestBody String postInfo,
|
|
|
+ HttpServletRequest request) {
|
|
|
+
|
|
|
+ NotifyChargeOrderDto notifyChargeOrderDto = new NotifyChargeOrderDto();
|
|
|
+ notifyChargeOrderDto.setMachineCode(id);
|
|
|
+ notifyChargeOrderDto.setPortCode(port);
|
|
|
+ notifyChargeOrderDto.setBodyParam(postInfo);
|
|
|
+
|
|
|
+ return notifyChargeV1InnerServiceSMOImpl.chargeHeartBeat(notifyChargeOrderDto);
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+}
|