From b8209d15d915f72d9abe3a68b76e1f4cfd21eac3 Mon Sep 17 00:00:00 2001
From: mac <user@users-MacBook-Pro.local>
Date: 星期六, 23 九月 2023 14:37:00 +0800
Subject: [PATCH] 2023年09月23日14:36:51

---
 app/src/main/java/com/hdl/photovoltaic/other/HdlDeviceLogic.java |  398 +++++++++++++++++++++++++++++++++++++++++++++++++-------
 1 files changed, 349 insertions(+), 49 deletions(-)

diff --git a/app/src/main/java/com/hdl/photovoltaic/other/HdlDeviceLogic.java b/app/src/main/java/com/hdl/photovoltaic/other/HdlDeviceLogic.java
index c16a5ad..49d7dce 100644
--- a/app/src/main/java/com/hdl/photovoltaic/other/HdlDeviceLogic.java
+++ b/app/src/main/java/com/hdl/photovoltaic/other/HdlDeviceLogic.java
@@ -1,25 +1,44 @@
 package com.hdl.photovoltaic.other;
 
+import android.text.TextUtils;
+
 import com.google.gson.Gson;
 import com.google.gson.JsonArray;
 import com.google.gson.JsonObject;
 import com.google.gson.reflect.TypeToken;
+import com.hdl.hdlhttp.HxHttp;
+import com.hdl.linkpm.sdk.core.exception.HDLException;
 import com.hdl.photovoltaic.bean.HttpResponsePack;
+import com.hdl.photovoltaic.config.AppConfigManage;
 import com.hdl.photovoltaic.config.UserConfigManage;
 import com.hdl.photovoltaic.internet.HttpClient;
+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.BaseSuccessFailureCallBeak;
 import com.hdl.photovoltaic.listener.CloudCallBeak;
+import com.hdl.photovoltaic.listener.LinkCallBack;
 import com.hdl.photovoltaic.ui.bean.CloudInverterChildDeviceBean;
 import com.hdl.photovoltaic.ui.bean.CloudInverterDeviceBean;
 import com.hdl.photovoltaic.ui.bean.InverterDeviceBean;
 import com.hdl.photovoltaic.ui.bean.OidBean;
+import com.hdl.photovoltaic.uni.HDLUniMP;
+import com.hdl.photovoltaic.uni.HDLUniMPSDKManager;
+import com.hdl.sdk.link.common.exception.HDLLinkCode;
+import com.hdl.sdk.link.common.exception.HDLLinkException;
+import com.hdl.sdk.link.core.bean.gateway.GatewayBean;
+import com.hdl.sdk.link.core.callback.GatewayCallBack;
+import com.hdl.sdk.link.core.callback.HDLLinkCallBack;
+import com.hdl.sdk.link.gateway.HDLLinkLocalGateway;
 
 import java.lang.reflect.Type;
+import java.util.ArrayList;
 import java.util.List;
 
+import io.reactivex.rxjava3.disposables.Disposable;
+
 /**
- * 璁惧閫昏緫鐨勭晫闈�
+ * 璁惧閫昏緫
  */
 public class HdlDeviceLogic {
     private static volatile HdlDeviceLogic sHdlDeviceLogic;
@@ -42,72 +61,81 @@
     }
 
     /**
-     * 娣诲姞閫嗗彉鍣�
+     * 娣诲姞閫嗗彉鍣ㄥ埌浜戠涓�
      *
-     * @param inverterDeviceBean 閫嗗彉鍣ㄥ璞�
-     * @param cloudCallBeak      鍥炶皟
+     * @param mac           -
+     * @param spk           -
+     * @param sid           -
+     * @param oid           -
+     * @param name          -
+     * @param cloudCallBeak
      */
-    public void addInverterDevice(InverterDeviceBean inverterDeviceBean, CloudCallBeak<Boolean> cloudCallBeak) {
+    public void addInverterDeviceToCloud(String mac, String spk, String sid, String oid, String name, CloudCallBeak<Boolean> cloudCallBeak) {
+
         String requestUrl = HttpApi.POST_Device_Add;
         JsonObject json = new JsonObject();
         json.addProperty("homeId", UserConfigManage.getInstance().getHomeId());
-        json.addProperty("mac", inverterDeviceBean.getDevice_mac());
-        json.addProperty("spk", inverterDeviceBean.getGateway_type());
-        json.addProperty("sid", inverterDeviceBean.getSid());
-        json.addProperty("oid", inverterDeviceBean.getOid());
-        json.addProperty("name", inverterDeviceBean.getDevice_name());
+        json.addProperty("mac", mac);
+        json.addProperty("spk", spk);
+        json.addProperty("sid", sid);
+        json.addProperty("oid", oid);
+        json.addProperty("name", name);
         // json.addProperty("zoneType", "password");//鍖哄煙
 
-        HttpClient.getInstance().requestHttp(requestUrl, json.toString(), true, true, new BaseSuccessFailureCallBeak() {
+        HttpClient.getInstance().requestHttp(requestUrl, json.toString(), new CloudCallBeak<String>() {
             @Override
-            public void onSuccess(HttpResponsePack httpResponsePack) {
+            public void onSuccess(String str) {
                 if (cloudCallBeak != null) {
                     cloudCallBeak.onSuccess(true);
                 }
             }
 
             @Override
-            public void onFailure(Exception exception) {
+            public void onFailure(HDLException e) {
                 if (cloudCallBeak != null) {
-                    cloudCallBeak.onFailure(exception);
+                    cloudCallBeak.onFailure(e);
                 }
             }
         });
     }
 
     /**
-     * 鑾峰彇閫嗗彉鍣ㄥ垪琛�
+     * 鑾峰彇浜戠閫嗗彉鍣ㄥ垪琛�
      *
-     * @param inverterDeviceBean 閫嗗彉鍣ㄥ璞�
-     * @param cloudCallBeak      鍥炶皟
+     * @param homeId        浣忓畢id
+     * @param cloudCallBeak 鍥炶皟
      */
-    public void getInverterDeviceList(InverterDeviceBean inverterDeviceBean, CloudCallBeak<CloudInverterDeviceBean> cloudCallBeak) {
+    public void getCloudInverterDeviceList(String homeId, CloudCallBeak<List<CloudInverterDeviceBean>> cloudCallBeak) {
         String requestUrl = HttpApi.POST_Device_List;
         JsonObject json = new JsonObject();
-        json.addProperty("homeId", UserConfigManage.getInstance().getHomeId());
+        json.addProperty("homeId", homeId);
         // json.addProperty("zoneType", "password");//鍖哄煙
 
-        HttpClient.getInstance().requestHttp(requestUrl, json.toString(), true, true, new BaseSuccessFailureCallBeak() {
+        HttpClient.getInstance().requestHttp(requestUrl, json.toString(), new CloudCallBeak<String>() {
             @Override
-            public void onSuccess(HttpResponsePack httpResponsePack) {
-                if (httpResponsePack != null && httpResponsePack.getData() != null) {
-                    Gson gson = new Gson();
-                    String json = gson.toJson(httpResponsePack.getData());
-                    CloudInverterDeviceBean loginUserRegionBean = new Gson().fromJson(json, CloudInverterDeviceBean.class);
+            public void onSuccess(String jsonStr) {
+                if (TextUtils.isEmpty(jsonStr)) {
                     if (cloudCallBeak != null) {
-                        cloudCallBeak.onSuccess(loginUserRegionBean);
+                        cloudCallBeak.onSuccess(null);
                     }
+                }
+                Type type = new TypeToken<List<CloudInverterDeviceBean>>() {
+                }.getType();
+                List<CloudInverterDeviceBean> list = new Gson().fromJson(jsonStr, type);
+                if (cloudCallBeak != null) {
+                    cloudCallBeak.onSuccess(list);
                 }
             }
 
             @Override
-            public void onFailure(Exception exception) {
+            public void onFailure(HDLException e) {
                 if (cloudCallBeak != null) {
-                    cloudCallBeak.onFailure(exception);
+                    cloudCallBeak.onFailure(e);
                 }
             }
         });
     }
+
 
     /**
      * 鍒犻櫎閫嗗彉鍣�
@@ -122,18 +150,18 @@
         json.addProperty("deviceId", deviceId);
         // json.addProperty("zoneType", "password");//鍖哄煙
 
-        HttpClient.getInstance().requestHttp(requestUrl, json.toString(), true, true, new BaseSuccessFailureCallBeak() {
+        HttpClient.getInstance().requestHttp(requestUrl, json.toString(), new CloudCallBeak<String>() {
             @Override
-            public void onSuccess(HttpResponsePack httpResponsePack) {
+            public void onSuccess(String str) {
                 if (cloudCallBeak != null) {
                     cloudCallBeak.onSuccess(true);
                 }
             }
 
             @Override
-            public void onFailure(Exception exception) {
+            public void onFailure(HDLException e) {
                 if (cloudCallBeak != null) {
-                    cloudCallBeak.onFailure(exception);
+                    cloudCallBeak.onFailure(e);
                 }
             }
         });
@@ -152,25 +180,28 @@
         json.addProperty("parentOid", parentOid);
         // json.addProperty("zoneType", "password");//鍖哄煙
 
-        HttpClient.getInstance().requestHttp(requestUrl, json.toString(), true, true, new BaseSuccessFailureCallBeak() {
+        HttpClient.getInstance().requestHttp(requestUrl, json.toString(), new CloudCallBeak<String>() {
             @Override
-            public void onSuccess(HttpResponsePack httpResponsePack) {
-                if (httpResponsePack != null && httpResponsePack.getData() != null) {
-                    Gson gson = new Gson();
-                    String json = gson.toJson(httpResponsePack.getData());
-                    Type typeOfT = new TypeToken<List<CloudInverterChildDeviceBean>>() {
-                    }.getType();
-                    List<CloudInverterChildDeviceBean> list = gson.fromJson(json, typeOfT);
+            public void onSuccess(String jsonStr) {
+                if (TextUtils.isEmpty(jsonStr)) {
                     if (cloudCallBeak != null) {
-                        cloudCallBeak.onSuccess(list);
+                        cloudCallBeak.onSuccess(null);
                     }
+                    return;
+                }
+                Gson gson = new Gson();
+                Type typeOfT = new TypeToken<List<CloudInverterChildDeviceBean>>() {
+                }.getType();
+                List<CloudInverterChildDeviceBean> list = gson.fromJson(jsonStr, typeOfT);
+                if (cloudCallBeak != null) {
+                    cloudCallBeak.onSuccess(list);
                 }
             }
 
             @Override
-            public void onFailure(Exception exception) {
+            public void onFailure(HDLException e) {
                 if (cloudCallBeak != null) {
-                    cloudCallBeak.onFailure(exception);
+                    cloudCallBeak.onFailure(e);
                 }
             }
         });
@@ -180,9 +211,9 @@
      * 鍏ㄩ噺鏇存柊OID
      *
      * @param oidList       oid鍒楄〃
-     * @param cloudCallBeak 鍥炶皟
+     * @param cloudCallBeak 鍥炶皟update
      */
-    public void fullRenewalOid(List<OidBean> oidList, CloudCallBeak<Boolean> cloudCallBeak) {
+    public void fullUpdateOid(List<OidBean> oidList, CloudCallBeak<Boolean> cloudCallBeak) {
         String requestUrl = HttpApi.POST_Device_ChildDevices_List;
         JsonObject json = new JsonObject();
         json.addProperty("operationSource", "PROGRAM_ENERGY");//
@@ -205,9 +236,9 @@
         json.add("devices", jsonArray);
         // json.addProperty("zoneType", "password");//鍖哄煙
 
-        HttpClient.getInstance().requestHttp(requestUrl, json.toString(), true, true, new BaseSuccessFailureCallBeak() {
+        HttpClient.getInstance().requestHttp(requestUrl, json.toString(), new CloudCallBeak<String>() {
             @Override
-            public void onSuccess(HttpResponsePack httpResponsePack) {
+            public void onSuccess(String str) {
 
                 if (cloudCallBeak != null) {
                     cloudCallBeak.onSuccess(true);
@@ -216,12 +247,281 @@
             }
 
             @Override
-            public void onFailure(Exception exception) {
+            public void onFailure(HDLException e) {
                 if (cloudCallBeak != null) {
-                    cloudCallBeak.onFailure(exception);
+                    cloudCallBeak.onFailure(e);
+                }
+            }
+        });
+
+    }
+
+
+    /**
+     * 璁剧疆缃戝叧杩滅▼鍙傛暟
+     *
+     * @param mac          璁惧mac
+     * @param linkCallBack 鍥炶皟update
+     */
+    public void steGatewayParam(String mac, LinkCallBack<Boolean> linkCallBack) {
+        String requestUrl = TopicApi.SET_GATEWAY_REMOTE_EDIT;
+        JsonObject json = new JsonObject();
+        json.addProperty("homeId", UserConfigManage.getInstance().getHomeId());
+        json.addProperty("server_addr", AppConfigManage.getUserRegionUrl());
+        json.addProperty("local_secret", UserConfigManage.getInstance().getLocalSecret());
+        //瑙e瘑璐熻浇鏁版嵁(鍥犱负鍐欏瘑閽ョ粰缃戝叧涓�瀹氭槑鏂囷紝鍥犱负閭f椂缃戝叧杩樻病鏈夊瘑閽�)
+        TcpClient.getInstance().sendDataToLinkGateway(mac, false, requestUrl, json, "", new HDLLinkCallBack() {
+            @Override
+            public void onSuccess(String msg) {
+                GatewayBean gatewayBean = HDLLinkLocalGateway.getInstance().getLocalGateway(mac);
+                if (gatewayBean != null) {
+                    if (!TextUtils.isEmpty(UserConfigManage.getInstance().getLocalSecret())) {
+                        gatewayBean.setLocalEncrypt(true);
+                    }
+                }
+                if (linkCallBack != null) {
+                    linkCallBack.onSuccess(true);
+                }
+
+            }
+
+            @Override
+            public void onError(HDLLinkException e) {
+                if (linkCallBack != null) {
+                    linkCallBack.onError(e);
                 }
             }
         });
     }
 
+    /**
+     * 缂栬緫缃戝叧鍙傛暟
+     *
+     * @param mac          璁惧mac
+     * @param linkCallBack 鍥炶皟update
+     */
+    public void editGatewayParam(String mac, LinkCallBack<Boolean> linkCallBack) {
+        String requestUrl = TopicApi.SET_GATEWAY_EDIT;
+        JsonObject json = new JsonObject();
+        json.addProperty("master", "true");
+        TcpClient.getInstance().sendDataToLinkGateway(mac, requestUrl, json, "", new HDLLinkCallBack() {
+            @Override
+            public void onSuccess(String msg) {
+                if (linkCallBack != null) {
+                    linkCallBack.onSuccess(true);
+                }
+            }
+
+            @Override
+            public void onError(HDLLinkException e) {
+                if (linkCallBack != null) {
+                    linkCallBack.onError(e);
+                }
+            }
+        });
+
+    }
+
+
+    /**
+     * 鑾峰彇缃戝叧璇︽儏淇℃伅
+     *
+     * @param mac          缃戝叧mac
+     * @param linkCallBack 鍥炶皟
+     */
+    public void getGatewayInfo(String mac, LinkCallBack<GatewayBean> linkCallBack) {
+        String requestUrl = TopicApi.GET_GATEWAY_INFO;
+        TcpClient.getInstance().sendDataToLinkGateway(mac, requestUrl, null, "", new HDLLinkCallBack() {
+            @Override
+            public void onSuccess(String json) {
+                if (TextUtils.isEmpty(json)) {
+                    if (linkCallBack != null) {
+                        linkCallBack.onSuccess(null);
+                    }
+                    return;
+                }
+                Gson gson = new Gson();
+                GatewayBean gatewayBean = gson.fromJson(json, GatewayBean.class);
+                if (linkCallBack != null) {
+                    linkCallBack.onSuccess(gatewayBean);
+                }
+            }
+
+            @Override
+            public void onError(HDLLinkException e) {
+                if (linkCallBack != null) {
+                    linkCallBack.onError(e);
+                }
+            }
+        });
+
+    }
+
+    /**
+     * 鑾峰彇缃戝叧oid鍒楄〃
+     *
+     * @param mac          缃戝叧mac
+     * @param linkCallBack 鍥炶皟
+     */
+    public void getGatewayOidList(String mac, LinkCallBack<List<OidBean>> linkCallBack) {
+        String requestUrl = TopicApi.GET_GATEWAY_OID_LIST;
+        TcpClient.getInstance().sendDataToLinkGateway(mac, requestUrl, null, "", new HDLLinkCallBack() {
+            @Override
+            public void onSuccess(String json) {
+                if (TextUtils.isEmpty(json)) {
+                    if (linkCallBack != null) {
+                        linkCallBack.onSuccess(null);
+                    }
+                    return;
+                }
+                Gson gson = new Gson();
+                Type typeOfT = new TypeToken<List<OidBean>>() {
+                }.getType();
+                List<OidBean> list = gson.fromJson(json, typeOfT);
+                if (linkCallBack != null) {
+                    linkCallBack.onSuccess(list);
+                }
+            }
+
+            @Override
+            public void onError(HDLLinkException e) {
+                if (linkCallBack != null) {
+                    linkCallBack.onError(e);
+                }
+            }
+        });
+
+    }
+
+    /**
+     * 鑾峰彇鏈湴璁惧鍒楄〃
+     * 娉ㄦ剰:鏈夊缃戜互浜戠璁惧涓哄噯,鏈湴瀛樺湪锛屼簯绔病鏈夊垯鍒犻櫎锛涘唴缃戜互鏈湴涓轰富,鎼滅储澶氬皯涓澶囧氨鏄剧ず澶氬皯涓紱
+     *
+     * @param cloudCallBeak -
+     */
+    public void getLocalGatewayList(CloudCallBeak<Boolean> cloudCallBeak) {
+        HdlDeviceLogic.getInstance().searchGateway(new GatewayCallBack() {
+            @Override
+            public void onSuccess(List<GatewayBean> gatewayBeanList) {
+                HdlDeviceLogic.getInstance().getCloudInverterDeviceList(UserConfigManage.getInstance().getHomeId(), new CloudCallBeak<List<CloudInverterDeviceBean>>() {
+                    @Override
+                    public void onSuccess(List<CloudInverterDeviceBean> list) {
+                        if (list == null || list.size() == 0) {
+//                            //浜戠娌℃湁缁戝畾閫嗗彉鍣�,浠ユ湰鍦颁负涓�;
+//                            HDLLinkLocalGateway.getInstance().getGatewayList().clear();
+                            if (cloudCallBeak != null) {
+                                cloudCallBeak.onSuccess(true);
+                            }
+                            return;
+                        }
+                        //鏀堕泦鍒犻櫎閫嗗彉鍣╯id
+                        List<String> removeSidList = new ArrayList<>();
+                        for (int i = 0; i < list.size(); i++) {
+                            CloudInverterDeviceBean cloudInverterDeviceBean = list.get(i);
+                            for (int j = 0; j < HDLLinkLocalGateway.getInstance().getGatewayList().size(); j++) {
+                                GatewayBean gatewayBean = HDLLinkLocalGateway.getInstance().getGatewayList().get(j);
+                                if (!cloudInverterDeviceBean.getSid().equals(gatewayBean.getSid())) {
+                                    //鏈湴鏈夛紝浜戠娌℃湁,鍒犻櫎鏈湴锛�
+                                    removeSidList.add(gatewayBean.getSid());
+                                }
+
+                            }
+                        }
+                        for (int i = 0; i < removeSidList.size(); i++) {
+                            //鑾峰彇鏈湴鐨勬绫虫尝
+                            removeInverter(removeSidList.get(i));
+                        }
+
+                        if (cloudCallBeak != null) {
+                            cloudCallBeak.onSuccess(true);
+                        }
+                    }
+
+                    @Override
+                    public void onFailure(HDLException e) {
+                        if (cloudCallBeak != null) {
+                            cloudCallBeak.onFailure(e);
+                        }
+                    }
+                });
+            }
+
+            @Override
+            public void onError(HDLLinkException e) {
+                HdlDeviceLogic.getInstance().getCloudInverterDeviceList(UserConfigManage.getInstance().getHomeId(), new CloudCallBeak<List<CloudInverterDeviceBean>>() {
+                    @Override
+                    public void onSuccess(List<CloudInverterDeviceBean> list) {
+                        if (list == null || list.size() == 0) {
+                            if (cloudCallBeak != null) {
+                                cloudCallBeak.onSuccess(true);
+                            }
+                            return;
+                        }
+                        //娓呮鏈湴缃戝叧鍒楄〃
+                        HDLLinkLocalGateway.getInstance().getGatewayList().clear();
+                        for (int i = 0; i < list.size(); i++) {
+                            CloudInverterDeviceBean cloudInverterDeviceBean = list.get(i);
+                            GatewayBean gatewayBean = new GatewayBean();
+                            gatewayBean.setOid(cloudInverterDeviceBean.getOid());
+                            gatewayBean.setSid(cloudInverterDeviceBean.getSid());
+                            gatewayBean.setGatewayId(cloudInverterDeviceBean.getGatewayId());
+                            gatewayBean.setOnline(cloudInverterDeviceBean.isOnline());
+                            gatewayBean.setDevice_name(cloudInverterDeviceBean.getGatewayName());
+                            gatewayBean.setHomeId(UserConfigManage.getInstance().getHomeId());
+                            gatewayBean.setLocalEncrypt(true);
+                            gatewayBean.setMaster("true");
+                            //娣诲姞缃戝叧
+                            HDLLinkLocalGateway.getInstance().getGatewayList().add(gatewayBean);
+                        }
+                        if (cloudCallBeak != null) {
+                            cloudCallBeak.onSuccess(true);
+                        }
+
+                    }
+
+                    @Override
+                    public void onFailure(HDLException e) {
+                        if (cloudCallBeak != null) {
+                            cloudCallBeak.onFailure(e);
+                        }
+                    }
+                });
+            }
+        });
+    }
+
+    /**
+     * 鍒犻櫎鏈湴閫嗗彉鍣�
+     *
+     * @param sid 璁惧sid
+     */
+    private void removeInverter(String sid) {
+        //鑾峰彇鏈湴鐨勬绫虫尝
+        GatewayBean gatewayBean = HDLLinkLocalGateway.getInstance().getLocalGateway(sid);
+        if (gatewayBean != null) {
+            HDLLinkLocalGateway.getInstance().getGatewayList().remove(gatewayBean);
+        }
+    }
+
+    /**
+     * 鎼滅储缃戝叧鍒楄〃
+     *
+     * @param gatewayCallBack -
+     */
+    public void searchGateway(GatewayCallBack gatewayCallBack) {
+        List<String> spks = this.getGatewaySpk();
+        //缃戝叧鎼滅储
+        HDLLinkLocalGateway.getInstance().refreshGatewayByHomeIdAndSpk(UserConfigManage.getInstance().getHomeId(), spks, true, gatewayCallBack);
+    }
+
+    /**
+     * 鑾峰彇缃戝叧spk鍒楄〃
+     *
+     * @return -
+     */
+    private List<String> getGatewaySpk() {
+        List<String> spks = new ArrayList<>();
+        spks.add("energy.hdl_inverter");
+        return spks;
+    }
 }

--
Gitblit v1.8.0