From 4e4310edcc77cbcad18f4c0ee03095562aace055 Mon Sep 17 00:00:00 2001
From: mac <user@users-MacBook-Pro.local>
Date: 星期二, 15 十月 2024 18:13:19 +0800
Subject: [PATCH] 2024年10月15日18:12:15

---
 app/src/main/java/com/hdl/photovoltaic/other/HdlUniLogic.java |   71 ++++++++++++++++++++++++++++-------
 1 files changed, 56 insertions(+), 15 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..a4f8bb5 100644
--- a/app/src/main/java/com/hdl/photovoltaic/other/HdlUniLogic.java
+++ b/app/src/main/java/com/hdl/photovoltaic/other/HdlUniLogic.java
@@ -10,8 +10,6 @@
 import android.location.Location;
 import android.location.LocationManager;
 import android.os.IBinder;
-import android.os.SystemClock;
-import android.print.PageRange;
 import android.provider.Settings;
 import android.text.TextUtils;
 
@@ -34,18 +32,15 @@
 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;
@@ -76,7 +71,6 @@
 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 +89,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;
 
@@ -165,8 +158,16 @@
                         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);
                     }
                     break;
                 }
@@ -262,7 +263,6 @@
 
                     }
                     break;
-
 
                 }
 
@@ -362,6 +362,11 @@
                     //蹇嵎寮�鍚�嗗彉鍣�
                     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;
                 }
@@ -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;
@@ -1190,7 +1203,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 +1456,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,10 +2491,35 @@
     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);
+            }
+
+            @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
@@ -2560,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