From 3f8f1590859188c334739f76f1d64c2b6c2bfd55 Mon Sep 17 00:00:00 2001
From: mac <user@users-MacBook-Pro.local>
Date: 星期四, 31 十月 2024 17:01:06 +0800
Subject: [PATCH] 2024年10月31日17:01:04

---
 app/src/main/java/com/hdl/photovoltaic/other/HdlUniLogic.java |  179 ++++++++++++++++++++++++++++++++++++++++++++++++++---------
 1 files changed, 150 insertions(+), 29 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 98aa56d..7beca24 100644
--- a/app/src/main/java/com/hdl/photovoltaic/other/HdlUniLogic.java
+++ b/app/src/main/java/com/hdl/photovoltaic/other/HdlUniLogic.java
@@ -11,7 +11,6 @@
 import android.location.LocationManager;
 import android.os.IBinder;
 import android.os.SystemClock;
-import android.print.PageRange;
 import android.provider.Settings;
 import android.text.TextUtils;
 
@@ -21,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;
@@ -31,21 +31,20 @@
 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.ConstantManage;
 import com.hdl.photovoltaic.config.UserConfigManage;
-import com.hdl.photovoltaic.enums.LowerTagType;
 import com.hdl.photovoltaic.internet.HttpServer.MyNanoHttpServer;
 import com.hdl.photovoltaic.internet.TcpClient;
-import com.hdl.photovoltaic.internet.api.HttpApi;
 import com.hdl.photovoltaic.internet.api.TopicApi;
 import com.hdl.photovoltaic.listener.CloudCallBeak;
 import com.hdl.photovoltaic.listener.LinkCallBack;
-import com.hdl.photovoltaic.ui.bean.BUserInfo;
 import com.hdl.photovoltaic.ui.bean.CUserInfo;
 import com.hdl.photovoltaic.ui.bean.CloudInverterDeviceBean;
+import com.hdl.photovoltaic.ui.bean.DeviceInfoBean;
 import com.hdl.photovoltaic.ui.bean.DeviceTimeBean;
 import com.hdl.photovoltaic.ui.bean.Geolocation;
 import com.hdl.photovoltaic.ui.bean.HouseIdBean;
@@ -65,7 +64,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;
@@ -73,10 +71,10 @@
 import com.hdl.sdk.link.core.callback.GatewayCallBack;
 import com.hdl.sdk.link.core.callback.HDLLinkCallBack;
 import com.hdl.sdk.link.core.callback.ModbusCallBack;
+import com.hdl.sdk.link.core.config.HDLLinkConfig;
 import com.hdl.sdk.link.core.connect.HDLModBusConnect;
 import com.hdl.sdk.link.core.connect.HDLUdpConnect;
 import com.hdl.sdk.link.gateway.HDLLinkLocalGateway;
-import com.huawei.hms.api.Api;
 
 import org.greenrobot.eventbus.EventBus;
 import org.json.JSONObject;
@@ -95,7 +93,6 @@
 import java.util.Objects;
 import java.util.concurrent.atomic.AtomicInteger;
 
-import io.dcloud.feature.sdk.DCUniMPSDK;
 import io.dcloud.feature.unimp.DCUniMPJSCallback;
 import okhttp3.ResponseBody;
 
@@ -160,13 +157,21 @@
                     break;
                     //鐢ㄦ埛鏈湴缂撳瓨淇℃伅
                     case HDLUniMP.UNI_EVENT_REPLY_USER_LOCAL_INFO: {
-                        HdlLogLogic.print("鏈湴澶村儚璺緞---->>>" + UserConfigManage.getInstance().getUserImageUrl());
                         JsonObject jsonObject = new JsonObject();
                         jsonObject.addProperty("user_name", UserConfigManage.getInstance().getUserName());
                         jsonObject.addProperty("user_image_url", UserConfigManage.getInstance().getUserImageUrl());
                         jsonObject.addProperty("user_account", UserConfigManage.getInstance().getAccount());
-                        uniSuccessCallback(mode_type, jsonObject, callback);
 
+                        jsonObject.addProperty("token", HDLLinkPMUser.getInstance().getAccessToken());
+                        jsonObject.addProperty("refreshToken", HDLLinkPMUser.getInstance().getRefreshToken());
+                        if (TextUtils.isEmpty(AppConfigManage.getUserRegionUrl())) {
+                            AppConfigManage.setUserRegionUrl(HDLLinkPMUser.getInstance().getUserRegionUrl());
+                        }
+                        jsonObject.addProperty("serverAddress", AppConfigManage.getUserRegionUrl());
+                        jsonObject.addProperty("appKey", AppConfigManage.getAppKey());
+                        jsonObject.addProperty("appSecret", AppConfigManage.getAppSecret());
+                        uniSuccessCallback(mode_type, jsonObject, callback);
+                        HdlLogLogic.print("鑾峰彇鐢ㄦ埛鏈湴缂撳瓨淇℃伅---->>>" + jsonObject.toString());
                     }
                     break;
                 }
@@ -178,10 +183,7 @@
                     case HDLUniMP.UNI_EVENT_REPLY_HOME_ADD: {
                         String url = getKeyValue("url", getKeyValue("data", data));
                         //EventBus浜嬩欢鍒嗗彂
-                        HdlCommonLogic.getInstance().postEventBusSticky(
-                                HDLUniMP.UNI_EVENT_REPLY_HOME_ADD,
-                                HDLUniMP.UNI_EVENT_REPLY_HOME_ADD,
-                                url);
+                        HdlCommonLogic.getInstance().postEventBusSticky(HDLUniMP.UNI_EVENT_REPLY_HOME_ADD, HDLUniMP.UNI_EVENT_REPLY_HOME_ADD, url);
 
                         if (callback != null) {
                             uniSuccessCallback(type, null, callback);
@@ -198,10 +200,7 @@
                     //鍒涘缓鐢电珯
                     case HDLUniMP.UNI_EVENT_REPLY_HOME_CREATION: {
                         //EventBus浜嬩欢鍒嗗彂
-                        HdlCommonLogic.getInstance().postEventBus(
-                                HDLUniMP.UNI_EVENT_REPLY_HOME_MODEL,
-                                HDLUniMP.UNI_EVENT_REPLY_HOME_CREATION,
-                                getKeyValue("data", data));
+                        HdlCommonLogic.getInstance().postEventBus(HDLUniMP.UNI_EVENT_REPLY_HOME_MODEL, HDLUniMP.UNI_EVENT_REPLY_HOME_CREATION, getKeyValue("data", data));
                         if (callback != null) {
                             uniSuccessCallback(type, null, callback);
                         }
@@ -236,10 +235,7 @@
                     //浣忓畢銆愮數绔欍�戠紪杈�
                     case HDLUniMP.UNI_EVENT_REPLY_HOME_EDIT: {
                         //EventBus浜嬩欢鍒嗗彂
-                        HdlCommonLogic.getInstance().postEventBus(
-                                HDLUniMP.UNI_EVENT_REPLY_HOME_MODEL,
-                                HDLUniMP.UNI_EVENT_REPLY_HOME_EDIT,
-                                getKeyValue("data", data));
+                        HdlCommonLogic.getInstance().postEventBus(HDLUniMP.UNI_EVENT_REPLY_HOME_MODEL, HDLUniMP.UNI_EVENT_REPLY_HOME_EDIT, getKeyValue("data", data));
                         if (callback != null) {
                             uniSuccessCallback(type, null, callback);
                         }
@@ -262,7 +258,6 @@
 
                     }
                     break;
-
 
                 }
 
@@ -362,6 +357,16 @@
                     //蹇嵎寮�鍚�嗗彉鍣�
                     case HDLUniMP.UNI_EVENT_REPLY_DEVICE_OPEN_DEVICE_LIST: {
                         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;
                 }
@@ -523,9 +528,17 @@
                     break;
                     //娑堟伅涓績
                     case HDLUniMP.UNI_EVENT_REPLY_MINE_MESSAGE_CENTER: {
+                        String homeId = getKeyValue("homeId", getKeyValue("data", data));
+                        String isShowFault = getKeyValue("isShowFault", getKeyValue("data", data));
                         Intent intent = new Intent();
                         intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
                         intent.setClass(HDLApp.getInstance(), MessageCenterList.class);
+                        if (!TextUtils.isEmpty(homeId)) {
+                            intent.putExtra("homeId", homeId);
+                        }
+                        if (!TextUtils.isEmpty(isShowFault)) {
+                            intent.putExtra("isShowFault", isShowFault);
+                        }
                         HDLApp.getInstance().startActivity(intent);
                     }
                     break;
@@ -658,6 +671,39 @@
                         HDLLinkPMUser.getInstance().logout(0);
                     }
                     break;
+                    //鏈湴瀵嗛挜鑾峰彇
+                    case HDLUniMP.UNI_EVENT_REPLY_OTHER_LOCAL_ENCRYPT_GET: {
+                        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);
+                        }
+
+                    }
+                    break;
+                    //鏈湴瀵嗛挜璁剧疆
+                    case HDLUniMP.UNI_EVENT_REPLY_OTHER_LOCAL_ENCRYPT_SET: {
+                        String local_encrypt = getKeyValue("local_encrypt", getKeyValue("data", data));
+                        if (!TextUtils.isEmpty(local_encrypt)) {
+                            //閲嶆柊璁剧疆鏈湴閫氳绉橀挜
+                            UserConfigManage.getInstance().setLocalSecret(local_encrypt);
+                            UserConfigManage.getInstance().Save();
+                            //閰嶇疆鏈湴閫氫俊鐨勪俊鎭�
+                            HDLLinkConfig.getInstance().setLocalSecret(local_encrypt);
+                            HdlLogLogic.print("uni---log---鏈湴瀵嗛挜璁剧疆---" + local_encrypt, true);
+                        }
+                        if (callback != null) {
+                            uniSuccessCallback(type, true, callback);
+                        }
+                    }
+                    break;
+                    //link杩涜瀵嗙爜楠岃瘉
+                    case HDLUniMP.UNI_EVENT_REPLY_OTHER_Password_verifiy: {
+                        uniCheckPasswordVerification(mode_type, data, callback);
+                    }
+                    break;
                 }
             }
 
@@ -706,6 +752,31 @@
     //region ******uni鎺ュ彛鏂规硶******
 
     /**
+     * link杩涜瀵嗙爜楠岃瘉
+     */
+    private void uniCheckPasswordVerification(String type, Object data, DCUniMPJSCallback callback) {
+        String password = getKeyValue("password", getKeyValue("data", data));
+        String mac = getKeyValue("mac", getKeyValue("data", data));
+        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);
+                }
+            }
+
+            @Override
+            public void onError(HDLLinkException e) {
+
+                if (callback != null) {
+                    uniCallbackData(type, null, e.getCode(), e.getMsg(), callback);
+                }
+            }
+        });
+    }
+
+    /**
      * 鐢电珯鍒犻櫎
      */
     private void uniGetDelResidence(String type, Object data, DCUniMPJSCallback callback) {
@@ -740,7 +811,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());
@@ -1190,7 +1261,9 @@
      */
     private void uniGetCurrentDeviceFirmwares(String type, Object data, DCUniMPJSCallback callback) {
         String deviceOidId = getKeyValue("deviceOidId", getKeyValue("data", data));//浜戠涓婅澶噄d
-        HdlOtaLogic.getInstance().getCurrentDeviceFirmwares(deviceOidId, new CloudCallBeak<List<DeviceFirmwareBean>>() {
+        String oid = getKeyValue("oid", getKeyValue("data", data));//璁惧oid
+        String homeId = getKeyValue("homeId", getKeyValue("data", data));//鐢电珯id
+        HdlOtaLogic.getInstance().getCurrentDeviceFirmwares(deviceOidId, oid, homeId, new CloudCallBeak<List<DeviceFirmwareBean>>() {
             @Override
             public void onSuccess(List<DeviceFirmwareBean> obj) {
                 uniSuccessCallback(type, obj, callback);
@@ -1441,7 +1514,8 @@
      */
     private void uniGetCurrentGatewayDrivers(String type, Object data, DCUniMPJSCallback callback) {
         String deviceOid = getKeyValue("oid", getKeyValue("data", data));
-        HdlOtaLogic.getInstance().getCurrentGatewayDrivers(deviceOid, new CloudCallBeak<List<GatewayDriverBean>>() {
+        String homeId = getKeyValue("homeId", getKeyValue("data", data));//鐢电珯id
+        HdlOtaLogic.getInstance().getCurrentGatewayDrivers(deviceOid, homeId, new CloudCallBeak<List<GatewayDriverBean>>() {
             @Override
             public void onSuccess(List<GatewayDriverBean> obj) {
                 uniSuccessCallback(type, obj, callback);
@@ -2475,7 +2549,8 @@
     public void uniSetDeviceStartup(String type, Object data, DCUniMPJSCallback callback) {
         String homeId = getKeyValue("homeId", getKeyValue("data", data));
         String aryJson = getKeyValue("deviceIds", getKeyValue("data", data));
-        HdlDeviceLogic.getInstance().setDeviceStartup(homeId, aryJson, new CloudCallBeak<Boolean>() {
+        JsonArray jsonArray = new Gson().fromJson(aryJson, JsonArray.class);
+        HdlDeviceLogic.getInstance().setDeviceStartup(homeId, jsonArray, new CloudCallBeak<Boolean>() {
             @Override
             public void onSuccess(Boolean obj) {
                 uniSuccessCallback(type, obj, callback);
@@ -2483,6 +2558,52 @@
 
             @Override
             public void onFailure(HDLException e) {
+                uniCallbackData(type, null, e.getCode(), e.getMsg(), callback);
+            }
+        });
+    }
+
+    /**
+     * 鑾峰彇璁惧璇︽儏锛堜簯绔級
+     *
+     * @param type     绫诲瀷
+     * @param data     uni璇锋眰鏁版嵁
+     * @param callback uni鍥炶皟
+     */
+    public void uniGetDeviceInfo(String type, Object data, DCUniMPJSCallback callback) {
+        String homeId = getKeyValue("homeId", getKeyValue("data", data));
+        String aryJson = getKeyValue("deviceIds", getKeyValue("data", data));
+        JsonArray jsonArray = new Gson().fromJson(aryJson, JsonArray.class);
+        HdlDeviceLogic.getInstance().getDeviceInfo(homeId, jsonArray, new CloudCallBeak<List<DeviceInfoBean>>() {
+            @Override
+            public void onSuccess(List<DeviceInfoBean> list) {
+                uniSuccessCallback(type, list, callback);
+            }
+
+            @Override
+            public void onFailure(HDLException e) {
+                uniCallbackData(type, null, e.getCode(), e.getMsg(), callback);
+            }
+        });
+    }
+
+    /**
+     * 鑾峰彇閫嗗彉鍣ㄨ鎯�
+     *
+     * @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);
             }
         });
@@ -2560,8 +2681,8 @@
             }
             if (isTokenAndRefreshToken) {
                 //灏忕▼搴忛偅閲屾湁鑷繁鐨勮姹傛柟娉�,浣嗛渶瑕佸師鐢熸彁渚涜繖浜涙暟鎹�
-                data.put("token", UserConfigManage.getInstance().getToken());
-                data.put("refreshToken", UserConfigManage.getInstance().getRefreshToken());
+                data.put("token", HDLLinkPMUser.getInstance().getAccessToken());
+                data.put("refreshToken", HDLLinkPMUser.getInstance().getRefreshToken());
                 if (TextUtils.isEmpty(AppConfigManage.getUserRegionUrl())) {
                     AppConfigManage.setUserRegionUrl(HDLLinkPMUser.getInstance().getUserRegionUrl());
                 }

--
Gitblit v1.8.0