From 20f70e3446df19bf5d0faaae9f7bd58fd0fc4bcc Mon Sep 17 00:00:00 2001 From: wxr <464027401@qq.com> Date: 星期五, 04 八月 2023 12:06:51 +0800 Subject: [PATCH] 轮询备份 --- Crabtree/SmartHome/UI/SimpleControl/Phone/Register/MigrationServer.cs | 313 +++++++++++++++++++++++++++++++++++++++++++++++----- 1 files changed, 283 insertions(+), 30 deletions(-) diff --git a/Crabtree/SmartHome/UI/SimpleControl/Phone/Register/MigrationServer.cs b/Crabtree/SmartHome/UI/SimpleControl/Phone/Register/MigrationServer.cs index 90e9c7c..10cf576 100644 --- a/Crabtree/SmartHome/UI/SimpleControl/Phone/Register/MigrationServer.cs +++ b/Crabtree/SmartHome/UI/SimpleControl/Phone/Register/MigrationServer.cs @@ -19,7 +19,8 @@ private bool finish = false; #if DEBUG - private string SeverAddr = "https://test-gz.hdlcontrol.com"; + //private string SeverAddr = "https://test-gz.hdlcontrol.com"; + private string SeverAddr = "https://bahrain-gateway.hdlcontrol.com"; #else private string SeverAddr = "https://bahrain-gateway.hdlcontrol.com"; #endif @@ -34,6 +35,7 @@ EditText etPwd; string pwd; string newUserId; + string newHomeId; Button btnSave; Button btnClose; @@ -185,12 +187,18 @@ #if DEBUG + - - //var moveAccontResult = Account2New ("12345678"); - //var newHomeId = Home2New (); - ////杩佺Щ缃戝叧 - //var moveGatewayResult = Gateway2New ("4D59383553502243", newHomeId, 0); + //Account2New ("12345678"); + //Home2New (); + ////杩佺Щ浜戠鍏朵粬澶囦唤 + //var moveCloudDataResult = MoveCloudBackup (); + //Application.RunOnMainThread (() => { + // btnTipMsg.Text = $"Failed to migrate cloud backup list.{moveCloudDataResult}"; + // btnTipMsg.TextColor = SkinStyle.Current.DelColor; + // loading.Hide (); + // return; + //}); #endif if (etPwd.Text.Trim() == "") { @@ -316,6 +324,7 @@ if (revertObj != null) { if (revertObj.data != null) { var newHomeInfo = Newtonsoft.Json.JsonConvert.DeserializeObject<Move_HomeInfo> (revertObj.data.ToString ()); + newHomeId = newHomeInfo.homeId; return newHomeInfo.homeId; } } @@ -372,32 +381,36 @@ /// </summary> /// <param name="newHomeId"></param> /// <returns></returns> - private string moveFolder2New (string newHomeId) + private string moveFolder2New (string newHomeId,string folderName = "") { - Dictionary<string, object> dic = new Dictionary<string, object> (); - dic.Add ("backupDataType", "HDL_ON"); - dic.Add ("homeId",newHomeId); - dic.Add ("userId",newUserId); - dic.Add ("backupClassify", "USER_DEFINED_BACKUP"); - dic.Add ("folderName", "MigrateBackup" + DateTime.Now.ToString ()); - dic.Add ("tenantId", "202106"); - var requestJson = HttpUtil.GetSignRequestJson (dic); - var revertObj = MainPage.RequestHttps ("/home-wisdom/data/move/folder/save", requestJson, false, false, SeverAddr); - if(revertObj!= null) { - if(revertObj.code == "0") { - var resultObj = Newtonsoft.Json.JsonConvert.DeserializeObject<FolderObj> (revertObj.data.ToString ()); - - return resultObj.id; + try { + Dictionary<string, object> dic = new Dictionary<string, object> (); + dic.Add ("backupDataType", "HDL_ON"); + dic.Add ("homeId", newHomeId); + dic.Add ("userId", newUserId); + dic.Add ("backupClassify", "USER_DEFINED_BACKUP"); + dic.Add ("folderName", folderName == "" ? "MigrateBackup" + DateTime.Now.ToString () : folderName); + dic.Add ("tenantId", "202106"); + var requestJson = HttpUtil.GetSignRequestJson (dic); + var revertObj = MainPage.RequestHttps ("/home-wisdom/data/move/folder/save", requestJson, false, false, SeverAddr); + if (revertObj != null) { + if (revertObj.code == "0") { + var resultObj = Newtonsoft.Json.JsonConvert.DeserializeObject<FolderObj> (revertObj.data.ToString ()); + + return resultObj.id; + } } + return ""; + } catch { + return ""; } - return ""; } - private string MoveFile2New(string newHomeId,string backupId) + private string MoveFile2New(string backupId) { Dictionary<string, object> dic = new Dictionary<string, object> (); - dic.Add ("backupId", backupId);//1534728347497418754//1534728860322385922 + dic.Add ("backupId", backupId); dic.Add ("homeId", newHomeId); dic.Add ("userId", newUserId); dic.Add ("backupClassify", "USER_DEFINED_BACKUP"); @@ -430,7 +443,7 @@ continue; } } - } + } } if (!dic.ContainsKey ("list")) { dic.Add ("list", fileObjs); @@ -446,6 +459,128 @@ } return ""; } + + /// <summary> + /// 杩佺Щ鏃т簯绔浠藉垪琛ㄥ埌鏂颁簯绔� + /// </summary> + /// <returns></returns> + private void MoveOldBackupList () + { + try { + GetUserFolderObj requestObj = new GetUserFolderObj () { LevelID = UserConfig.Instance.CurrentRegion.RegionID }; + var requestJson = Newtonsoft.Json.JsonConvert.SerializeObject (requestObj); + var revertObj = MainPage.RequestHttps ("GetUserFolder", requestJson, true, false);//鑾峰彇鏃ф湇鍔″櫒澶囦唤鍒楄〃 + if (revertObj.StateCode == "SUCCESS") { + var responseDataObj = Newtonsoft.Json.JsonConvert.DeserializeObject<List<FolderRes>> (revertObj.ResponseData.ToString ()); + int index = 1; + foreach (var folder in responseDataObj) { + Application.RunOnMainThread (() => { + try { + btnTipMsg.Text = $"Migrating server backup {index} / {responseDataObj.Count + 1}."; + btnTipMsg.TextColor = SkinStyle.Current.TextColor; + } catch { } + }); + try { + var requestObj2 = new UserBackupListObj () { LevelID = folder.FolderID }; + var requestJson2 = Newtonsoft.Json.JsonConvert.SerializeObject (requestObj2); + var revertObj2 = MainPage.RequestHttps ("UserBackupList", requestJson2);//涓嬭浇鏃ф湇鍔″櫒鐨勫浠芥枃浠跺垪琛� + if (revertObj2.StateCode == "SUCCESS") { + var newFolderId = moveFolder2New (newHomeId, folder.FolderName);//鍦ㄦ柊鏈嶅姟鍣ㄥ垱寤烘柊鐨勫浠�,鑾峰彇澶囦唤ID + if (string.IsNullOrEmpty (newFolderId)) {//濡傛灉鏂版湇鍔″櫒澶囦唤ID涓虹┖锛屽彲鑳芥姤閿欎簡锛屾柊鏈嶅姟鍣ㄥ彲鑳藉凡缁忓瓨鍦ㄨ繖涓浠� + var backupInfoRes = Newtonsoft.Json.JsonConvert.DeserializeObject<List<BackupInfoRes>> (revertObj2.ResponseData.ToString ()); + MoveOldBackupFile2New (newFolderId, backupInfoRes); + } + } + } catch { } + } + } + } catch { + } + } + + /// <summary> + /// 杩佺Щ鏃ф湇鍔″櫒澶囦唤鏂囦欢鍒版柊鏈嶅姟鍣� + /// </summary> + /// <param name="backupId"></param> + /// <returns></returns> + private string MoveOldBackupFile2New ( string backupId, List<BackupInfoRes> responseDataObj) + { + Dictionary<string, object> dic = new Dictionary<string, object> (); + dic.Add ("backupId", backupId); + dic.Add ("homeId", newHomeId); + dic.Add ("userId", newUserId); + dic.Add ("backupClassify", "USER_DEFINED_BACKUP"); + dic.Add ("tenantId", "202106"); + + List<BackupFileObj> fileObjs = new List<BackupFileObj> (); + + int index = 0; + foreach (var file in responseDataObj) { + var fileName = file.FileName; + if (fileName == "null" || "UserConfig" == fileName || fileName == UserInfo.GlobalRegisterFile) { + continue; + } + index++; + var requestObj3 = new BackupDetailObj () { Id = file.Id }; + var requestJson3 = Newtonsoft.Json.JsonConvert.SerializeObject (requestObj3); + var revertObj3 = MainPage.RequestHttps ("BackupDetail", requestJson3);//涓嬭浇鏃ф湇鍔″櫒鐨勫浠芥枃浠� + if (revertObj3.StateCode == "SUCCESS") { + var jsonBytes = Newtonsoft.Json.JsonConvert.SerializeObject (revertObj3.ResponseData); + var byresss = Newtonsoft.Json.JsonConvert.DeserializeObject<byte []> (jsonBytes); + BackupFileObj backupFileObj = new BackupFileObj () { fileName = fileName, content = byresss }; + fileObjs.Add (backupFileObj); + + if (fileObjs.Count > 9) { + if (!dic.ContainsKey ("list")) { + dic.Add ("list", fileObjs); + } + var json = HttpUtil.GetSignRequestJson (dic); + var revertObj_foreach = MainPage.RequestHttps ("/home-wisdom/data/move/file/save", json, false, false, SeverAddr); + if (revertObj_foreach != null) { + if (revertObj_foreach.code == "0") { + fileObjs.Clear (); + continue; + } + } + } + } + } + if (!dic.ContainsKey ("list")) { + dic.Add ("list", fileObjs); + } + var requestJson = HttpUtil.GetSignRequestJson (dic); + var revertObj = MainPage.RequestHttps ("/home-wisdom/data/move/file/save", requestJson, false, false, SeverAddr); + if (revertObj != null) { + if (revertObj.code == "0") { + return "true"; + } + } + return ""; + } + + + + /// 杩佺Щ鏈嶅姟鍣ㄥ叏閮ㄥ浠� + /// </summary> + private string MoveCloudBackup () + { + var dic = new Dictionary<string, object> (); + dic.Add ("oldPlatformToken", MainPage.LoginUser.LoginTokenString);//鏃у钩鍙皌oken + dic.Add ("oldPlatformHomeId", UserConfig.Instance.CurrentRegion.RegionID);//鏃у钩鍙颁綇瀹卛d + dic.Add ("homeId", newHomeId);//鏂板钩鍙颁綇瀹卛d + dic.Add ("userId", newUserId);//鏂板钩鍙扮敤鎴穒d + dic.Add ("tenantId", "202106");//绉熸埛id + var requestJson = HttpUtil.GetSignRequestJson (dic); + var revertObj = MainPage.RequestHttps ("/home-wisdom/data/move/backup/all", requestJson, false, false, SeverAddr); + if (revertObj != null) { + if (revertObj.code == "0") { + + } + return revertObj.code; + } + return "-99"; + } + /// <summary> /// 鑾峰彇瀹氭椂鍣ㄥ垪琛� /// </summary> @@ -554,8 +689,6 @@ GatewayBase common = null; string gateWayString = ""; if (gateWayList.Count > 0) { - - foreach (var gatewayFileName in gateWayList) { var tempStrings = gatewayFileName.Split ('_'); if (tempStrings [1].ToString () == DeviceType.OnePortBus.ToString () || tempStrings [1].ToString () == DeviceType.RCU.ToString () || @@ -732,7 +865,7 @@ return; } //杩佺Щ浣忓畢锛岃幏鍙栨柊鐨刪omeid - var newHomeId = Home2New (); + newHomeId = Home2New (); if (newHomeId == "") { Application.RunOnMainThread (() => { btnTipMsg.Text = "Home migration failed. Please try again."; @@ -764,6 +897,8 @@ //鑾峰彇涓婄綉绉橀挜 var netKet = GetInternetAccessKey (common.MAC.Replace (".", "")); + + if (!string.IsNullOrEmpty (netKet)) { Application.RunOnMainThread (() => { btnTipMsg.Text = "The Internet access key was obtained successfully. It is being written."; @@ -794,6 +929,110 @@ return; }); } + +#if DEBUG + System.Threading.Thread.Sleep (5000); +#endif + + CommonPage.FindGateway = true; + try { + #region 鎼滅储璁惧 + CommonPage.LocalPhoneFindDevice = true; + CommonPage.RandomHigh = (byte)new Random ().Next (255); + CommonPage.RandomLow = (byte)new Random ().Next (255); + CommonPage.GateWayList.Clear (); + CommonPage.FindGateway = true; + //濡傛灉涓ゆ閮芥病鏈夋暟鎹弽棣堬紝灏变笉璇诲彇 + int readCount = 2; + while (0 < readCount) { + readCount--; + System.IO.MemoryStream ms = new System.IO.MemoryStream (); + ms.WriteByte (CommonPage.RandomHigh); + ms.WriteByte (CommonPage.RandomLow); + + List<Common> list = CommonPage.GateWayList; + + int tempCount = list.Count; + string s = ";"; + for (int i = 0; i < list.Count; i++) { + Common common2 = list [i]; + if (s.Contains (";" + common2.SubnetID.ToString () + ":" + common2.DeviceID.ToString ())) + continue; + s += common2.SubnetID.ToString () + ":" + common2.DeviceID.ToString () + ";"; + ms.WriteByte (common2.SubnetID); + ms.WriteByte (common2.DeviceID); + } + Control control = new Control (); + + Console.WriteLine ("缁勬挱鎼滅储缃戝叧锛屾悳绱㈠湴鍧�鏄�:" + CommonPage.EndPoint.ToString () + " " + CommonPage.GateWayList.Count); + control.Send (new Target () { + IPEndPoint = CommonPage.EndPoint, + Command = Command.ReadGateway, + SubnetID = 0xFF, + DeviceID = 0xFF, + AddData = ms.ToArray () + }, SendCount.Zero, false); + + Console.WriteLine ("骞挎挱鎼滅储缃戝叧锛屾悳绱㈠湴鍧�鏄�:" + new Net.NetWiFi ().BroadcastIpAddress.ToString () + " " + CommonPage.GateWayList.Count); + control.Send (new Target () { + IPEndPoint = new System.Net.IPEndPoint (new Net.NetWiFi ().BroadcastIpAddress, 6000), + Command = Command.ReadGateway, + SubnetID = 0xFF, + DeviceID = 0xFF, + AddData = ms.ToArray () + }, SendCount.Zero, false); + + System.Threading.Thread.Sleep (800); + //濡傛灉鏁伴噺涓嶇浉绛夛紝灏遍噸缃鏁� + if (tempCount != CommonPage.GateWayList.Count) { + readCount = 2; + } + } + CommonPage.FindGateway = false; + + CommonPage.LocalPhoneFindDevice = false; + #endregion + } catch (Exception ex) { + Console.WriteLine (ex.ToString ()); + } finally { + if (CommonPage.GateWayList.Count > 0) { + foreach (var gateway1 in CommonPage.GateWayList) { + var bingResidenceIdBytes = Control.ControlBytesSendHasReturn (Command.Read_APP_Data_STORE_1D5C_CMD, common.SubnetID, common.DeviceID, new byte [] { }); + if (bingResidenceIdBytes == null) { + continue; + } + int bingResideceId = 0; + for (int i = 0; i < bingResidenceIdBytes.Length; i++) { + bingResideceId += (int)(bingResidenceIdBytes [i] * Math.Pow (256, 3 - i)); + } + if (bingResideceId != UserConfig.Instance.CurrentRegion.RegionID && bingResideceId != 0) { + } else { + //鍐欏叆涓婄綉绉橀挜 + writeSecretKeyResult = WriteSecretKey (gateway1.SubnetID, gateway1.DeviceID, secretkeySendBytes); + if (writeSecretKeyResult) { + Application.RunOnMainThread (() => { + btnTipMsg.Text = "The Internet access key was written successfully."; + }); + } else { + Application.RunOnMainThread (() => { + btnTipMsg.Text = "Failed to write Internet secret key."; + btnTipMsg.TextColor = SkinStyle.Current.DelColor; + }); + } +#if DEBUG + System.Threading.Thread.Sleep (5000); +#endif + + } + } + } + } + + + + + + } else { Application.RunOnMainThread (() => { btnTipMsg.Text = "Failed to obtain the Internet secret key. Please try again."; @@ -803,7 +1042,6 @@ } //鍐欏叆mqtt鍩熷悕淇℃伅 SetGateWayMqttUrlAddress (common.SubnetID, common.DeviceID); - //杩佺Щ缃戝叧 var moveGatewayResult = Gateway2New (common.MAC.Replace (".", ""), newHomeId, common.SubnetID); @@ -820,10 +1058,25 @@ }); return; } + //杩佺Щ浜戠鍏朵粬澶囦唤 + var moveCloudDataResult = MoveCloudBackup (); + if (moveCloudDataResult != "0") { + Application.RunOnMainThread (() => { + btnTipMsg.Text = $"Failed to migrate cloud backup list.{moveCloudDataResult}"; + btnTipMsg.TextColor = SkinStyle.Current.DelColor; + loading.Hide (); + return; + }); + } //鍒涘缓杩佺Щ澶囦唤鏂囦欢澶� var backId = moveFolder2New (newHomeId); //杩佺Щ澶囦唤鏂囦欢 - var moveFileResult = MoveFile2New (newHomeId, backId); + var moveFileResult = MoveFile2New (backId); + // Application.RunOnMainThread (() => { + // btnTipMsg.Text = "Migrating server backup."; + // btnTipMsg.TextColor = SkinStyle.Current.TextColor; + // }); + // MoveOldBackupList (); if (moveFileResult == "true") { Application.RunOnMainThread (() => { btnTipMsg.Text = "Migration backup succeeded, migrating Schedule data."; -- Gitblit v1.8.0