From a93db4940a37fd73a37dd9b237c16e744e36f9ea Mon Sep 17 00:00:00 2001
From: wxr <464027401@qq.com>
Date: 星期二, 30 八月 2022 10:24:45 +0800
Subject: [PATCH] 迁移升级网关之后修改网关子网号

---
 Crabtree/SmartHome/UI/SimpleControl/Phone/Register/MigrationServer.cs |   70 ++++++++++++++++++++++++++---------
 1 files changed, 52 insertions(+), 18 deletions(-)

diff --git a/Crabtree/SmartHome/UI/SimpleControl/Phone/Register/MigrationServer.cs b/Crabtree/SmartHome/UI/SimpleControl/Phone/Register/MigrationServer.cs
index 19d329c..fb2a5fb 100644
--- a/Crabtree/SmartHome/UI/SimpleControl/Phone/Register/MigrationServer.cs
+++ b/Crabtree/SmartHome/UI/SimpleControl/Phone/Register/MigrationServer.cs
@@ -163,14 +163,12 @@
 
 #if DEBUG
 
-                //SetGateWayMqttUrlAddress (1, 0);
-                //WriteSecretKey (1, 0, new byte [] {1,1,2,3,2,3,4,5,2,3,5,6 });
-                //CheckGateway ();
 
-                //var newHomeId = Home2New ();
-                //if (newHomeId == "") { } else { }
-                //Account2New (etPwd.Text.Trim());
-                //return;
+
+                var moveAccontResult = Account2New ("12345678");
+                var newHomeId = Home2New ();
+                //杩佺Щ缃戝叧
+                var moveGatewayResult = Gateway2New ("4D59383553502243", newHomeId, 0);
 #endif
 
                 if (etPwd.Text.Trim() == "") {
@@ -559,16 +557,26 @@
                             }
                             var visionString = Encoding.GetEncoding ("gb2312").GetString (bytes);
 
-
                             int result = -99;
 
-
-                            if (visionString.Contains("Ind_V03.01U_2021/07/12")) {
+                            if (visionString.Contains ("Ind_C03.02U_2022/06/22")) {
                                 Application.RunOnMainThread (() => {
                                     btnTipMsg.Text = "Gateway firmware has been upgraded, initializing gateway.";
                                     btnTipMsg.TextColor = SkinStyle.Current.TextColor;
                                 });
                                 result = 100;
+                            //} else if (!visionString.Contains ("Ind_V02.35U_2019/06/25")) {//鐩墠鍙厑璁稿崌绾ц繖涓浐浠剁殑缃戝叧
+                            //    Application.RunOnMainThread (() => {
+                            //        btnTipTitle.Text = "The gateway does not support automatic migration. Please contact technical support.";
+                            //        btnTipTitle.Height = Application.GetRealHeight (150);
+                            //        btnTipTitle.TextColor = SkinStyle.Current.DelColor;
+                            //        btnTipMsg.Text = "";
+                            //        etPwd.Visible = false;
+                            //        loading.Hide ();
+                            //        btnSave.Visible = false;
+                            //        btnClose.Width = Application.GetRealWidth (500);
+                            //    });
+                            //    return;
                             } else {
                                 Application.RunOnMainThread (() => {
                                     btnTipMsg.Text = "Upgrading gateway.";
@@ -589,7 +597,7 @@
                                 while (true) {
                                     var ub = MainPage.GatewayStatus.Split ("_");
                                     if (ub.Length > 1) {
-                                         result = Convert.ToInt32 (ub [1]);
+                                        result = Convert.ToInt32 (ub [1]);
                                         //if (result < result0 && result0 < 100)
                                         {
                                             //result = result0;
@@ -611,24 +619,26 @@
                                             btnTipMsg.Text = "Gateway upgrade succeeded. Initializing gateway.";
                                             btnTipMsg.TextColor = SkinStyle.Current.TextColor;
                                         });
+                                        //鍒濆鍖栨爣璁�
+                                        MainPage.GatewayStatus = "";
                                         break;
-                                    }
-                                     else {
+                                    } else {
                                         if (upgradeData.Count >= result) {
-                                            var listPack = upgradeData [result-1];//
+                                            var listPack = upgradeData [result - 1];//
                                             byte [] packData = new byte [2 + listPack.Count];
                                             packData [0] = Convert.ToByte (result / 256);
-                                            packData [1] = Convert.ToByte (result % 256 );
+                                            packData [1] = Convert.ToByte (result % 256);
                                             Array.Copy (listPack.ToArray (), 0, packData, 2, listPack.Count);
-                                            Console.WriteLine ("packId"+result);
+                                            Console.WriteLine ("packId" + result);
                                             SendUpgradeData (common.SubnetID, common.DeviceID, packData);
 
                                         }
                                     }
                                 }
                             }
-
-
+                            //閲嶆柊璁剧疆涓�涓嬪瓙缃戝彿
+                            SetSubnetId (common);
+                            System.Threading.Thread.Sleep (1000);
 
                             if (result == 100) {
 
@@ -651,6 +661,8 @@
                                     if (MainPage.GatewayStatus != "Initialization_complete") {
                                         System.Threading.Thread.Sleep (100);
                                     } else if (initiaIndex == 0) {
+                                        //鍒濆鍖栨爣璁�
+                                        MainPage.GatewayStatus = "";
                                         Application.RunOnMainThread (() => {
                                             btnTipMsg.Text = "Successfully initialized the gateway. Opening the gateway remote configuration.";
                                             btnTipMsg.TextColor = SkinStyle.Current.TextColor;
@@ -920,6 +932,28 @@
         }
 
         /// <summary>
+        /// 璁剧疆瀛愮綉鍙�
+        /// </summary>
+        /// <param name="gatewayDevice"></param>
+        private void SetSubnetId (GatewayBase gatewayDevice)
+        {
+            string [] macAddress = gatewayDevice.MAC.Split ('.');
+                byte [] Musics = new byte [10];
+                for (int i = 0; i < macAddress.Length; i++) {
+                    Musics [i] = Convert.ToByte (macAddress [i], 16);
+                }
+                try {
+                    Musics [8] = Convert.ToByte (Convert.ToInt32 (gatewayDevice.SubnetID));
+                    if (Musics [8] < 0 || Musics [8] > 255) {
+                        throw new Exception ();
+                    }
+                } catch {
+                    return;
+                }
+                Control.ControlBytesSend (Command.SetDeviceSubnetID, gatewayDevice.SubnetID, gatewayDevice.DeviceID, Musics);
+        }
+
+        /// <summary>
         /// 璁惧缃戝叧寮�鍚繙绋�
         /// </summary>
         private bool SetGatewayRemote(byte subnetId, byte deviceId)

--
Gitblit v1.8.0