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 = "/equipments")
public class NotifyDingDingChargeController extends BaseController {
private final static Logger logger = LoggerFactory.getLogger(NotifyDingDingChargeController.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;
/**
*
支付回调Api
*
* @param request
* @throws Exception
*/
@RequestMapping(path = "/{id}/{port}/finish", method = RequestMethod.POST)
public ResponseEntity finishCharge(
@PathVariable String id,
@PathVariable String port,
@RequestBody String postInfo,
HttpServletRequest request) {
if (!validateSign(request)) {
return new ResponseEntity<>("{\n" +
"\"code\" : -1,\n" +
"\"msg\" : \"鉴权失败\"\n" +
"}", HttpStatus.OK);
}
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);
}
/**
* 支付回调Api
*
* @param request
* @throws Exception
*/
@RequestMapping(path = "/{id}/event", method = RequestMethod.POST)
public ResponseEntity heartbeat(
@PathVariable String id,
@RequestBody String postInfo,
HttpServletRequest request) {
if (!validateSign(request)) {
return new ResponseEntity<>("{\n" +
"\"code\" : -1,\n" +
"\"msg\" : \"鉴权失败\"\n" +
"}", HttpStatus.OK);
}
JSONObject param = JSONObject.parseObject(postInfo);
NotifyChargeOrderDto notifyChargeOrderDto = new NotifyChargeOrderDto();
notifyChargeOrderDto.setMachineCode(id);
notifyChargeOrderDto.setBodyParam(postInfo);
return notifyChargeV1InnerServiceSMOImpl.heartbeat(notifyChargeOrderDto);
}
/**
* 支付回调Api
*
* @param request
* @throws Exception
*/
@RequestMapping(path = "/{id}/{port}/event", method = RequestMethod.POST)
public ResponseEntity chargeHeartbeat(
@PathVariable String id,
@PathVariable String port,
@RequestBody String postInfo,
HttpServletRequest request) {
if (!validateSign(request)) {
return new ResponseEntity<>("{\n" +
"\"code\" : -1,\n" +
"\"msg\" : \"鉴权失败\"\n" +
"}", HttpStatus.OK);
}
NotifyChargeOrderDto notifyChargeOrderDto = new NotifyChargeOrderDto();
notifyChargeOrderDto.setMachineCode(id);
notifyChargeOrderDto.setPortCode(port);
notifyChargeOrderDto.setBodyParam(postInfo);
return notifyChargeV1InnerServiceSMOImpl.chargeHeartBeat(notifyChargeOrderDto);
}
private boolean validateSign(HttpServletRequest request) {
String appId = request.getParameter("appid");
String timestamp = request.getParameter("timestamp");
String sign = request.getParameter("sign");
String secret = MappingCache.getValue(DING_DING_DOMAIN, DING_DING_APP_SECURE);
String data = "appid=" + appId + "×tamp=" + timestamp;
SecretKey secretKey = new SecretKeySpec(secret.getBytes(), "HmacMD5");
Mac mac = null;
try {
mac = Mac.getInstance(secretKey.getAlgorithm());
mac.init(secretKey);
} catch (Exception e) {
throw new RuntimeException(e);
}
String result =
Base64.getEncoder().encodeToString(mac.doFinal(data.getBytes()));
if (sign.equals(result)) {
return true;
}
return false;
}
}