update 青海省平台Controller

This commit is contained in:
Lemon
2025-02-25 10:48:15 +08:00
parent 31d44174e0
commit 832304a52d

View File

@@ -3,6 +3,7 @@ package com.jsowell.api.thirdparty;
import com.alibaba.fastjson2.JSON; import com.alibaba.fastjson2.JSON;
import com.alibaba.fastjson2.JSONObject; import com.alibaba.fastjson2.JSONObject;
import com.jsowell.common.annotation.Anonymous; import com.jsowell.common.annotation.Anonymous;
import com.jsowell.common.enums.thirdparty.ThirdPartyReturnCodeEnum;
import com.jsowell.common.enums.thirdparty.ThirdPlatformTypeEnum; import com.jsowell.common.enums.thirdparty.ThirdPlatformTypeEnum;
import com.jsowell.common.exception.BusinessException; import com.jsowell.common.exception.BusinessException;
import com.jsowell.common.response.RestApiResponse; import com.jsowell.common.response.RestApiResponse;
@@ -11,6 +12,7 @@ import com.jsowell.pile.domain.ThirdPartyPlatformConfig;
import com.jsowell.pile.dto.PushRealTimeInfoDTO; import com.jsowell.pile.dto.PushRealTimeInfoDTO;
import com.jsowell.pile.dto.QueryStartChargeDTO; import com.jsowell.pile.dto.QueryStartChargeDTO;
import com.jsowell.pile.dto.QueryStationInfoDTO; import com.jsowell.pile.dto.QueryStationInfoDTO;
import com.jsowell.pile.dto.ningxiajiaotou.NXJTQueryStationInfoDTO;
import com.jsowell.pile.service.ThirdPartyPlatformConfigService; import com.jsowell.pile.service.ThirdPartyPlatformConfigService;
import com.jsowell.pile.thirdparty.CommonParamsDTO; import com.jsowell.pile.thirdparty.CommonParamsDTO;
import com.jsowell.thirdparty.lianlian.common.CommonResult; import com.jsowell.thirdparty.lianlian.common.CommonResult;
@@ -37,30 +39,27 @@ import java.util.Map;
@RequestMapping("/qinghai/evcs") @RequestMapping("/qinghai/evcs")
public class QingHaiController extends ThirdPartyBaseController { public class QingHaiController extends ThirdPartyBaseController {
@Autowired private final String platformName = "青海省平台";
@Qualifier("qingHaiPlatformServiceImpl")
private ThirdPartyPlatformService qingHaiPlatformServiceImpl; private final String platformType = ThirdPlatformTypeEnum.QING_HAI_PLATFORM.getTypeCode();
@Autowired @Autowired
private ThirdPartyPlatformConfigService thirdPartyPlatformConfigService; @Qualifier("qingHaiPlatformServiceImpl")
private ThirdPartyPlatformService platformLogic;
/** /**
* 获取token接口 * 获取token接口
* http://localhost:8080/qinghai/evcs/v1/query_token
*/ */
@PostMapping("/v1/query_token") @PostMapping("/v1/query_token")
public CommonResult<?> queryToken(@RequestBody CommonParamsDTO dto) { public CommonResult<?> queryToken(@RequestBody CommonParamsDTO dto) {
logger.info("青海平台请求令牌 params:{}", JSON.toJSONString(dto));
try { try {
// Map<String, String> map = lianLianService.generateToken(dto); Map<String, String> map = platformLogic.queryToken(dto);
Map<String, String> map = qingHaiPlatformServiceImpl.queryToken(dto); logger.info("{}-请求令牌, params:{}, result:{}", platformName, JSON.toJSONString(dto), JSON.toJSONString(map));
logger.info("青海平台请求令牌 result:{}", JSON.toJSONString(map));
return CommonResult.success(Integer.parseInt(map.get("Ret")), map.get("Msg"), map.get("Data"), map.get("Sig")); return CommonResult.success(Integer.parseInt(map.get("Ret")), map.get("Msg"), map.get("Data"), map.get("Sig"));
}catch (BusinessException e) {
logger.error("青海平台请求令牌 error:{}, {}", e.getCode(), e.getMessage());
return CommonResult.failed("获取token发生异常");
} catch (Exception e) { } catch (Exception e) {
logger.error("青海平台请求令牌接口 异常"); logger.error("{}-获取token接口, 异常, params:{}", platformName, JSON.toJSONString(dto), e);
return CommonResult.failed("获取token发生异常"); return CommonResult.failed("获取token发生异常");
} }
} }
@@ -71,41 +70,31 @@ public class QingHaiController extends ThirdPartyBaseController {
*/ */
@RequestMapping("/v1/query_stations_info") @RequestMapping("/v1/query_stations_info")
public CommonResult<?> query_stations_info(HttpServletRequest request, @RequestBody CommonParamsDTO dto) { public CommonResult<?> query_stations_info(HttpServletRequest request, @RequestBody CommonParamsDTO dto) {
logger.info("青海平台查询充电站信息 params:{}", JSON.toJSONString(dto)); logger.info("{}-查询充电站信息 params:{}", platformName, JSON.toJSONString(dto));
try { try {
// 校验令牌 // 校验令牌
String token = request.getHeader("Authorization"); if (!verifyToken(request.getHeader("Authorization"))) {
if (!JWTUtils.checkThirdPartyToken(token)) {
// 校验失败 // 校验失败
return CommonResult.failed("令牌校验错误"); return CommonResult.failed(ThirdPartyReturnCodeEnum.TOKEN_ERROR);
} }
// 查询配置信息
ThirdPartyPlatformConfig platformConfig = thirdPartyPlatformConfigService.getInfoByOperatorId(dto.getOperatorID());
String operatorSecret = platformConfig.getOperatorSecret();
String dataString = dto.getData();
String dataSecret = platformConfig.getDataSecret();
String dataSecretIV = platformConfig.getDataSecretIv();
// 校验签名 // 校验签名
boolean verifyResult = qingHaiPlatformServiceImpl.verifySignature(dto, platformConfig.getSignSecret()); if (!verifySignature(dto)) {
if (!verifyResult) { // 签名错误
// 验签失败 return CommonResult.failed(ThirdPartyReturnCodeEnum.SIGN_ERROR);
return CommonResult.failed("签名错误");
} }
// 解密data
byte[] plainText = Cryptos.aesDecrypt(Encodes.decodeBase64(dataString), dataSecret.getBytes(), dataSecretIV.getBytes()); // 解析入参
String dataStr = new String(plainText, StandardCharsets.UTF_8); QueryStationInfoDTO queryStationInfoDTO = parseParamsDTO(dto, QueryStationInfoDTO.class);
// 转换成相应对象
QueryStationInfoDTO queryStationInfoDTO = JSONObject.parseObject(dataStr, QueryStationInfoDTO.class); // 执行逻辑
queryStationInfoDTO.setOperatorId(dto.getOperatorID()); Map<String, String> map = platformLogic.queryStationsInfo(queryStationInfoDTO);
queryStationInfoDTO.setThirdPlatformType(ThirdPlatformTypeEnum.QING_HAI_PLATFORM.getTypeCode());
Map<String, String> map = qingHaiPlatformServiceImpl.queryStationsInfo(queryStationInfoDTO);
return CommonResult.success(Integer.parseInt(map.get("Ret")), map.get("Msg"), map.get("Data"), map.get("Sig")); return CommonResult.success(Integer.parseInt(map.get("Ret")), map.get("Msg"), map.get("Data"), map.get("Sig"));
} catch (Exception e) { } catch (Exception e) {
logger.error("青海平台查询充电站信息 error", e); logger.info("{}-查询充电站信息 error:", platformName, e);
} }
return CommonResult.failed("查询充电站信息异常"); return CommonResult.failed("查询充电站信息发生异常");
} }
/** /**
@@ -114,39 +103,31 @@ public class QingHaiController extends ThirdPartyBaseController {
*/ */
@RequestMapping("/v1/query_equip_business_policy") @RequestMapping("/v1/query_equip_business_policy")
public CommonResult<?> query_equip_business_policy(HttpServletRequest request, @RequestBody CommonParamsDTO dto) { public CommonResult<?> query_equip_business_policy(HttpServletRequest request, @RequestBody CommonParamsDTO dto) {
logger.info("青海平台查询业务策略信息 params:{}", JSON.toJSONString(dto)); logger.info("{}-查询业务策略信息 params:{}", platformName, JSON.toJSONString(dto));
try { try {
// 校验令牌 // 校验令牌
String token = request.getHeader("Authorization"); if (!verifyToken(request.getHeader("Authorization"))) {
if (!JWTUtils.checkThirdPartyToken(token)) {
// 校验失败 // 校验失败
return CommonResult.failed("令牌校验错误"); return CommonResult.failed(ThirdPartyReturnCodeEnum.TOKEN_ERROR);
} }
// 查询配置信息
ThirdPartyPlatformConfig platformConfig = thirdPartyPlatformConfigService.getInfoByOperatorId(dto.getOperatorID());
String operatorSecret = platformConfig.getOperatorSecret();
String dataString = dto.getData();
String dataSecret = platformConfig.getDataSecret();
String dataSecretIV = platformConfig.getDataSecretIv();
// 校验签名 // 校验签名
boolean verifyResult = qingHaiPlatformServiceImpl.verifySignature(dto, platformConfig.getSignSecret()); if (!verifySignature(dto)) {
if (!verifyResult) { // 签名错误
// 验签失败 return CommonResult.failed(ThirdPartyReturnCodeEnum.SIGN_ERROR);
return CommonResult.failed("签名错误");
} }
// 解密data
byte[] plainText = Cryptos.aesDecrypt(Encodes.decodeBase64(dataString), dataSecret.getBytes(), dataSecretIV.getBytes()); // 解析入参
String dataStr = new String(plainText, StandardCharsets.UTF_8); QueryStartChargeDTO queryStartChargeDTO = parseParamsDTO(dto, QueryStartChargeDTO.class);
// 转换成相应对象
QueryStartChargeDTO queryStartChargeDTO = JSONObject.parseObject(dataStr, QueryStartChargeDTO.class); // 执行逻辑
queryStartChargeDTO.setOperatorId(dto.getOperatorID()); Map<String, String> map = platformLogic.queryEquipBusinessPolicy(queryStartChargeDTO);
Map<String, String> map = qingHaiPlatformServiceImpl.queryEquipBusinessPolicy(queryStartChargeDTO);
return CommonResult.success(Integer.parseInt(map.get("Ret")), map.get("Msg"), map.get("Data"), map.get("Sig")); return CommonResult.success(Integer.parseInt(map.get("Ret")), map.get("Msg"), map.get("Data"), map.get("Sig"));
} catch (Exception e) { } catch (Exception e) {
logger.error("青海平台查询业务策略信息 error", e); logger.info("{}-查询业务策略信息 error:", platformName, e);
} }
return CommonResult.failed("查询业务策略信息异常"); return CommonResult.failed("查询业务策略信息发生异常");
} }
/** /**
@@ -154,71 +135,71 @@ public class QingHaiController extends ThirdPartyBaseController {
* @param stationIds * @param stationIds
* @return * @return
*/ */
@PostMapping("/pushStationPower") // @PostMapping("/pushStationPower")
public RestApiResponse<?> pushStationPower(@RequestBody List<String> stationIds) { // public RestApiResponse<?> pushStationPower(@RequestBody List<String> stationIds) {
RestApiResponse<?> response = null; // RestApiResponse<?> response = null;
try { // try {
String result = qingHaiPlatformServiceImpl.notificationPowerInfo(stationIds); // String result = qingHaiPlatformServiceImpl.notificationPowerInfo(stationIds);
response = new RestApiResponse<>(result); // response = new RestApiResponse<>(result);
}catch (Exception e) { // }catch (Exception e) {
logger.error("青海平台推送站点功率 error", e); // logger.error("青海平台推送站点功率 error", e);
} // }
logger.info("青海平台推送站点功率 result:{}", response); // logger.info("青海平台推送站点功率 result:{}", response);
return response; // return response;
} // }
/** /**
* 推送设备状态变化 * 推送设备状态变化
* @param dto * @param dto
* @return * @return
*/ */
@PostMapping("/pushRealTimeInfo") // @PostMapping("/pushRealTimeInfo")
public RestApiResponse<?> pushStationPower(@RequestBody PushRealTimeInfoDTO dto) { // public RestApiResponse<?> pushStationPower(@RequestBody PushRealTimeInfoDTO dto) {
RestApiResponse<?> response = null; // RestApiResponse<?> response = null;
try { // try {
String result = qingHaiPlatformServiceImpl.notificationStationStatus(dto); // String result = qingHaiPlatformServiceImpl.notificationStationStatus(dto);
response = new RestApiResponse<>(result); // response = new RestApiResponse<>(result);
}catch (Exception e) { // }catch (Exception e) {
logger.error("青海平台推送设备状态变化 error", e); // logger.error("青海平台推送设备状态变化 error", e);
} // }
logger.info("青海平台推送设备状态变化 result:{}", response); // logger.info("青海平台推送设备状态变化 result:{}", response);
return response; // return response;
} // }
/** /**
* 推送充电状态 * 推送充电状态
* @param orderCode * @param orderCode
* @return * @return
*/ */
@GetMapping("/notificationEquipChargeStatus/{orderCode}") // @GetMapping("/notificationEquipChargeStatus/{orderCode}")
public RestApiResponse<?> notificationEquipChargeStatus(@PathVariable("orderCode") String orderCode) { // public RestApiResponse<?> notificationEquipChargeStatus(@PathVariable("orderCode") String orderCode) {
RestApiResponse<?> response = null; // RestApiResponse<?> response = null;
try { // try {
String result = qingHaiPlatformServiceImpl.notificationEquipChargeStatus(orderCode); // String result = qingHaiPlatformServiceImpl.notificationEquipChargeStatus(orderCode);
response = new RestApiResponse<>(result); // response = new RestApiResponse<>(result);
}catch (Exception e) { // }catch (Exception e) {
logger.error("青海平台推送充电状态 error", e); // logger.error("青海平台推送充电状态 error", e);
} // }
logger.info("青海平台推送充电状态 result:{}", response); // logger.info("青海平台推送充电状态 result:{}", response);
return response; // return response;
} // }
/** /**
* 推送订单 * 推送订单
* @param orderCode * @param orderCode
* @return * @return
*/ */
@GetMapping("/pushOrderInfo/{orderCode}") // @GetMapping("/pushOrderInfo/{orderCode}")
public RestApiResponse<?> pushOrderInfo(@PathVariable("orderCode") String orderCode) { // public RestApiResponse<?> pushOrderInfo(@PathVariable("orderCode") String orderCode) {
RestApiResponse<?> response = null; // RestApiResponse<?> response = null;
try { // try {
String result = qingHaiPlatformServiceImpl.notificationChargeOrderInfo(orderCode); // String result = qingHaiPlatformServiceImpl.notificationChargeOrderInfo(orderCode);
response = new RestApiResponse<>(result); // response = new RestApiResponse<>(result);
}catch (Exception e) { // }catch (Exception e) {
logger.error("青海平台推送订单信息 error", e); // logger.error("青海平台推送订单信息 error", e);
} // }
logger.info("青海平台推送订单信息 result:{}", response); // logger.info("青海平台推送订单信息 result:{}", response);
return response; // return response;
} // }
} }