From 54a8c79222bba0644b02fe1dbc5d75e26ea50b5d Mon Sep 17 00:00:00 2001
From: mac <user@users-MacBook-Pro.local>
Date: 星期二, 14 十一月 2023 18:17:58 +0800
Subject: [PATCH] 2023年11月14日18:17:48

---
 app/src/main/java/com/hdl/photovoltaic/other/HdlUniLogic.java |  230 +++++++++++++++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 207 insertions(+), 23 deletions(-)

diff --git a/app/src/main/java/com/hdl/photovoltaic/other/HdlUniLogic.java b/app/src/main/java/com/hdl/photovoltaic/other/HdlUniLogic.java
index 9cf071e..ff4307a 100644
--- a/app/src/main/java/com/hdl/photovoltaic/other/HdlUniLogic.java
+++ b/app/src/main/java/com/hdl/photovoltaic/other/HdlUniLogic.java
@@ -6,6 +6,11 @@
 
 import com.google.gson.Gson;
 import com.hdl.linkpm.sdk.core.exception.HDLException;
+import com.hdl.linkpm.sdk.device.bean.DeviceOidInfoBean;
+import com.hdl.linkpm.sdk.ota.bean.CloudDeviceFirmwaresBean;
+import com.hdl.linkpm.sdk.ota.bean.CloudGatewayDriversBean;
+import com.hdl.linkpm.sdk.ota.bean.DeviceFirmwareBean;
+import com.hdl.linkpm.sdk.ota.bean.GatewayDriverBean;
 import com.hdl.photovoltaic.HDLApp;
 import com.hdl.photovoltaic.bean.ModBusBean;
 import com.hdl.photovoltaic.config.UserConfigManage;
@@ -187,6 +192,46 @@
                     break;
 
                 }
+            } else if (HDLUniMP.UNI_EVENT_REPLY_OTA_MODEL.equals(event)) {
+                //OTA鍗囩骇妯″潡
+                switch (type) {
+                    //鍚戜簯绔幏鍙杘id鍒楄〃
+                    case HDLUniMP.UNI_EVENT_REPLY_OTA_CLOUD_OID_LIST: {
+                        this.uniGetCloudOidList(data, callback);
+                    }
+                    break;
+                    //褰撳墠璁惧鍥轰欢鍒楄〃
+                    case HDLUniMP.UNI_EVENT_REPLY_OTA_FIRMWARES_LIST: {
+                        this.uniGetCurrentDeviceFirmwares(data, callback);
+                    }
+                    break;
+                    //璁惧鏂板浐浠跺垪琛�
+                    case HDLUniMP.UNI_EVENT_REPLY_OTA_FIRMWARES_NEW_LIST: {
+                        this.uniGetNewDeviceFirmwares(data, callback);
+                    }
+                    break;
+                    //璁惧鍥轰欢鍗囩骇
+                    case HDLUniMP.UNI_EVENT_REPLY_OTA_FIRMWARES_UPGRADE: {
+                        this.uniUpgradeDeviceFirmware(data, callback);
+                    }
+                    break;
+                    //褰撳墠璁惧椹卞姩鍒楄〃
+                    case HDLUniMP.UNI_EVENT_REPLY_OTA_DRIVER_LIST: {
+                        this.uniGetCurrentGatewayDrivers(data, callback);
+                    }
+                    break;
+                    //璁惧鏂伴┍鍔ㄥ垪琛�
+                    case HDLUniMP.UNI_EVENT_REPLY_OTA_DRIVER_NEW: {
+                        this.uniGetNewGatewayDrivers(data, callback);
+                    }
+                    break;
+                    //璁惧椹卞姩鍗囩骇
+                    case HDLUniMP.UNI_EVENT_REPLY_OTA_DRIVER_UPGRADE: {
+                        this.uniUpgradeGatewayDriver(data, callback);
+                    }
+                    break;
+
+                }
             }
             HdlLogLogic.print("uni===鍘熺敓鎺ユ敹uni鍙戞潵鐨勬暟鎹�===" + event + "\r\n" + data, false);
         } catch (Exception e) {
@@ -203,10 +248,9 @@
      * @param jsonObject 闄勪欢鏁版嵁(娌℃湁鏁版嵁濉玭ull)
      */
     public void openUniMP(String path, JSONObject jsonObject) {
-
-        JSONObject json = this.createdJsonDate(jsonObject, true);
-        HdlLogLogic.print("uni===缁勮uni鍙戦�佹暟鎹牸寮�===" + json, false);
+        JSONObject json = this.createdJSONObject(jsonObject, true);
         HDLUniMPSDKManager.getInstance().openUniMP(HDLUniMP.UNI_APP_ID, path, json, HdlUniLogic.this);
+        HdlLogLogic.print("uni===缁勮uni鍙戦�佹暟鎹牸寮�===" + json, false);
     }
 
     /**
@@ -232,7 +276,143 @@
     }
     //endregion
 
-    //region ******uni閫昏緫鏂规硶******
+    //region ******uni鎺ュ彛鏂规硶******
+
+    /**
+     * 鍚戜簯绔幏鍙栭�嗗彉鍣╫id鍒楄〃
+     * 鍓嶆彁鏉′欢:瑕佷笂浼犻�嗗彉鍣╫id鍒楄〃缁欎簯绔�
+     *
+     * @param callback -
+     */
+    private void uniGetCloudOidList(Object data, DCUniMPJSCallback callback) {
+        HdlOtaLogic.getInstance().getCloudOidList(new CloudCallBeak<List<DeviceOidInfoBean>>() {
+            @Override
+            public void onSuccess(List<DeviceOidInfoBean> obj) {
+                uniCallbackData(obj, callback);
+            }
+
+            @Override
+            public void onFailure(HDLException e) {
+                uniCallbackData(null, e.getCode(), e.getMsg(), callback);
+            }
+        });
+    }
+
+    /**
+     * 鍚戜簯绔幏鍙栥�愬綋鍓嶈澶囧浐浠躲�戝垪琛�
+     * 鍓嶆彁鏉′欢:璁惧鑷姩涓婃姤oid淇℃伅缁欎簯绔�
+     */
+    private void uniGetCurrentDeviceFirmwares(Object data, DCUniMPJSCallback callback) {
+        String deviceOidId = getKeyValue("deviceOidId", getKeyValue("data", data));
+        HdlOtaLogic.getInstance().getCurrentDeviceFirmwares(deviceOidId, new CloudCallBeak<List<DeviceFirmwareBean>>() {
+            @Override
+            public void onSuccess(List<DeviceFirmwareBean> obj) {
+                uniCallbackData(obj, callback);
+            }
+
+            @Override
+            public void onFailure(HDLException e) {
+                uniCallbackData(null, e.getCode(), e.getMsg(), callback);
+            }
+        });
+    }
+
+    /**
+     * 鍚戜簯绔幏鍙栥�愯澶囨柊鍥轰欢銆戝垪琛�
+     * 鍓嶆彁鏉′欢:瑕侀�氳繃骞冲彴杞欢涓婁紶鏂板浐浠�
+     */
+    private void uniGetNewDeviceFirmwares(Object data, DCUniMPJSCallback callback) {
+        String hardwareModel = getKeyValue("hardwareModel", getKeyValue("data", data));//纭欢鍨嬪彿
+        String osImageId = getKeyValue("osImageId", getKeyValue("data", data));//绯荤粺闀滃儚id
+        HdlOtaLogic.getInstance().getNewDeviceFirmwares(hardwareModel, osImageId, new CloudCallBeak<List<CloudDeviceFirmwaresBean>>() {
+            @Override
+            public void onSuccess(List<CloudDeviceFirmwaresBean> obj) {
+                uniCallbackData(obj, callback);
+            }
+
+            @Override
+            public void onFailure(HDLException e) {
+                uniCallbackData(null, e.getCode(), e.getMsg(), callback);
+            }
+        });
+    }
+
+    /**
+     * 鍚戜簯绔彂璧枫�愯澶囧浐浠躲�戝崌绾TA鎸囦护
+     */
+    private void uniUpgradeDeviceFirmware(Object data, DCUniMPJSCallback callback) {
+        String deviceOidId = getKeyValue("deviceOidId", getKeyValue("data", data));//璁惧id
+        String firmwareVersionId = getKeyValue("firmwareVersionId", getKeyValue("data", data));//鍥轰欢鐗堟湰id
+        HdlOtaLogic.getInstance().upgradeDeviceFirmware(deviceOidId, firmwareVersionId, new CloudCallBeak<Boolean>() {
+            @Override
+            public void onSuccess(Boolean obj) {
+                uniCallbackData(obj, callback);
+            }
+
+            @Override
+            public void onFailure(HDLException e) {
+                uniCallbackData(null, e.getCode(), e.getMsg(), callback);
+            }
+        });
+    }
+
+    /**
+     * 鍚戜簯绔幏鍙栥�愬綋鍓嶈澶囬┍鍔ㄣ�戝垪琛�
+     * 鍓嶆彁鏉′欢:璁惧鑷姩涓婃姤oid淇℃伅缁欎簯绔�
+     */
+    private void uniGetCurrentGatewayDrivers(Object data, DCUniMPJSCallback callback) {
+        String deviceOid = getKeyValue("oid", getKeyValue("data", data));
+        HdlOtaLogic.getInstance().getCurrentGatewayDrivers(deviceOid, new CloudCallBeak<List<GatewayDriverBean>>() {
+            @Override
+            public void onSuccess(List<GatewayDriverBean> obj) {
+                uniCallbackData(obj, callback);
+            }
+
+            @Override
+            public void onFailure(HDLException e) {
+                uniCallbackData(null, e.getCode(), e.getMsg(), callback);
+            }
+        });
+    }
+
+    /**
+     * 鍚戜簯绔幏鍙栥�愯澶囨柊椹卞姩銆戝垪琛�
+     * 鍓嶆彁鏉′欢:瑕侀�氳繃骞冲彴杞欢涓婁紶鏂伴┍鍔�
+     */
+    private void uniGetNewGatewayDrivers(Object data, DCUniMPJSCallback callback) {
+        String driveCode = getKeyValue("driveCode", getKeyValue("data", data));//椹卞姩缂栧彿鎴栭┍鍔ㄥ悕绉�
+        String osImageId = getKeyValue("osImageId", getKeyValue("data", data));//椹卞姩绫诲瀷id
+        HdlOtaLogic.getInstance().getNewGatewayDrivers(driveCode, osImageId, new CloudCallBeak<CloudGatewayDriversBean>() {
+            @Override
+            public void onSuccess(CloudGatewayDriversBean obj) {
+                uniCallbackData(obj, callback);
+            }
+
+            @Override
+            public void onFailure(HDLException e) {
+                uniCallbackData(null, e.getCode(), e.getMsg(), callback);
+            }
+        });
+    }
+
+    /**
+     * 鍚戜簯绔彂璧枫�愯澶囬┍鍔ㄣ�戝崌绾TA鎸囦护
+     */
+    private void uniUpgradeGatewayDriver(Object data, DCUniMPJSCallback callback) {
+        String deviceOid = getKeyValue("oid", getKeyValue("data", data));//缃戝叧璁惧oid
+        String driverVersionId = getKeyValue("driverVersionId", getKeyValue("data", data));//椹卞姩鐗堟湰id
+        HdlOtaLogic.getInstance().upgradeGatewayDriver(deviceOid, driverVersionId, new CloudCallBeak<Boolean>() {
+            @Override
+            public void onSuccess(Boolean obj) {
+                uniCallbackData(obj, callback);
+            }
+
+            @Override
+            public void onFailure(HDLException e) {
+                uniCallbackData(null, e.getCode(), e.getMsg(), callback);
+            }
+        });
+    }
 
     /**
      * 閫嗗彉鍣ㄦ竻绌轰綇瀹卛d
@@ -354,22 +534,17 @@
                             uniCallbackData(null, -100, "鏈湴鎵句笉鍒扮綉鍏�", callback);
                             return;
                         }
-                        HdlDeviceLogic.getInstance().addInverterDeviceToCloud(mac,
-                                gatewayBean.getGatewayType(),
-                                gatewayBean.getSid(),
-                                gatewayBean.getOid(),
-                                gatewayBean.getDevice_name(),
-                                new CloudCallBeak<Boolean>() {
-                                    @Override
-                                    public void onSuccess(Boolean obj) {
-                                        uniCallbackData(null, callback);
-                                    }
+                        HdlDeviceLogic.getInstance().addInverterDeviceToCloud(mac, gatewayBean.getGatewayType(), gatewayBean.getSid(), gatewayBean.getOid(), gatewayBean.getDevice_name(), new CloudCallBeak<Boolean>() {
+                            @Override
+                            public void onSuccess(Boolean obj) {
+                                uniCallbackData(null, callback);
+                            }
 
-                                    @Override
-                                    public void onFailure(HDLException e) {
-                                        uniCallbackData(null, e.getCode(), e.getMsg(), callback);
-                                    }
-                                });
+                            @Override
+                            public void onFailure(HDLException e) {
+                                uniCallbackData(null, e.getCode(), e.getMsg(), callback);
+                            }
+                        });
                     }
 
                     @Override
@@ -461,11 +636,19 @@
 
     /**
      * 鍙戦�乵odbus鍗忚鏁版嵁
+     * 閫忎紶鍗忚
+     * 涓嬪彂涓婚锛�/user/${gw_id}/custom/native/${driver}/down;
+     * 閫嗗彉鍣ㄥ洖澶嶄富棰橈細/user/${gw_id}/custom/native/${driver}/down_reply;
+     * Modbus ECU鍗忚锛氫簨浠禝D(2涓猙yte)->鍗忚[鍥哄畾:0,0](2涓猙yte)->闀垮害(2byte)->鏍囪瘑绗oid鐨刟ddresses鍊糫(4涓猙yte)->鍔熻兘鐮�(1涓猙yte)->璐熻浇鏁版嵁(N涓猙yte);
+     * 闀垮害(2涓猙yte)=鏍囪瘑绗�(4涓猙yte)+鍔熻兘鐮�(1涓猙yte)+璐熻浇鏁版嵁(N涓猙yte);
+     * 璐熻浇鏁版嵁=瀵勫瓨鍣ㄥ湴鍧�(2涓猙yte)+瀵勫瓨鍣ㄩ暱搴�(2涓猙yte)+鍐呭闀垮害(1涓猙yte)+鍐呭鏁版嵁(N涓猙yte)銆愭敞鎰�:鍗曚釜鍐欏叆瀵勫瓨鍣�-->鍘绘帀<瀵勫瓨鍣ㄩ暱搴�>鍜�<鍐呭闀垮害>銆�;
+     * 瀵勫瓨鍣ㄩ暱搴�=(鍐呭鏁版嵁/2);
+     * 渚嬪瓙:new byte[]{00,01,00,00,00,0x09,00,00,00,01,03,00,00,00,01};
      *
      * @param data     modbus鏁版嵁
      * @param callback 鍥炶皟
      */
-    void sendModBus(Object data, DCUniMPJSCallback callback) {
+    private void sendModBus(Object data, DCUniMPJSCallback callback) {
         String tempData = getKeyValue("data", data);
         if (TextUtils.isEmpty(tempData)) {
             HdlLogLogic.print("data鍐呭涓虹┖", false);
@@ -506,11 +689,11 @@
     /**
      * 缁勮uni鍙戦�佹暟鎹牸寮�
      *
-     * @param data                   -闄勪欢鏁版嵁(娌℃湁鏁版嵁濉玭ull)
+     * @param data                   闄勫姞鏁版嵁(娌℃湁鏁版嵁濉玭ull)
      * @param isTokenAndRefreshToken (true=搴曞眰榛樿娣诲姞token鍜宺efreshToken;false=涓嶅姞)
-     * @return JSONObject
+     * @return JSONObject            uni鏂规硶鍚嶉噷闈㈠弬鏁伴渶瑕佺殑JSONObject瀵硅薄
      */
-    private JSONObject createdJsonDate(JSONObject data, boolean isTokenAndRefreshToken) {
+    private JSONObject createdJSONObject(JSONObject data, boolean isTokenAndRefreshToken) {
         HDLUniMP.UniCallBackBaseBean uniCallBackBaseBean = new HDLUniMP.UniCallBackBaseBean();
         try {
             if (data == null) {
@@ -604,6 +787,7 @@
         } catch (Exception e) {
             return "";
         }
+
     }
     //endregion
 

--
Gitblit v1.8.0