///* //更新了EMQ连接方式 //*/ //using System.Collections.Generic; //using System; //using MQTTnet.Client; //using System.Threading.Tasks; //using Shared; //using MQTTnet; //using System.Text; //using System.Security.Cryptography; //namespace HDL_ON //{ // public static class MqttCommon // { // /// // /// 是否提示 远程连接的错误信息 // /// // public static bool IfDEBUG = false; // static string mqttEncryptKey = ""; // //static string checkGatewayTopicBase64 = ""; // static readonly string PushNotifySqueeze = "/Push/NotifySqueeze"; // static string RandomKey = ""; // static string GetRandomKey() // { // if (string.IsNullOrEmpty(RandomKey)) // { // //随机2位字符串 // RandomKey = Utlis.CreateRandomString(2); // } // return RandomKey; // } // /// // /// 是否获取MQTT参数成功 // /// // //public static bool MqttInfoConfig.Instance.IfGetMqttInfoSuccess = false; // //static RemoteMACInfo CurRemoteMACInfo = null; // //static MqttInfo mMqttInfo = null; // ///// // ///// 手机标识 // ///// // //static Guid currentGuid = Guid.NewGuid (); // //static bool thisShowTip = true; // //static string mqttRequestParToken=""; // /// // /// 远程MqttClient // /// // public static IMqttClient RemoteMqttClient = new MqttFactory().CreateMqttClient(); // /// // /// 推送标识 // /// // static string PushSignStr = System.DateTime.Now.Ticks.ToString(); // /// // /// 断开远程Mqtt的链接 // /// // static async System.Threading.Tasks.Task DisConnectRemoteMqttClient(string s = "") // { // try // { // if (remoteIsConnected) // { // remoteIsConnected = false; // isSubscribeSuccess = false; // MainPage.Log($"Remote主动断开_{s}"); // //await RemoteMqttClient.DisconnectAsync(new MQTTnet.Client.Disconnecting.MqttClientDisconnectOptions { }, CancellationToken.None); // await RemoteMqttClient.DisconnectAsync(); // if (CommonPage.IsRemote) // { // //不是无网络 // if (UserConfig.Instance.internetStatus != 0) // { // Utlis.ShowAppLinkStatus(AppLinkStatus.CloudUnlink); // } // } // } // } // catch (Exception e) // { // MainPage.Log($"Remote断开通讯连接出异常:{e.Message}"); // } // } // /// // /// 断开远程Mqtt的链接 // /// // static async Task DisConnectRemoteMqttClientWhenStart(string s = "") // { // try // { // //if (remoteIsConnected) { // remoteIsConnected = false; // isSubscribeSuccess = false; // MainPage.Log($"RemoteStart主动断开_{s}"); // await RemoteMqttClient.DisconnectAsync(); // //} // } // catch (Exception e) // { // MainPage.Log($"RemoteStart断开通讯连接出异常:{e.Message}"); // } // } // /// // /// 断开mqtt连接 // /// // /// 断开原因 // /// 是否需要去中心服务器 重新获取参数 // /// // public static async Task DisConnectRemote(string s = "", bool reset = true) // { // if (reset) // { // bNeedStartTip = true; // bNeedConnectTip = true; // MqttInfoConfig.Instance.IfGetMqttInfoSuccess = false; // } // await DisConnectRemoteMqttClient(s); // } // //static DateTime dateTime = DateTime.MinValue; // /// // /// 外网的MQTT是否正在连接 // /// // public static bool remoteMqttIsConnecting; // static bool remoteIsConnected; // static MqttCommon() // { // InitMqtt(); // } // public static bool IsInitMqtt = false; // static void InitMqtt() // { // new System.Threading.Thread(async () => // { // while (true) // { // try // { // System.Threading.Thread.Sleep(200); // //if (!MainPage.LoginUser.IsLogin) { // // continue; // //} // if (!CommonPage.IsRemote) continue; // //#if Android // if (BusSocket.IsEnterBackground) continue; // //#endif // await StartCloudMqtt(); // await SubscribeTopics(); // } // catch { } // } // }) // { IsBackground = true }.Start(); // } // public static void InitState() // { // IfNeedReadAllDeviceStatus = true; // bNeedStartTip = true; // bNeedConnectTip = true; // IsGatewayOnline = false; // StartCloudMqtt(); // } // static bool isSubscribeSuccess; // static async Task SubscribeTopics() // { // if (remoteIsConnected && !isSubscribeSuccess) // { // try // { // //var topicFilterPush = new TopicFilter { QualityOfServiceLevel = MQTTnet.Protocol.MqttQualityOfServiceLevel.ExactlyOnce, // // Topic = $"/BusGateWayToClient/{MqttInfoConfig.Instance.CurRemoteMACInfo.clientId}/Push/NotifySqueeze" }; // //2020-05-14 订阅主题质量改为0 // var topicFilterBusGateWayToClient = new TopicFilter() // { // Topic = $"/BusGateWayToClient/{MqttInfoConfig.Instance.CurRemoteMACInfo.macMark}/#", // QualityOfServiceLevel = MQTTnet.Protocol.MqttQualityOfServiceLevel.AtMostOnce // //QualityOfServiceLevel = MQTTnet.Protocol.MqttQualityOfServiceLevel.ExactlyOnce // }; // var topicFilterPush2 = new TopicFilter // { // Topic = $"/BusGateWayToClient/{MainPage.LoginUser.ID}" + PushNotifySqueeze, // QualityOfServiceLevel = MQTTnet.Protocol.MqttQualityOfServiceLevel.AtMostOnce, // //QualityOfServiceLevel = MQTTnet.Protocol.MqttQualityOfServiceLevel.ExactlyOnce // }; // Utlis.WriteLine("开始订阅!"); // var result = await RemoteMqttClient.SubscribeAsync(new TopicFilter[] { topicFilterBusGateWayToClient, topicFilterPush2 }); // if (result.Items[0].ResultCode == MQTTnet.Client.Subscribing.MqttClientSubscribeResultCode.GrantedQoS0) // { // isSubscribeSuccess = true; // Utlis.WriteLine("订阅成功!"); // MainPage.AddTip(Language.StringByID(Shared.SimpleControl.R.MyInternationalizationString.SubscriptionSuccessful)); // MqttRemoteSend(new byte[] { 0 }, 3); // //读取搜索网关,判断网关是否在线 // CheckGatewaysIfOnline(); // //连接成功后检测是否需要通过远程获取Key // CheckIfNeedGetLocalPasswordFromRemote(); // } // } // catch (Exception ex) // { // Console.WriteLine("订阅catch:" + ex.Message.ToString()); // } // } // } // static DateTime mFlagDateTime; // //static readonly object SendLocker = new object (); // /// // /// 启动远程Mqtt // /// // public static async Task StartCloudMqtt() // { // if (UserConfig.Instance.internetStatus == 0) // { // return; // } // if (!MainPage.LoginUser.IsLogin) // { // return; // } // ////60S后强制重置isConnectiong状态,防止isConnectiong一直为true状态 // //if (mFlagDateTime.AddSeconds (60).Ticks <= System.DateTime.Now.Ticks) { // // mFlagDateTime = DateTime.Now; // // if (remoteMqttIsConnecting) { // // MainPage.Log ("60s》remoteMqttIsConnecting true "); // // remoteMqttIsConnecting = false; // // } // //} // //MainPage.Log ($"remoteMqttIsConnecting: " + remoteMqttIsConnecting.ToString()); // //追加:没有远程连接的权限 // if (remoteMqttIsConnecting || remoteIsConnected) // { // return; // } // //lock (SendLocker) { // // remoteMqttIsConnecting = true; // //} // remoteMqttIsConnecting = true; //#if DEBUG // MainPage.Log($"StartCloudMqtt: 开始"); //#endif // await Task.Factory.StartNew(async () => // { // try // { // //lock (RemoteMqttClient) { // // //表示后面将进行连接 // // remoteMqttIsConnecting = true; // #region 初始化远程Mqtt // RemoteMqttClient = new MqttFactory().CreateMqttClient(); // //(1)当[连接云端的Mqtt成功后]或者[以及后面App通过云端Mqtt转发数据给网关成功后],处理接收到云端数据包响应时在mqttServerClient_ApplicationMessageReceived这个方法处理 // if (RemoteMqttClient.ApplicationMessageReceivedHandler == null) // { // RemoteMqttClient.UseApplicationMessageReceivedHandler((e) => // { // try // { // var topic = e.ApplicationMessage.Topic; // //Utlis.WriteLine ("回复Topic={0}", topic); // //if (topic == $"/BusGateWayToClient/{MqttInfoConfig.Instance.CurRemoteMACInfo.clientId}/Push/NotifySqueeze") { // // var mMes = System.Text.Encoding.UTF8.GetString (e.ApplicationMessage.Payload); // // //收到挤下线主题 // // ReceiveNotifySqueezeAsync (mMes); // //} else // if (topic == $"/BusGateWayToClient/{MainPage.LoginUser.ID}" + PushNotifySqueeze) // { // var mMes = System.Text.Encoding.UTF8.GetString(e.ApplicationMessage.Payload); // //新挤下线主题方案 收到挤下线主题 // ReceiveNotifySqueezeAsync(mMes); // } // else if (topic == $"/BusGateWayToClient/{MqttInfoConfig.Instance.CurRemoteMACInfo.macMark}/NotifyBusGateWayInfoChange") // {//网关上线,需要更新aeskey // //收到网关上线消息主题 // ReceiveNotifyBusGateWayInfoChange(); // } // else if (topic == $"/BusGateWayToClient/{MqttInfoConfig.Instance.CurRemoteMACInfo.macMark}/NotifyGateWayOffline") // {//网关掉线 //----第二步:读取账号下面的网关列表 // ReceiveNotifyGateWayOffline(); // } // else if (topic == $"/BusGateWayToClient/{MqttInfoConfig.Instance.CurRemoteMACInfo.macMark}/Common/CheckGateway") // { // var ss = System.Text.Encoding.UTF8.GetString(e.ApplicationMessage.Payload); // ReceiveCheckGateway(ss); // } // else // { // SetGatewayOnlineResetCheck(); // var packet = new Packet(); // if (!string.IsNullOrEmpty(mqttEncryptKey)) // { // packet.Bytes = Shared.Securitys.EncryptionService.AesDecryptPayload(e.ApplicationMessage.Payload, mqttEncryptKey); // } // else // { // packet.Bytes = e.ApplicationMessage.Payload; // } // packet.IsLocal = false; // packet.Manager(); // } // } // catch { } // }); // } // //(2)DisconnectedHandler // if (RemoteMqttClient.DisconnectedHandler == null) // { // RemoteMqttClient.UseDisconnectedHandler(async (e) => // { // MainPage.Log($"远程连接断开"); // isSubscribeSuccess = false; // await DisConnectRemoteMqttClient("UseDisconnectedHandler"); // }); // } // //(3)ConnectedHandler // if (RemoteMqttClient.ConnectedHandler == null) // { // RemoteMqttClient.UseConnectedHandler(async (e) => // { // IfNeedReadAllDeviceStatus = true; // bNeedStartTip = true;// // bNeedConnectTip = true; // MainPage.Log($"============>Mqtt远程连接成功"); // SendPushSignOut(); // //if (CommonPage.IsRemote) { // // Utlis.ShowAppLinkStatus (AppLinkStatus.CloudLink); // //} // //if (MqttInfoConfig.Instance.CurRemoteMACInfo != null) { // // IsGatewayOnline = MqttInfoConfig.Instance.CurRemoteMACInfo.isValid != "InValid"; // // if (!IsGatewayOnline) { // // //网关不在线 // // if (CommonPage.IsRemote) { // // Utlis.ShowAppLinkStatus (AppLinkStatus.CloudOffline); // // MainPage.AddTip (Language.StringByID (Shared.SimpleControl.R.MyInternationalizationString.RemoteFailedGatewayOffline)); // // //发送一次CheckGateway主题 // // MqttRemoteSend (new byte [] { 0 }, 3); // // } // // } else { // // //网关在线 // // //重新一次所有设备状态 // // CheckIfNeedReadAllDeviceStatus (); // // // // // //MqttRemoteSend (new byte [] { 0 }, 3); // // if (CommonPage.IsRemote) { // // MainPage.AddTip (Language.StringByID (Shared.SimpleControl.R.MyInternationalizationString.LinkSuccess)); // // } // // } // //} // if (CommonPage.IsRemote) // { // Utlis.ShowAppLinkStatus(AppLinkStatus.CloudLink); // MainPage.AddTip(Language.StringByID(Shared.SimpleControl.R.MyInternationalizationString.LinkSuccess)); // // // //MqttRemoteSend (new byte [] { 0 }, 3); // ////读取搜索网关,判断网关是否在线 // //CheckGatewaysIfOnline (); // ////连接成功后检测是否需要通过远程获取Key // //CheckIfNeedGetLocalPasswordFromRemote (); // } // }); // } // #endregion // //} // //(4)===========开始连接过程========== // //MainPage.Log ($"CheckMQTTConnectAsync"); // //之前已经获取参数成功过 // if (MqttInfoConfig.Instance.IfGetMqttInfoSuccess) // { // //判断是否需要重新获取 // await CheckMQTTConnectAsync(); // } // else // { // //开始获取远程连接参数 // await StartMQTTGetInfo(); // } // } // catch (Exception ex) // { // MainPage.Log($"error:" + ex.Message); // if (IfDEBUG) // { // MainPage.ShowAlertOnMainThread("error: " + ex.Message); // } // } // finally // { // //最终要释放连接状态 // remoteMqttIsConnecting = false; // //lock (SendLocker) { // // remoteMqttIsConnecting = false; // //} // //连接成功才关闭Loading // if (remoteIsConnected) // { // MainPage.LoadingTipHide(); // ERRORCount = 0; // } // else // { // ERRORCount++; // //每5次重新提示一次 // if (ERRORCount > 5) // { // ERRORCount = 0; // MainPage.AddTip(Language.StringByID(Shared.SimpleControl.R.MyInternationalizationString.RemoteFailure)); // MainPage.LoadingTipHide(); // } // } //#if DEBUG // MainPage.Log($"StartCloudMqtt: 结束"); //#endif // } // }); // } // //static bool // /// // /// 检查网关是否在线线程 // /// // static System.Threading.Thread CheckGatewaysThead; // /// // /// 检查网关是否在线 // /// // static void CheckGatewaysIfOnline() // { // if (GatewayCommon == null) return; // try // { // if (CheckGatewaysThead != null) // CheckGatewaysThead.Abort(); // CheckGatewaysThead = new System.Threading.Thread(() => // { // var returnBytes = Control.ControlBytesSendHasReturn(Command.ReadGateway, GatewayCommon.SubnetID, GatewayCommon.DeviceID, new byte[] { (byte)new Random().Next(255), (byte)new Random().Next(255) }); // if (CommonPage.IsRemote) // { // if (returnBytes == null) // { // Application.RunOnMainThread(() => // { // IsGatewayOnline = false; // Utlis.ShowAppLinkStatus(AppLinkStatus.CloudOffline); // MainPage.AddTip(Language.StringByID(Shared.SimpleControl.R.MyInternationalizationString.RemoteFailedGatewayOffline)); // //发送一次CheckGateway主题 // MqttRemoteSend(new byte[] { 0 }, 3); // }); // } // else // { // IsGatewayOnline = true; // Utlis.ShowAppLinkStatus(AppLinkStatus.CloudLink); // Console.WriteLine("ReadGateway success"); // CheckIfNeedReadAllDeviceStatus(); // } // } // }) // { IsBackground = true }; // CheckGatewaysThead.Start(); // } // catch // { // } // } // /// // /// 检测是否需要发送刷新获取所有设备的命令 // /// // static void CheckIfNeedReadAllDeviceStatus() // { // if (IfNeedReadAllDeviceStatus) // { // Utlis.WriteLine("ReadAllDeviceStatus"); // IfNeedReadAllDeviceStatus = false; // Shared.SimpleControl.Phone.UserMiddle.ReadAllDeviceStatus(); // } // } // //连接错误次数统计 // static int ERRORCount = 0; // /// // /// 是否需要提示 // /// // static bool bNeedConnectTip = true; // /// // /// 从开始到连接成功,只提示1次 // /// // static bool bNeedStartTip = true; // /// // /// 正在获取连接参数... // /// // static void ShowStartTip() // { // if (bNeedStartTip) // { // bNeedStartTip = false; // if (CommonPage.IsRemote) // { // MainPage.LoadingTipShow(Language.StringByID(Shared.SimpleControl.R.MyInternationalizationString.GettingRemoteConnectionInfo)); // } // } // //if (CommonPage.IsRemote) { // // //MainPage.AddTip (Language.StringByID (Shared.SimpleControl.R.MyInternationalizationString.GettingRemoteConnectionInfo)); // // MainPage.LoadingTipShow (Language.StringByID (Shared.SimpleControl.R.MyInternationalizationString.GettingRemoteConnectionInfo)); // //} // } // /// // /// 检测之前获取的Mac与当前住宅MAC是否一致 不一致从新获取 // /// // /// // static async Task CheckMQTTConnectAsync() // { // try // { // if (MqttInfoConfig.Instance.CurRemoteMACInfo != null && MqttInfoConfig.Instance.CurRemoteMACInfo.mac == UserConfig.Instance.GatewayMAC) // { // await MQTTConnectAsync(); // } // else // { // //Mac 变化了重新获取参数 // await StartMQTTGetInfo(); // } // } // catch // { // MqttInfoConfig.Instance.IfGetMqttInfoSuccess = false; // } // } // /// // /// 开始获取Mqtt 远程参数 // /// // /// // static async Task StartMQTTGetInfo() // { // ShowStartTip(); // if (!CommonPage.IsRemote) // { // return; // } // //--判断是当前是否分享的住宅 // if (!UserConfig.Instance.CurrentRegion.IsOthreShare) // { // //主账号获取MQTT 远程链接信息,并连接 // await GetMqttInfoAndMQTTConnectAsync(); // } // else // { // //如果是分享过来的住宅 走下面流程 // //--第一步:获取当前住分享宅网关信息并连接MQTT // await GetSingleHomeGatewayPaggerAndMQTTConnectAsync(); // } // } // /// // /// 连接MQTT // /// // static async Task MQTTConnectAsync() // { // if (!CommonPage.IsRemote) // { // return; // } // if (MqttInfoConfig.Instance.CurRemoteMACInfo != null && MqttInfoConfig.Instance.mMqttInfo != null) // { // if (bNeedConnectTip) // { // bNeedConnectTip = false; // MainPage.LoadingTipShow(Language.StringByID(Shared.SimpleControl.R.MyInternationalizationString.GetSuccessfullyStartConnecting)); // } // try // { // var url = MqttInfoConfig.Instance.mMqttInfo.connEmqDomainPort; // //#if DEBUG // // var zdURL = "15.185.137.39"; // // if (url.Contains (zdURL)) { // // url = url.Replace (zdURL,"106.53.216.186"); // // } // //#endif // var clientId = MqttInfoConfig.Instance.mMqttInfo.connEmqClientId; // var username = MqttInfoConfig.Instance.mMqttInfo.connEmqUserName; // var passwordRemote = MqttInfoConfig.Instance.mMqttInfo.connEmqPwd; // MqttInfoConfig.Instance.CurRemoteMACInfo.clientId = clientId; // //MqttInfoConfig.Instance.CurRemoteMACInfo.LoginAccessToken = MainPage.LoginUser.LoginTokenString; // //获取参数成功,保存到本地并标记为true // MqttInfoConfig.Instance.IfGetMqttInfoSuccess = true; // MqttInfoConfig.Instance.Save(); // //Console.WriteLine ("Connect url: " + url); // mqttEncryptKey = MqttInfoConfig.Instance.CurRemoteMACInfo.isNewBusproGateway ? MqttInfoConfig.Instance.CurRemoteMACInfo.aesKey : ""; // var options1 = new MQTTnet.Client.Options.MqttClientOptionsBuilder() // .WithClientId(clientId) // .WithTcpServer(url.Split(':')[1].Substring("//".Length), int.Parse(url.Split(':')[2])) // .WithCredentials(username, passwordRemote) // .WithCleanSession() // .WithProtocolVersion(MQTTnet.Formatter.MqttProtocolVersion.V311) // //.WithCommunicationTimeout (new TimeSpan (0, 0, 10)) // .WithCommunicationTimeout(new TimeSpan(0, 0, 5)) // //.WithCommunicationTimeout (new TimeSpan (0, 1, 0)) // .Build(); // await DisConnectRemoteMqttClient("StartRemoteMqtt"); // //await DisConnectRemoteMqttClientWhenStart ("StartRemoteMqtt"); // var mResult = await RemoteMqttClient.ConnectAsync(options1); // if (mResult.ResultCode == MQTTnet.Client.Connecting.MqttClientConnectResultCode.Success) // { // remoteIsConnected = true; // IsDisConnectingWithSendCatch = false; // UnsupportedProtocolVersionCount = 0; // } // else // { // //重新中心服务器获取参数标记 // MqttInfoConfig.Instance.IfGetMqttInfoSuccess = false; // } // } // catch (Exception ex) // { // if (ex.Message == UnsupportedProtocolVersion) // { // UnsupportedProtocolVersionCount++; // if (UnsupportedProtocolVersionCount > 5) // { // UnsupportedProtocolVersionCount = 0; // //连续异常5次,重新中心服务器获取参数标记 // MqttInfoConfig.Instance.IfGetMqttInfoSuccess = false; // } // Console.WriteLine("Connect error UN: " + ex.Message); // } // else if (ex.Message == MqttCommunicationTimedOutException) // { // Console.WriteLine("Connect error TimedOut: " + ex.Message); // } // else // { // //重新中心服务器获取参数标记 // MqttInfoConfig.Instance.IfGetMqttInfoSuccess = false; // Console.WriteLine("Connect error: " + ex.Message); // } // //Console.WriteLine ("Connect error: " + ex.Message); // if (IfDEBUG) // { // MainPage.ShowAlertOnMainThread("Connect error: " + ex.Message); // } // } // finally // { // } // } // else // { // MqttInfoConfig.Instance.IfGetMqttInfoSuccess = false; // } // } // static int UnsupportedProtocolVersionCount = 0; // static readonly string MqttCommunicationTimedOutException = "Exception of type 'MQTTnet.Exceptions.MqttCommunicationTimedOutException' was thrown."; // // // static readonly string UnsupportedProtocolVersion = "Connecting with MQTT server failed (UnsupportedProtocolVersion)."; // /// // /// 收到网关上线消息 // /// // static void ReceiveNotifyBusGateWayInfoChange() // { // try // { // SetGatewayOnlineResetCheck(); // if (CommonPage.IsRemote) // { // //#if DEBUG // MainPage.AddTip(Language.StringByID(Shared.SimpleControl.R.MyInternationalizationString.GatewayLoginOnline)); // //#endif // CheckIfNeedReadAllDeviceStatus(); // } // GetSingleHomeGatewayPaggerAndMQTTConnectAsync(false); // } // catch { } // } // /// // /// 收到网关掉线信息 // /// // static void ReceiveNotifyGateWayOffline() // { // MainPage.Log("============>Mqtt GateWayOffline"); // IsGatewayOnline = false; // if (CommonPage.IsRemote) // { // Utlis.ShowAppLinkStatus(AppLinkStatus.CloudOffline); // MainPage.AddTip(Language.StringByID(Shared.SimpleControl.R.MyInternationalizationString.GatewayOffline)); // } // } // /// // /// 收到挤下线推送 // /// // static void ReceiveNotifySqueezeAsync(string mMes) // { // if (mMes == PushSignStr) return;//是自己的登录推送不处理 // //断开远程连接 // CommonPage.IsRemote = false; // if (!MainPage.LoginUser.IsLogin) // { // return; // } // DisConnectRemoteMqttClient("挤下线"); // MainPage.LoginUser.LastTime = DateTime.MinValue; // MainPage.LoginUser.SaveUserInfo(); // Room.Lists.Clear(); // ////删除推送数据 // //var webclient = new System.Net.WebClient (); // //webclient.Headers.Add (System.Net.HttpRequestHeader.Authorization, MainPage.LoginUser.LoginTokenString); // //webclient.DownloadStringAsync (new Uri ("https://global.hdlcontrol.com/HangZhouHdlCloudApi/ZigbeeUsers/SignOut")); // Application.RunOnMainThread(() => // { // Utlis.ShowAppLinkStatus(AppLinkStatus.WiFi); // new Shared.SimpleControl.Phone.AccountLogin(MainPage.LoginUser.AccountString, "").Show(); // SharedMethod.SharedMethod.CurPageLayout = null; // //CommonPage.IsRemote = false; // MainPage.LoadingTipHide(); // MainPage.Loading.Hide(); // new Alert(Language.StringByID(Shared.SimpleControl.R.MyInternationalizationString.Tip), Language.StringByID(Shared.SimpleControl.R.MyInternationalizationString.LoggedOnOtherDevices), // Language.StringByID(Shared.SimpleControl.R.MyInternationalizationString.Close)).Show(); // }); // //2020-06-30 删除推送数据 // ForceUpdateUtlis.Current.SignOut(); //#if HDL // if (!String.IsNullOrEmpty (MainPage.LoginUser.AllVisionRegisterDevUserNameGuid)) { // com.freeview.global.Video.Logout (); // }///BusGateWayToClient/320c1fea-1866-4708-8277-e2321a4dd236/NotifyGateWayInfoChange //#endif // } // /// // /// 收到CheckGateway主题 // /// // static void ReceiveCheckGateway(string mMes) // { // if (!CommonPage.IsRemote) return; // Utlis.WriteLine("ReceiveCheckGateway!"); // if (MqttInfoConfig.Instance.CurRemoteMACInfo.isNewBusproGateway) // { // SetGatewayOnlineResetCheck(); // } // else // { // } // //CheckIfNeedReadAllDeviceStatus (); // var obj = Newtonsoft.Json.JsonConvert.DeserializeObject(mMes); // if (obj == null) // { // //SetGatewayOnlineResetCheck (); // return; // } // switch (obj.StateCode) // { // case "HDLUdpDataForwardServerMqttClientNoOnLine": // case "NoOnline": // case "NetworkAnomaly"://不在线 // IsGatewayOnline = false; // MainPage.AddTip(Language.StringByID(Shared.SimpleControl.R.MyInternationalizationString.RemoteFailedGatewayOffline)); // Utlis.ShowAppLinkStatus(AppLinkStatus.CloudOffline); // break; // case "NoRecord"://MAC不正确 // IsGatewayOnline = false; // MainPage.AddTip(Language.StringByID(Shared.SimpleControl.R.MyInternationalizationString.MACError)); // Utlis.ShowAppLinkStatus(AppLinkStatus.CloudOffline); // break; // case "Success": // SetGatewayOnlineResetCheck(); // IsGatewayOnline = true; // //MainPage.AddTip (UserConfig.Instance.CurrentRegion.Name + ":" + Language.StringByID (Shared.SimpleControl.R.MyInternationalizationString.LinkSuccess)); // break; // default: // IsGatewayOnline = false; // MainPage.AddTip(Language.StringByID(Shared.SimpleControl.R.MyInternationalizationString.LinkLoser)); // Utlis.ShowAppLinkStatus(AppLinkStatus.CloudOffline); // break; // } // } // static RemoteMACInfo CurRemoteMACInfo; // /// // /// // /// // /// 附加数据包 // /// 操作类型:0=网关控制;1=订阅网关数据;2=订阅网关上线数据 // /// // public static async Task MqttRemoteSend(byte[] message, int optionType = 0) // { // //return; // try // { // string topicName; // switch (optionType) // { // case 0: // topicName = $"/ClientToBusGateWay/{CurRemoteMACInfo.macMark}/Common/ON"; // if (!string.IsNullOrEmpty(mqttEncryptKey)) // { // message = Shared.Securitys.EncryptionService.AesEncryptPayload(message, mqttEncryptKey); // } // await RemoteMqttClient.PublishAsync(new MqttApplicationMessage { Topic = topicName, Payload = message, Retain = false, QualityOfServiceLevel = MQTTnet.Protocol.MqttQualityOfServiceLevel.AtMostOnce }); // break; // case 3: // topicName = $"/ClientToBusGateWay/{MqttInfoConfig.Instance.CurRemoteMACInfo.macMark}/Common/CheckGateway"; // MainPage.Log("CheckGateway"); // await RemoteMqttClient.PublishAsync(new MqttApplicationMessage { Topic = topicName, Retain = false, QualityOfServiceLevel = MQTTnet.Protocol.MqttQualityOfServiceLevel.AtMostOnce }); // break; // case 4://发布新方案的挤下线主题 // topicName = $"/BusGateWayToClient/{MainPage.LoginUser.ID}" + PushNotifySqueeze; // //message = System.Text.Encoding.UTF8.GetBytes (PushSignStr); // await RemoteMqttClient.PublishAsync(new MqttApplicationMessage { Topic = topicName, Payload = message, Retain = false, QualityOfServiceLevel = MQTTnet.Protocol.MqttQualityOfServiceLevel.AtMostOnce }); // break; // } // } // catch (Exception e) // { // //Utlis.WriteLine ($"============>Mqtt MqttRemoteSend catch"); // if (!IsDisConnectingWithSendCatch) // { // IsDisConnectingWithSendCatch = true; // await DisConnectRemoteMqttClient("SendCatch"); // } // } // } // /// // /// SendCatch 后执行一次断开操作 // /// // static bool IsDisConnectingWithSendCatch = false; // /// // /// 是否需要读取一次所有设备状态 // /// // static bool IfNeedReadAllDeviceStatus = true; // public static bool IsGatewayOnline = true; // //static int CheckGatewayCount = 0; // //static DateTime mCheckGatewayTime; // /// // /// 设置网关在线标志,并重置CheckGateway参数 // /// // static void SetGatewayOnlineResetCheck() // { // //mCheckGatewayTime = DateTime.Now; // //CheckGatewayCount = 0; // if (CommonPage.IsRemote) // { // if (!IsGatewayOnline) // { // IsGatewayOnline = true; // Utlis.ShowAppLinkStatus(AppLinkStatus.CloudLink); // } // } // } // /// // /// 主账号获取MQTT 远程链接信息,并连接 // /// // /// // static async Task GetMqttInfoAndMQTTConnectAsync() // { // var mqttInfoRequestPar = new GetConnMqttInfoObj() // { // LoginAccessToken = MainPage.LoginUser.LoginTokenString, // PlatformStr = GetRandomKey(), // PublishPayloadJsonStr = PushSignStr, // Mac = UserConfig.Instance.GatewayMAC, // }; // var mqttInfoRequestResult = MainPage.RequestHttpsNew(API.GetConnMqttInfo, Newtonsoft.Json.JsonConvert.SerializeObject(mqttInfoRequestPar)); // if (mqttInfoRequestResult != null && mqttInfoRequestResult.ResponseData != null) // { // try // { // var mqttInfoRequestResult_Obj = Newtonsoft.Json.JsonConvert.DeserializeObject(mqttInfoRequestResult.ResponseData.ToString()); // if (mqttInfoRequestResult_Obj != null) // { // MqttInfoConfig.Instance.mMqttInfo = mqttInfoRequestResult_Obj; // string url = mqttInfoRequestResult_Obj.connEmqDomainPort; // string clientId = mqttInfoRequestResult_Obj.connEmqClientId; // string username = mqttInfoRequestResult_Obj.connEmqUserName; // string passwordRemote = mqttInfoRequestResult_Obj.connEmqPwd; // if (mqttInfoRequestResult_Obj.AccountAllGateways != null && mqttInfoRequestResult_Obj.AccountAllGateways.Count > 0) // { // //----第二步找出是否存在匹配当前住宅的mac,存在再进行远程。 // MqttInfoConfig.Instance.CurRemoteMACInfo = mqttInfoRequestResult_Obj.AccountAllGateways.Find((obj) => obj.mac == UserConfig.Instance.GatewayMAC); // if (MqttInfoConfig.Instance.CurRemoteMACInfo != null) // { // //MqttInfoConfig.Instance.CurRemoteMACInfo.LoginAccessToken = MainPage.LoginUser.LoginTokenString; // MqttInfoConfig.Instance.CurRemoteMACInfo.clientId = clientId; // //----第三步 开始连接 // await MQTTConnectAsync(); // } // } // else // { // //Utlis.WriteLine ("============>Please wait, failed to get gateway parameters."); // } // } // else // { // //Utlis.WriteLine ("============>Please wait, failed to get user parameters."); // } // } // catch { } // } // else // { // //Utlis.WriteLine ("Please wait, failed to get parameters."); // //MainPage.AddTip ("Please wait, failed to get parameters."); // } // } // } //}