From df93e50c747a585aa3acad599ba9be7d9617872d Mon Sep 17 00:00:00 2001 From: wxr <464027401@qq.com> Date: 星期四, 21 四月 2022 10:28:48 +0800 Subject: [PATCH] Merge remote-tracking branch 'origin/wjc' into Dev-Branch --- HDL_ON/DAL/DriverLayer/Control.cs | 112 ++++++++++++++++++++++++++++++++++++++++++++++++------- 1 files changed, 97 insertions(+), 15 deletions(-) diff --git a/HDL_ON/DAL/DriverLayer/Control.cs b/HDL_ON/DAL/DriverLayer/Control.cs index 3eafb36..66e423f 100644 --- a/HDL_ON/DAL/DriverLayer/Control.cs +++ b/HDL_ON/DAL/DriverLayer/Control.cs @@ -26,7 +26,7 @@ public class Control { - + static Control _control; public static Control Ins { @@ -360,10 +360,11 @@ /// <param name="function"></param> /// <param name="useRemote">鏄惁鐩存帴浣跨敤杩滅▼鍙戦��</param> /// <returns></returns> - public void SendWriteCommand(Function function, Dictionary<string, string> commandDictionary, bool useRemote = false,int resend = 3) + public bool SendWriteCommand(Function function, Dictionary<string, string> commandDictionary, bool useRemote = false,int resend = 3) { function.controlCounter++; function.refreshTime = DateTime.Now; + //濡傛灉鏄帶鍒惰皟鍏夌殑寮�鏃讹紝浜害鍊间笉鑳戒负0 if (commandDictionary.Count > 2) @@ -404,7 +405,7 @@ upDataObj.objects.Add(asd); revString = Newtonsoft.Json.JsonConvert.SerializeObject(upDataObj); UpdataFunctionStatus(revString, null, true); - return; + return true; } @@ -493,6 +494,8 @@ } } + + return true; } /// <summary> /// 鍏ㄥ紑鍏ㄥ叧鍔熻兘 @@ -754,7 +757,7 @@ //2.Body瀛楃涓茶浆涓篵yte鏁扮粍 byte[] bodyBytes = Encoding.UTF8.GetBytes(bodyDataString); //鍒ゆ柇鏄惁闇�鍔犲瘑Body鏁版嵁 - //if (isEncryption && IsLocalEncryptAndGetAesKey) + if (isEncryption && IsLocalEncryptAndGetAesKey) { bodyBytes = Securitys.EncryptionService.AesEncryptPayload(bodyBytes, DB_ResidenceData.Instance.CurrentRegion.localSecret); //bodyDataString = Encoding.UTF8.GetString(bodyBytes); @@ -769,8 +772,8 @@ topicAndLengthBytes.CopyTo(sendDataBytes, 0); bodyBytes.CopyTo(sendDataBytes, topicAndLengthBytes.Length); - //var sendDataString = Encoding.UTF8.GetString(sendDataBytes); - //MainPage.Log($"杞崲HDL-Link鏁版嵁\r\n{sendDataString}\r\n"); + var sendDataString = Encoding.UTF8.GetString(sendDataBytes); + MainPage.Log($"杞崲HDL-Link鏁版嵁\r\n{sendDataString}\r\n"); //*************************************************************** return sendDataBytes; @@ -866,7 +869,7 @@ if (receiveObj.Topic == CommunicationTopic.SearchLoaclGatewayReply || receiveObj.Topic == CommunicationTopic.GatewayBroadcast) { - + var bodyJObj = Newtonsoft.Json.JsonConvert.DeserializeObject<ResponsePack>(res[1]); if (bodyJObj == null) { @@ -948,6 +951,7 @@ /// <summary> /// 鏇存柊璁惧鐘舵�� /// A鍗忚鏁版嵁 + /// Tag Link鐘舵�佸鐞� /// </summary> /// <param name="updateBytes"></param> public void UpdataFunctionStatus(string revString, byte[] usefulBytes,bool isCloudData = false) @@ -980,7 +984,6 @@ var localFunction = allLocalFuntion.Find((obj) => obj.sid == updateTemp.sid); if (localFunction == null) { - MainPage.Log("鎵句笉鍒伴煶涔愭挱鏀惧櫒娣�=======" + revString); continue; } MainPage.Log(localFunction.name); @@ -1063,6 +1066,10 @@ RollingShutterPage.UpdataState(localFunction); break; case SPK.CurtainShades: + break; + case SPK.HvacCac: + Stan.HdlDeviceStatuPushLogic.Current.UpdateDeviceStatu(updateTemp.sid, updateTemp.status); + break; case SPK.AcStandard: case SPK.HvacAC: @@ -1195,7 +1202,7 @@ case SPK.AvMusic: case SPK.MusicStandard: //UI.Music.MusicMain.mMusicMain.RefreshView(updateTemp); - Console.WriteLine("闊充箰鎾斁鍣ㄦ樉绀虹姸鎬�======="+ revString); + //Console.WriteLine("闊充箰鎾斁鍣ㄦ樉绀虹姸鎬�======="+ revString); //wjc break; } @@ -1233,16 +1240,91 @@ } else { - Dictionary<string, object> d = new Dictionary<string, object>(); - d.Add("homeId", DB_ResidenceData.Instance.CurrentRegion.id); - d.Add("deviceId", doorlock.deviceId); - var requestJson = HttpUtil.GetSignRequestJson(d); - HttpUtil.RequestHttpsPost("/home-wisdom/app/device/door/remoteOpen", requestJson); + ConfirmUnlocking(doorlock.deviceId, extStr); } + } + /// <summary> + /// 纭寮�閿� + /// </summary> + /// <param name="functionId"></param> + /// <param name="pwd"></param> + public void ConfirmUnlocking(string functionId,string pwd) + { + Loading loading = new Loading(); + MainPage.BaseView.AddChidren(loading); + loading.BackgroundColor = 0x88000000; + loading.LodingBackgroundColor = UI.CSS.CSS_Color.BackgroundColor; + loading.Start(Language.StringByID(StringId.PleaseWait)); + new System.Threading.Thread(() => + { + try + { + Dictionary<string, object> d = new Dictionary<string, object>(); + d.Add("homeId", DB_ResidenceData.Instance.CurrentRegion.id); + d.Add("deviceId", functionId); + d.Add("pwd", pwd); + var requestJson = HttpUtil.GetSignRequestJson(d); + var pack = HttpUtil.RequestHttpsPost("/home-wisdom/app/device/door/pwdConfirm", requestJson); + if (pack.Code == StateCode.SUCCESS) + { + Newtonsoft.Json.Linq.JObject pairs = Newtonsoft.Json.Linq.JObject.Parse(pack.Data.ToString()); + var scrip = pairs.GetValue("scrip"); + + d = new Dictionary<string, object>(); + d.Add("homeId", DB_ResidenceData.Instance.CurrentRegion.id); + d.Add("deviceId", functionId); + d.Add("scrip", scrip); + requestJson = HttpUtil.GetSignRequestJson(d); + pack = HttpUtil.RequestHttpsPost("/home-wisdom/app/device/door/remoteOpen", requestJson); + //if(pack.Code == StateCode.SUCCESS) + //{ + // return true; + //} + //else + //{ + // return false; + //} + if (pack.Code != StateCode.SUCCESS) { + Application.RunOnMainThread(() => { + new PublicAssmebly().TipMsg(Language.StringByID(StringId.Tip), pack.message); + UserInfo.Current.doorPasswordString = "";// + UserInfo.Current.LastTimeOpenDoor = DateTime.MinValue; + }); + } + } + if (pack.Code != StateCode.SUCCESS) + { + Application.RunOnMainThread(() => { + if(string.IsNullOrEmpty(pack.message)) + { + new PublicAssmebly().TipMsg(Language.StringByID(StringId.Tip), + Language.StringByID(StringId.OperationFailed)); + } + else + { + new PublicAssmebly().TipMsg(Language.StringByID(StringId.Tip), pack.message); + } + }); + } + } + catch (Exception ex) + { + + } + finally + { + Application.RunOnMainThread(() => + { + loading.Hide(); + loading.RemoveFromParent(); + }); + } + }) + { IsBackground = true }.Start(); } //瀵嗙爜鍐荤粨 //瀵嗙爜楠岃瘉 #endregion } -} \ No newline at end of file +} -- Gitblit v1.8.0