From 3bc8d709e19d7ed0f26cb5af3aa82091e26bd9b5 Mon Sep 17 00:00:00 2001
From: mac <user@users-MacBook-Pro.local>
Date: 星期五, 18 十月 2024 13:55:35 +0800
Subject: [PATCH] 修复Token未失效提到登录界面问题

---
 app/src/main/java/com/hdl/photovoltaic/other/HdlUniLogic.java |  172 +++++++++++++++++++++++++++++++++++++++++++++++++++------
 1 files changed, 154 insertions(+), 18 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 f3c32c1..80fb4b7 100644
--- a/app/src/main/java/com/hdl/photovoltaic/other/HdlUniLogic.java
+++ b/app/src/main/java/com/hdl/photovoltaic/other/HdlUniLogic.java
@@ -46,11 +46,13 @@
 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;
 import com.hdl.photovoltaic.ui.bean.LinkBean;
 import com.hdl.photovoltaic.ui.bean.MemberBean;
+import com.hdl.photovoltaic.ui.bean.NotRunBean;
 import com.hdl.photovoltaic.ui.bean.OidBean;
 import com.hdl.photovoltaic.ui.bean.StaffBean;
 import com.hdl.photovoltaic.ui.bean.UnCountBean;
@@ -159,11 +161,23 @@
                     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());
+
+                        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);
+
                     }
                     break;
                 }
@@ -349,6 +363,21 @@
                     //璁惧鍚嶇О淇敼(淇敼鏄簯绔痮id鍚嶇О锛岃澶囦娇鐢╩odbus鍗忚淇敼)
                     case HDLUniMP.UNI_EVENT_REPLY_DEVICE_EDIT_NAME: {
                         this.uniOidEditName(mode_type, data, callback);
+                    }
+                    break;
+                    //鑾峰彇鏈繍琛岄�嗗彉鍣ㄥ垪琛�
+                    case HDLUniMP.UNI_EVENT_REPLY_DEVICE_NOT_RUN_DEVICE_LIST: {
+                        this.uniGetListNotRun(mode_type, data, callback);
+                    }
+                    break;
+                    //蹇嵎寮�鍚�嗗彉鍣�
+                    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;
                 }
@@ -1757,21 +1786,29 @@
                 if (cUserInfo == null) {
                     return;
                 }
-                UserConfigManage.getInstance().setBingPhone(cUserInfo.getMemberPhone());
-                UserConfigManage.getInstance().setBingEmail(cUserInfo.getMemberEmail());
-                UserConfigManage.getInstance().Save();
+
                 //鑾峰彇鐢ㄦ埛澶村儚璺緞
                 if (cUserInfo.getMemberHeadIcon().contains("http")) {
-                    UserConfigManage.getInstance().setUserImageUrl(cUserInfo.getMemberHeadIcon());
                     //鏇存柊鐢ㄦ埛澶村儚
                     uniSuccessCallback(type, cUserInfo, callback);
+                    UserConfigManage.getInstance().setUserName(cUserInfo.getMemberName());
+                    UserConfigManage.getInstance().setBingPhone(cUserInfo.getMemberPhone());
+                    UserConfigManage.getInstance().setBingEmail(cUserInfo.getMemberEmail());
+                    UserConfigManage.getInstance().setUserImageUrl(cUserInfo.getMemberHeadIcon());
+                    UserConfigManage.getInstance().Save();
+                    HdlLogLogic.print("澶村儚璺緞---->>>" + cUserInfo.getMemberHeadIcon());
                 } else {
                     HdlAccountLogic.getInstance().getImageKey_C(cUserInfo.getMemberHeadIcon(), new CloudCallBeak<String>() {
                         @Override
                         public void onSuccess(String url) {
                             cUserInfo.setMemberHeadIcon(url);
-                            UserConfigManage.getInstance().setUserImageUrl(cUserInfo.getMemberHeadIcon());
                             uniSuccessCallback(type, cUserInfo, callback);
+                            UserConfigManage.getInstance().setUserName(cUserInfo.getMemberName());
+                            UserConfigManage.getInstance().setBingPhone(cUserInfo.getMemberPhone());
+                            UserConfigManage.getInstance().setBingEmail(cUserInfo.getMemberEmail());
+                            UserConfigManage.getInstance().setUserImageUrl(cUserInfo.getMemberHeadIcon());
+                            UserConfigManage.getInstance().Save();
+                            HdlLogLogic.print("澶村儚璺緞---->>>" + cUserInfo.getMemberHeadIcon());
                         }
 
                         @Override
@@ -2030,6 +2067,22 @@
 
                                         @Override
                                         public void onFailure(HDLException e) {
+                                            //娣诲姞閫嗗彉鍣ㄥけ璐ュ悗鍒濆鍖栭�嗗彉鍣�
+                                            HdlLogLogic.print("娣诲姞閫嗗彉鍣ㄥけ璐ュ悗寮�濮嬪垵濮嬪寲閫嗗彉鍣�-->", true);
+                                            for (int i = 0; i < list.size(); i++) {
+                                                GatewayBean gatewayBean = list.get(i);
+                                                HdlDeviceLogic.getInstance().initializeInverter(gatewayBean.getDevice_mac(), new LinkCallBack<Boolean>() {
+                                                    @Override
+                                                    public void onSuccess(Boolean obj) {
+                                                        HdlLogLogic.print("鍒濆鍖栭�嗗彉鍣ㄦ垚鍔�-->mac:" + gatewayBean.getDevice_mac(), true);
+                                                    }
+
+                                                    @Override
+                                                    public void onError(HDLLinkException e) {
+                                                        HdlLogLogic.print("鍒濆鍖栭�嗗彉鍣ㄥけ璐�-->mac:" + gatewayBean.getDevice_mac(), true);
+                                                    }
+                                                });
+                                            }
                                             uniCallbackData(type, null, e.getCode(), e.getMsg(), callback);
                                         }
                                     });
@@ -2082,7 +2135,25 @@
 
             @Override
             public void onFailure(HDLException e) {
-                uniCallbackData(type, null, e.getCode(), e.getMsg(), callback);
+                if (e.getCode() == 121005) {
+                    //璁惧涓嶅瓨鍦紙121005锛夌姸鎬佺爜
+                    //鍒濆鍖栭�嗗彉鍣ㄨ澶�
+                    HdlDeviceLogic.getInstance().initializeInverter(mac, new LinkCallBack<Boolean>() {
+                        @Override
+                        public void onSuccess(Boolean obj) {
+                            //绉婚櫎鏈湴缂撳瓨
+                            HdlDeviceLogic.getInstance().removeLocalCacheMemoryGatewayToDeviceId(homeId, deviceId);
+                            uniSuccessCallback(type, null, callback);
+                        }
+
+                        @Override
+                        public void onError(HDLLinkException e) {
+                            uniCallbackData(type, null, e.getCode(), e.getMsg(), callback);
+                        }
+                    });
+                } else {
+                    uniCallbackData(type, null, e.getCode(), e.getMsg(), callback);
+                }
             }
         });
     }
@@ -2122,19 +2193,14 @@
         HdlDeviceLogic.getInstance().getCurrentHomeLocalAndCloudGatewayList(homeId, new CloudCallBeak<List<GatewayBean>>() {
             @Override
             public void onSuccess(List<GatewayBean> list) {
-                if (list == null || list.size() == 0) {
-                    if (callback != null) {
-                        uniSuccessCallback(type, list, callback);
-                    }
-                    return;
-                }
                 if (callback != null) {
                     uniSuccessCallback(type, list, callback);
                 }
                 //EventBus浜嬩欢鍒嗗彂,杩涘叆浣忓畢寮�濮嬭闃呬富棰�
                 BaseEventBus baseEventBus = new BaseEventBus();
+                baseEventBus.setTopic(HDLUniMP.UNI_EVENT_REPLY_DEVICE_LIST);
                 baseEventBus.setType(HDLUniMP.UNI_EVENT_REPLY_DEVICE_LIST);
-                baseEventBus.setData(list);
+                baseEventBus.setData(homeId);
                 EventBus.getDefault().post(baseEventBus);
                 //杩涙潵浣忓畢璇︽儏閮借涓婁紶涓�娆id鍒楄〃鍒颁簯绔�;
                 HdlDeviceLogic.getInstance().uploadOidDataToCloud(homeId, list, false, null);
@@ -2302,7 +2368,7 @@
     /**
      * 鍒濆鍖栭�嗗彉鍣�
      *
-     * @param type     璐﹀彿
+     * @param type     绫诲瀷
      * @param data     uni璇锋眰鏁版嵁
      * @param callback uni鍥炶皟
      */
@@ -2324,7 +2390,7 @@
     /**
      * 鍒濆鍖栭�嗗彉鍣�
      *
-     * @param type     璐﹀彿
+     * @param type     绫诲瀷
      * @param data     uni璇锋眰鏁版嵁
      * @param callback uni鍥炶皟
      */
@@ -2371,7 +2437,7 @@
     /**
      * 淇敼璁惧鍚嶇О閫嗗彉鍣˙MS鐢垫睜鍖�
      *
-     * @param type     璐﹀彿
+     * @param type     绫诲瀷
      * @param data     uni璇锋眰鏁版嵁
      * @param callback uni鍥炶皟
      */
@@ -2384,6 +2450,76 @@
             @Override
             public void onSuccess(Boolean obj) {
                 uniSuccessCallback(type, obj, 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 uniGetListNotRun(String type, Object data, DCUniMPJSCallback callback) {
+        String homeId = getKeyValue("homeId", getKeyValue("data", data));
+        HdlDeviceLogic.getInstance().getListNotRun(homeId, new CloudCallBeak<List<NotRunBean>>() {
+            @Override
+            public void onSuccess(List<NotRunBean> obj) {
+                uniSuccessCallback(type, obj, 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 uniSetDeviceStartup(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().setDeviceStartup(homeId, jsonArray, new CloudCallBeak<Boolean>() {
+            @Override
+            public void onSuccess(Boolean obj) {
+                uniSuccessCallback(type, obj, 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 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
@@ -2465,8 +2601,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