From 2c7a721e947d86d4f8988a9b2b11b87ad7e923bf Mon Sep 17 00:00:00 2001 From: xuhy <3313886187@qq.com> Date: 星期一, 02 九月 2024 11:57:31 +0800 Subject: [PATCH] 处理消息中转 --- ruoyi-service/ruoyi-integration/src/main/java/com/ruoyi/integration/iotda/utils/listener/IotMessageListener.java | 86 ++++++++++++++++++++++++++++++++++++++++++- 1 files changed, 84 insertions(+), 2 deletions(-) diff --git a/ruoyi-service/ruoyi-integration/src/main/java/com/ruoyi/integration/iotda/utils/listener/IotMessageListener.java b/ruoyi-service/ruoyi-integration/src/main/java/com/ruoyi/integration/iotda/utils/listener/IotMessageListener.java index acf6897..3640b42 100644 --- a/ruoyi-service/ruoyi-integration/src/main/java/com/ruoyi/integration/iotda/utils/listener/IotMessageListener.java +++ b/ruoyi-service/ruoyi-integration/src/main/java/com/ruoyi/integration/iotda/utils/listener/IotMessageListener.java @@ -2,7 +2,11 @@ import com.alibaba.fastjson.JSONObject; import com.ruoyi.common.core.web.domain.AjaxResult; +import com.ruoyi.integration.iotda.constant.SendTagConstant; +import com.ruoyi.integration.rocket.produce.EnhanceProduce; import lombok.extern.slf4j.Slf4j; +import org.apache.rocketmq.client.producer.SendResult; +import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.RestController; @@ -16,6 +20,8 @@ @RestController public class IotMessageListener { + @Autowired + private EnhanceProduce enhanceProduce; /** * 设备消息监听 @@ -27,9 +33,85 @@ public AjaxResult<String> message(@RequestBody JSONObject jsonObject) throws IOException { log.info("接收到消息中转:{}",jsonObject); JSONObject content = jsonObject.getJSONObject("content"); - if (content.getString("name").equals("device_status_change")){ - //设备状态改变 + String service_id = content.getString("service_id"); + log.info("服务id:{}",service_id); + SendResult sendResult; + // 设备消息下发 + switch (service_id){ + case SendTagConstant.ONLINE: + sendResult = enhanceProduce.onlineMessage(content); + break; + case SendTagConstant.PING: + sendResult = enhanceProduce.pingMessage(content); + break; + case SendTagConstant.BILLING_MODE_VERIFY: + sendResult = enhanceProduce.billingModeVerifyMessage(content); + break; + case SendTagConstant.ACQUISITION_BILLING_MODE: + sendResult = enhanceProduce.acquisitionBillingModeMessage(content); + break; + case SendTagConstant.UPLOAD_REAL_TIME_MONITORING_DATA: + sendResult = enhanceProduce.uploadRealTimeMonitoringDataMessage(content); + break; + case SendTagConstant.CHARGING_HANDSHAKE: + sendResult = enhanceProduce.chargingHandshakeMessage(content); + break; + case SendTagConstant.BMS_ABORT: + sendResult = enhanceProduce.bmsAbortMessage(content); + break; + case SendTagConstant.MOTOR_ABORT: + sendResult = enhanceProduce.motorAbortMessage(content); + break; + case SendTagConstant.BMS_DEMAND_AND_CHARGER_EXPORTATION: + sendResult = enhanceProduce.bmsDemandAndChargerExportationMessage(content); + break; + case SendTagConstant.BMS_INFORMATION: + sendResult = enhanceProduce.bmsInformationMessage(content); + break; + case SendTagConstant.CHARGING_PILE_STARTS_CHARGING: + sendResult = enhanceProduce.chargingPileStartsChargingMessage(content); + break; + case SendTagConstant.PLATFORM_START_CHARGING_REPLY: + sendResult = enhanceProduce.platformStartChargingReplyMessage(content); + break; + case SendTagConstant.PLATFORM_STOP_CHARGING_REPLY: + sendResult = enhanceProduce.platformStopChargingReplyMessage(content); + break; + case SendTagConstant.TRANSACTION_RECORD: + sendResult = enhanceProduce.transactionRecordMessage(content); + break; + case SendTagConstant.UPDATE_BALANCE_REPLY: + sendResult = enhanceProduce.updateBalanceReplyMessage(content); + break; + case SendTagConstant.SYNCHRONIZE_OFFLINE_CARD_REPLY: + sendResult = enhanceProduce.synchronizeOfflineCardReplyMessage(content); + break; + case SendTagConstant.CLEAR_OFFLINE_CARD_REPLY: + sendResult = enhanceProduce.clearOfflineCardReplyMessage(content); + break; + case SendTagConstant.WORKING_PARAMETER_SETTING_REPLY: + sendResult = enhanceProduce.workingParameterSettingReplyMessage(content); + break; + case SendTagConstant.TIMING_SETTING_REPLY: + sendResult = enhanceProduce.timingSettingReplyMessage(content); + break; + case SendTagConstant.SETUP_BILLING_MODEL_REPLY: + sendResult = enhanceProduce.setupBillingModelReplyMessage(content); + break; + case SendTagConstant.GROUND_LOCK_REAL_TIME_DATA: + sendResult = enhanceProduce.groundLockRealTimeDataMessage(content); + break; + case SendTagConstant.CHARGING_PILE_RETURNS_GROUND_LOCK_DATA: + sendResult = enhanceProduce.chargingPileReturnsGroundLockDataMessage(content); + break; + case SendTagConstant.PLATFORM_RESTART_REPLY: + sendResult = enhanceProduce.platformRestartReplyMessage(content); + break; + default: + sendResult = enhanceProduce.platformRemoteUpdateReplyMessage(content); + break; } + log.info("rocketmq消息下发结果:{}",sendResult); return AjaxResult.success(); } -- Gitblit v1.7.1