From 62afcbeaa5cc328bff01ae1facb18a6b8c03c5bc Mon Sep 17 00:00:00 2001
From: zhubaomin <zhubaomin>
Date: 星期二, 24 六月 2025 16:57:18 +0800
Subject: [PATCH] Merge branch 'master' of http://8.140.179.55:20000/r/pipIrr-SV

---
 pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol4Mqtt/pSdV1/ProtocolParserSdV1.java |   88 +++++++++++++++++++++++++------------------
 1 files changed, 51 insertions(+), 37 deletions(-)

diff --git a/pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol4Mqtt/pSdV1/ProtocolParserSdV1.java b/pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol4Mqtt/pSdV1/ProtocolParserSdV1.java
index 77c38d8..7ba7e80 100644
--- a/pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol4Mqtt/pSdV1/ProtocolParserSdV1.java
+++ b/pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol4Mqtt/pSdV1/ProtocolParserSdV1.java
@@ -3,9 +3,7 @@
 import com.alibaba.fastjson2.JSON;
 import com.alibaba.fastjson2.JSONObject;
 import com.dy.common.mw.protocol.Command;
-import com.dy.common.mw.protocol4Mqtt.MqttCallback;
-import com.dy.common.mw.protocol4Mqtt.MqttTopic;
-import com.dy.common.mw.protocol4Mqtt.Vo4Up;
+import com.dy.common.mw.protocol4Mqtt.*;
 import com.dy.common.mw.protocol4Mqtt.pSdV1.comParam.ComCtrlVo;
 import com.dy.common.mw.protocol4Mqtt.pSdV1.comParam.ComSetParamVo;
 import com.dy.common.mw.protocol4Mqtt.pSdV1.downVos.FaultClearVo;
@@ -22,37 +20,53 @@
  * @Description
  */
 public class ProtocolParserSdV1 {
-    public MqttSubMsgSdV1 parseSubMsg(MqttTopic subTopic, MqttMessage mqttMsg, MqttCallback callback) throws Exception {
+    public MqttSubMsg parseSubMsg(MqttTopic subTopic, MqttMessage mqttMsg, MqttCallback callback) throws Exception {
         String strTxt = new String(mqttMsg.getPayload(), "UTF-8");
         if(!JSON.isValid(strTxt)){
             throw new Exception("鎺ユ敹鍒癕QTT娑堟伅锛屽崗璁�" + subTopic.protocol + "锛岃澶嘔D" + subTopic.devId + "锛屼富棰�" + subTopic.longName() + "娑堟伅鏍煎紡闈瀓son鏁版嵁(" + strTxt + ")") ;
         }
-        MqttSubMsgSdV1 msg = new MqttSubMsgSdV1(subTopic, strTxt);
+        MqttSubMsg msg = new MqttSubMsg(subTopic, strTxt);
         Vo4Up vo ;
         DevRunInfo stInfo = null ;
         switch (subTopic.type) {
             case ProtocolConstantSdV1.SubTopicWeather -> {
-                vo = JSON.parseObject(strTxt, WeatherVo.class);
+                WeatherVo wvo = JSON.parseObject(strTxt, WeatherVo.class);
+                //璋冩暣灏忔暟
+                wvo.airTemperature = (wvo.airTemperature == null ? null: (wvo.airTemperature / 10.0F)) ;
+                wvo.airHumidity = (wvo.airHumidity == null ? null: (wvo.airHumidity / 10.0F)) ;
+                wvo.rainfall = (wvo.rainfall == null ? null: (wvo.rainfall / 10.0F)) ;
+                wvo.windSpeed = (wvo.windSpeed == null ? null: (wvo.windSpeed / 10.0F)) ;
+                vo = wvo ;
                 break;
             }
             case ProtocolConstantSdV1.SubTopicSoil -> {
-                vo = JSON.parseObject(strTxt, SoilVo.class);
+                SoilVo svo = JSON.parseObject(strTxt, SoilVo.class);
+                //璋冩暣灏忔暟
+                svo.soilHumidity1 = (svo.soilHumidity1 == null ? null: (svo.soilHumidity1 / 10.0F)) ;
+                svo.soilHumidity2 = (svo.soilHumidity2 == null ? null: (svo.soilHumidity2 / 10.0F)) ;
+                svo.soilHumidity3 = (svo.soilHumidity3 == null ? null: (svo.soilHumidity3 / 10.0F)) ;
+                svo.soilHumidity4 = (svo.soilHumidity4 == null ? null: (svo.soilHumidity4 / 10.0F)) ;
+                svo.soilHumidity5 = (svo.soilHumidity5 == null ? null: (svo.soilHumidity5 / 10.0F)) ;
+                svo.soilTemperature1 = (svo.soilTemperature1 == null ? null: (svo.soilTemperature1 / 10.0F)) ;
+                svo.soilTemperature2 = (svo.soilTemperature2 == null ? null: (svo.soilTemperature2 / 10.0F)) ;
+                svo.soilTemperature3 = (svo.soilTemperature3 == null ? null: (svo.soilTemperature3 / 10.0F)) ;
+                svo.soilTemperature4 = (svo.soilTemperature4 == null ? null: (svo.soilTemperature4 / 10.0F)) ;
+                svo.soilTemperature5 = (svo.soilTemperature5 == null ? null: (svo.soilTemperature5 / 10.0F)) ;
+                vo = svo ;
                 break;
             }
             case ProtocolConstantSdV1.SubTopicManure -> {
-                vo = JSON.parseObject(strTxt, ManureVo.class);
-                break;
-            }
-            case ProtocolConstantSdV1.SubTopicState -> {
-                //姝ゅ鏈畬鎴愶紝搴旇浜х敓涓�浜涢�氫俊鐨刬nfo锛屼緵涓嬮潰callback.notify(objs)閫氱煡鍑哄幓
-                vo = JSON.parseObject(strTxt, StateVo.class);
-                StateVo stVo = (StateVo)vo ;
+                ManureVo mvo = JSON.parseObject(strTxt, ManureVo.class);
+                //璋冩暣灏忔暟
+                mvo.manureFlow = (mvo.manureFlow == null ? null: (mvo.manureFlow / 10.0F)) ;
+                vo = mvo ;
+
                 stInfo = new DevRunInfo() ;
                 stInfo.devId = msg.deviceId ;
-                stInfo.stirRunning = (stVo.stirRunning==null?false:(stVo.stirRunning.byteValue()==1?true:false)) ; //鎼呮媽杩愯 true鏄� false鍚�
-                stInfo.injectRunning = (stVo.injectRunning==null?false:(stVo.injectRunning.byteValue()==1?true:false)) ; //娉ㄨ偉杩愯 true鏄� false鍚�
-                stInfo.irrRunning = (stVo.irrRunning==null?false:(stVo.irrRunning.byteValue()==1?true:false)) ; //鐏屾簤杩愯 true鏄� false鍚�
-                stInfo.alarm = (stVo.alarm==null?false:(stVo.alarm.byteValue()==1?true:false)) ; //鎶ヨ true鏄� false鍚�
+                stInfo.stirRunning = (mvo.stirRunning1 ==null?false:(mvo.stirRunning1.byteValue()==1?true:false)) ; //鎼呮媽杩愯 true鏄� false鍚�
+                stInfo.injectRunning = (mvo.injectRunning==null?false:(mvo.injectRunning.byteValue()==1?true:false)) ; //娉ㄨ偉杩愯 true鏄� false鍚�
+                stInfo.irrRunning = (mvo.irrRunning==null?false:(mvo.irrRunning.byteValue()==1?true:false)) ; //鐏屾簤杩愯 true鏄� false鍚�
+                stInfo.alarm = (mvo.alarm==null?false:(mvo.alarm.byteValue()==1?true:false)) ; //鎶ヨ true鏄� false鍚�
                 break;
             }
             default -> {
@@ -66,8 +80,8 @@
         return msg;
     }
 
-    public MqttPubMsgSdV1 createPubMsg(String orgTag, Command com) throws Exception {
-        MqttPubMsgSdV1 msg ;
+    public MqttPubMsg createPubMsg(String orgTag, Command com) throws Exception {
+        MqttPubMsg msg ;
         switch (com.code) {
             case CodeSdV1.cd_Fault -> {
                 //鏁呴殰瑙i櫎鍛戒护
@@ -120,89 +134,89 @@
             throw new Exception("鎺ユ敹鍒癕QTT鍛戒护锛屽崗璁�" + com.protocol + "鐗堟湰" + com.protocolVersion + "鍔熻兘鐮�" + com.code + "鍛戒护缁撴灉鍥炴敹URL涓虹┖") ;
         }
     }
-    private MqttPubMsgSdV1 createPubMsgOfFault(String orgTag, Command com) throws Exception {
+    private MqttPubMsg createPubMsgOfFault(String orgTag, Command com) throws Exception {
         JSONObject obj = (JSONObject) com.param;
         String json = obj.toJSONString();
         ComCtrlVo cvo = JSON.parseObject(json, ComCtrlVo.class);
         if(cvo == null){
             throw new Exception("json杞珻omCtrlVo涓簄ull") ;
         }
-        MqttPubMsgSdV1 msg = new MqttPubMsgSdV1() ;
+        MqttPubMsg msg = new MqttPubMsg() ;
         this.setPubMsgBase(com, msg);
         msg.isCacheForOffLine = false ;
         msg.hasResponse = true ;
         msg.cd = CodeSdV1.cd_Fault ;
-        msg.topic = new MqttTopic(orgTag, com.protocol, com.rtuAddr, ProtocolConstantSdV1.PubTopicFault, cvo.no) ;
+        msg.topic = new MqttTopic(orgTag, com.protocol + com.protocolVersion, com.rtuAddr, ProtocolConstantSdV1.PubTopicFault, cvo.no) ;
         msg.msg = JSON.toJSONString(new FaultClearVo(cvo.startTrueStopFalse ?(byte)1:0)) ;
         return msg ;
     }
-    private MqttPubMsgSdV1 createPubMsgOfStir(String orgTag, Command com) throws Exception {
+    private MqttPubMsg createPubMsgOfStir(String orgTag, Command com) throws Exception {
         JSONObject obj = (JSONObject) com.param;
         String json = obj.toJSONString();
         ComCtrlVo cvo = JSON.parseObject(json, ComCtrlVo.class);
         if(cvo == null){
             throw new Exception("json杞珻omCtrlVo涓簄ull") ;
         }
-        MqttPubMsgSdV1 msg = new MqttPubMsgSdV1() ;
+        MqttPubMsg msg = new MqttPubMsg() ;
         this.setPubMsgBase(com, msg);
         msg.isCacheForOffLine = false ;
         msg.hasResponse = true ;
         msg.cd = CodeSdV1.cd_Fault ;
-        msg.topic = new MqttTopic(orgTag, com.protocol, com.rtuAddr, ProtocolConstantSdV1.PubTopicStir, cvo.no) ;
+        msg.topic = new MqttTopic(orgTag, com.protocol + com.protocolVersion, com.rtuAddr, ProtocolConstantSdV1.PubTopicStir, cvo.no) ;
         msg.msg = JSON.toJSONString(new StirStartVo(cvo.startTrueStopFalse ?(byte)1:0)) ;
         return msg ;
     }
-    private MqttPubMsgSdV1 createPubMsgOfInject(String orgTag, Command com) throws Exception {
+    private MqttPubMsg createPubMsgOfInject(String orgTag, Command com) throws Exception {
         JSONObject obj = (JSONObject) com.param;
         String json = obj.toJSONString();
         ComCtrlVo cvo = JSON.parseObject(json, ComCtrlVo.class);
         if(cvo == null){
             throw new Exception("json杞珻omCtrlVo涓簄ull") ;
         }
-        MqttPubMsgSdV1 msg = new MqttPubMsgSdV1() ;
+        MqttPubMsg msg = new MqttPubMsg() ;
         this.setPubMsgBase(com, msg);
         msg.isCacheForOffLine = false ;
         msg.hasResponse = true ;
         msg.cd = CodeSdV1.cd_Fault ;
-        msg.topic = new MqttTopic(orgTag, com.protocol, com.rtuAddr, ProtocolConstantSdV1.PubTopicInject, cvo.no) ;
+        msg.topic = new MqttTopic(orgTag, com.protocol + com.protocolVersion, com.rtuAddr, ProtocolConstantSdV1.PubTopicInject, cvo.no) ;
         msg.msg = JSON.toJSONString(new InjectStartVo(cvo.startTrueStopFalse ?(byte)1:0)) ;
         return msg ;
     }
-    private MqttPubMsgSdV1 createPubMsgOfIrr(String orgTag, Command com) throws Exception {
+    private MqttPubMsg createPubMsgOfIrr(String orgTag, Command com) throws Exception {
         JSONObject obj = (JSONObject) com.param;
         String json = obj.toJSONString();
         ComCtrlVo cvo = JSON.parseObject(json, ComCtrlVo.class);
         if(cvo == null){
             throw new Exception("json杞珻omCtrlVo涓簄ull") ;
         }
-        MqttPubMsgSdV1 msg = new MqttPubMsgSdV1() ;
+        MqttPubMsg msg = new MqttPubMsg() ;
         this.setPubMsgBase(com, msg);
         msg.isCacheForOffLine = false ;
         msg.hasResponse = true ;
         msg.cd = CodeSdV1.cd_Fault ;
-        msg.topic = new MqttTopic(orgTag, com.protocol, com.rtuAddr, ProtocolConstantSdV1.PubTopicIrr, cvo.no) ;
+        msg.topic = new MqttTopic(orgTag, com.protocol + com.protocolVersion, com.rtuAddr, ProtocolConstantSdV1.PubTopicIrr, cvo.no) ;
         msg.msg = JSON.toJSONString(new StirStartVo(cvo.startTrueStopFalse ?(byte)1:0)) ;
         return msg ;
     }
 
-    private MqttPubMsgSdV1 createPubMsgOfParam(String orgTag, Command com) throws Exception {
+    private MqttPubMsg createPubMsgOfParam(String orgTag, Command com) throws Exception {
         JSONObject obj = (JSONObject) com.param;
         String json = obj.toJSONString();
         ComSetParamVo cvo = JSON.parseObject(json, ComSetParamVo.class);
         if(cvo == null){
             throw new Exception("json杞珻omSetParamVo涓簄ull") ;
         }
-        MqttPubMsgSdV1 msg = new MqttPubMsgSdV1() ;
+        MqttPubMsg msg = new MqttPubMsg() ;
         this.setPubMsgBase(com, msg);
         msg.isCacheForOffLine = false ;
-        msg.hasResponse = false ;
+        msg.hasResponse = true ;
         msg.cd = CodeSdV1.cd_Param ;
-        msg.topic = new MqttTopic(orgTag, com.protocol, com.rtuAddr, ProtocolConstantSdV1.PubTopicParam, cvo.no) ;
+        msg.topic = new MqttTopic(orgTag, com.protocol + com.protocolVersion, com.rtuAddr, ProtocolConstantSdV1.PubTopicParam, cvo.no) ;
         msg.msg = JSON.toJSONString(new ParamSetVo(cvo.stirDuration, cvo.injectDuration)) ;
         return msg ;
     }
 
-    private void setPubMsgBase(Command com, MqttPubMsgSdV1 msg){
+    private void setPubMsgBase(Command com, MqttPubMsg msg){
         msg.commandId = com.id ;
         msg.deviceId = com.rtuAddr ;
         msg.mqttResultSendWebUrl = com.rtuResultSendWebUrl ;

--
Gitblit v1.8.0