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