From d8a4151b56f04796dff5bc4164246732036c05f9 Mon Sep 17 00:00:00 2001
From: mac <user@users-MacBook-Pro.local>
Date: 星期三, 06 十一月 2024 18:14:27 +0800
Subject: [PATCH] 增加uni请求功能http接口

---
 app/src/main/java/com/hdl/photovoltaic/other/HdlUniLogic.java |  105 +++++++++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 98 insertions(+), 7 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 0dd24b0..67b7d2e 100644
--- a/app/src/main/java/com/hdl/photovoltaic/other/HdlUniLogic.java
+++ b/app/src/main/java/com/hdl/photovoltaic/other/HdlUniLogic.java
@@ -10,6 +10,7 @@
 import android.location.Location;
 import android.location.LocationManager;
 import android.os.IBinder;
+import android.os.SystemClock;
 import android.provider.Settings;
 import android.text.TextUtils;
 
@@ -19,6 +20,7 @@
 import com.google.gson.JsonArray;
 import com.google.gson.JsonObject;
 import com.google.gson.reflect.TypeToken;
+import com.hdl.link.error.HDLLinkCode;
 import com.hdl.linkpm.sdk.core.exception.HDLException;
 import com.hdl.linkpm.sdk.device.bean.DeviceOidInfoBean;
 import com.hdl.linkpm.sdk.ota.bean.CloudDeviceFirmwaresBean;
@@ -29,11 +31,13 @@
 import com.hdl.linkpm.sdk.utils.HDLMD5Utils;
 import com.hdl.photovoltaic.HDLApp;
 import com.hdl.photovoltaic.R;
+import com.hdl.photovoltaic.bean.InverterBean;
 import com.hdl.photovoltaic.bean.LocalResponse;
 import com.hdl.photovoltaic.bean.ModBusBean;
 import com.hdl.photovoltaic.bean.PageNumberObject;
 import com.hdl.photovoltaic.config.AppConfigManage;
 import com.hdl.photovoltaic.config.UserConfigManage;
+import com.hdl.photovoltaic.internet.HttpClient;
 import com.hdl.photovoltaic.internet.HttpServer.MyNanoHttpServer;
 import com.hdl.photovoltaic.internet.TcpClient;
 import com.hdl.photovoltaic.internet.api.TopicApi;
@@ -45,6 +49,7 @@
 import com.hdl.photovoltaic.ui.bean.DeviceTimeBean;
 import com.hdl.photovoltaic.ui.bean.Geolocation;
 import com.hdl.photovoltaic.ui.bean.HouseIdBean;
+import com.hdl.photovoltaic.ui.bean.HouseInfoBean;
 import com.hdl.photovoltaic.ui.bean.LinkBean;
 import com.hdl.photovoltaic.ui.bean.MemberBean;
 import com.hdl.photovoltaic.ui.bean.NotRunBean;
@@ -61,7 +66,6 @@
 import com.hdl.photovoltaic.uni.HDLUniMPSDKManager;
 import com.hdl.photovoltaic.utils.NetworkUtils;
 import com.hdl.photovoltaic.utils.WifiUtils;
-import com.hdl.sdk.link.common.exception.HDLLinkCode;
 import com.hdl.sdk.link.common.exception.HDLLinkException;
 import com.hdl.sdk.link.core.bean.eventbus.BaseEventBus;
 import com.hdl.sdk.link.core.bean.gateway.GatewayBean;
@@ -357,9 +361,14 @@
                         this.uniSetDeviceStartup(mode_type, data, callback);
                     }
                     break;
-                    //鑾峰彇璁惧璇︽儏
+                    //鑾峰彇璁惧璇︽儏锛堜簯绔澶囷級
                     case HDLUniMP.UNI_EVENT_REPLY_DEVICE_OPEN_DEVICE_info: {
                         this.uniGetDeviceInfo(mode_type, data, callback);
+                    }
+                    break;
+                    //鑾峰彇閫嗗彉鍣ㄨ鎯咃紙鐗╃悊璁惧锛�
+                    case HDLUniMP.UNI_EVENT_REPLY_DEVICE_OPEN_gateway_info: {
+                        this.uniGetGatewayInfo(mode_type, data, callback);
                     }
                     break;
                 }
@@ -669,10 +678,10 @@
                         String localSecret = HDLLinkConfig.getInstance().getLocalSecret();
                         JsonObject jsonObject = new JsonObject();
                         jsonObject.addProperty("local_encrypt", localSecret);
+                        HdlLogLogic.print("uni---log---鏈湴瀵嗛挜鑾峰彇---" + localSecret, true);
                         if (callback != null) {
                             uniSuccessCallback(type, jsonObject, callback);
                         }
-                        HdlLogLogic.print("uni---log---" + localSecret, true);
 
                     }
                     break;
@@ -685,15 +694,73 @@
                             UserConfigManage.getInstance().Save();
                             //閰嶇疆鏈湴閫氫俊鐨勪俊鎭�
                             HDLLinkConfig.getInstance().setLocalSecret(local_encrypt);
-                            HdlLogLogic.print("uni---log---" + local_encrypt, true);
+                            HdlLogLogic.print("uni---log---鏈湴瀵嗛挜璁剧疆---" + local_encrypt, true);
+                        }
+                        if (callback != null) {
+                            uniSuccessCallback(type, true, callback);
                         }
                     }
                     break;
                     //link杩涜瀵嗙爜楠岃瘉
-                    case HDLUniMP.UNI_EVENT_REPLY_OTHER_Password_verifiy: {
+                    case HDLUniMP.UNI_EVENT_REPLY_OTHER_PASSWORD_VERIFIY: {
                         uniCheckPasswordVerification(mode_type, data, callback);
                     }
                     break;
+                    //鏈湴json璧勬簮鏂囦欢鑾峰彇
+                    case HDLUniMP.UNI_EVENT_REPLY_OTHER_GET_LOCAL_JSON: {
+                        String url = getKeyValue("url", getKeyValue("data", data));
+                        String deviceModel = getKeyValue("deviceModel", getKeyValue("data", data));
+                        String language = getKeyValue("language", getKeyValue("data", data));
+                        String json = HdlESLocalJsonLogic.getInstance().readHdlESLocalJson(url, deviceModel);
+                        if (TextUtils.isEmpty(json)) {
+                            //鏈湴娌℃湁缂撳瓨
+                            HdlESLocalJsonLogic.getInstance().getHdlESLocalJson(url, deviceModel, new CloudCallBeak<String>() {
+                                @Override
+                                public void onSuccess(String obj) {
+                                    if (callback != null) {
+                                        uniSuccessCallback(type, obj, callback);
+                                    }
+                                }
+
+                                @Override
+                                public void onFailure(HDLException e) {
+                                    if (callback != null) {
+                                        uniExceptionCallback(type, e, callback);
+                                    }
+                                }
+                            });
+                        } else {
+                            //鏈湴缂撳瓨鏁版嵁
+                            if (callback != null) {
+                                uniSuccessCallback(type, json, callback);
+                            }
+                        }
+                    }
+                    break;
+                }
+            } else if (HDLUniMP.UNI_EVENT_REPLY_COMMON_MODEL.equals(topic)) {
+                //缃戠粶璇锋眰妯″潡
+                if (type.equals(HDLUniMP.UNI_EVENT_REPLY_UNI_SEND_TO_CLOUD)) {
+                    String url = getKeyValue("url", getKeyValue("data", data));
+                    JsonObject jObject = new JsonObject();
+                    String body = getKeyValue("body", getKeyValue("data", data));
+                    if (!TextUtils.isEmpty(body)) {
+                        try {
+                            jObject = new Gson().fromJson(body, JsonObject.class);
+                        } catch (Exception ignored) {
+                        }
+                    }
+                    HttpClient.getInstance().requestHttp(url, jObject.toString(), new CloudCallBeak<String>() {
+                        @Override
+                        public void onSuccess(String jsonStr) {
+                            uniSuccessCallback(mode_type, jsonStr, callback);
+                        }
+
+                        @Override
+                        public void onFailure(HDLException e) {
+                            uniExceptionCallback(mode_type, e, callback);
+                        }
+                    });
                 }
             }
 
@@ -750,6 +817,7 @@
         HdlDeviceLogic.getInstance().getPasswordVerification(mac, password, new LinkCallBack<LocalResponse>() {
             @Override
             public void onSuccess(LocalResponse obj) {
+
                 if (callback != null) {
                     uniCallbackData(type, obj.getObjects(), obj.getCode(), obj.getMsg(), callback);
                 }
@@ -757,6 +825,7 @@
 
             @Override
             public void onError(HDLLinkException e) {
+
                 if (callback != null) {
                     uniCallbackData(type, null, e.getCode(), e.getMsg(), callback);
                 }
@@ -799,7 +868,7 @@
                         HdlUniLogic.getInstance().openUniMP(path, null);
                     } else {
                         HouseIdBean houseIdBean = HouseIdList.get(0);//榛樿鎷跨涓�涓�
-                        HdlResidenceLogic.getInstance().switchHouse(houseIdBean);
+                        HdlResidenceLogic.getInstance().switchHouse(houseIdBean, true);
                         JsonObject jsonObject = new JsonObject();
                         jsonObject.addProperty("homeId", houseIdBean.getHomeId());
                         jsonObject.addProperty("homeName", houseIdBean.getHomeName());
@@ -2552,7 +2621,7 @@
     }
 
     /**
-     * 鑾峰彇璁惧璇︽儏
+     * 鑾峰彇璁惧璇︽儏锛堜簯绔級
      *
      * @param type     绫诲瀷
      * @param data     uni璇锋眰鏁版嵁
@@ -2575,6 +2644,28 @@
         });
     }
 
+    /**
+     * 鑾峰彇閫嗗彉鍣ㄨ鎯�
+     *
+     * @param type     绫诲瀷
+     * @param data     uni璇锋眰鏁版嵁
+     * @param callback uni鍥炶皟
+     */
+    public void uniGetGatewayInfo(String type, Object data, DCUniMPJSCallback callback) {
+        String mac = getKeyValue("mac", getKeyValue("data", data));
+        HdlDeviceLogic.getInstance().getGatewayInfo(mac, new LinkCallBack<InverterBean>() {
+            @Override
+            public void onSuccess(InverterBean obj) {
+                uniSuccessCallback(type, obj, callback);
+            }
+
+            @Override
+            public void onError(HDLLinkException e) {
+                uniCallbackData(type, null, e.getCode(), e.getMsg(), callback);
+            }
+        });
+    }
+
 
     /**
      * 鍙戦�乵odbus鍗忚鏁版嵁

--
Gitblit v1.8.0