///*
//更新了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 = CommonPage.MyEncodingUTF8.GetString (e.ApplicationMessage.Payload);
// // //收到挤下线主题
// // ReceiveNotifySqueezeAsync (mMes);
// //} else
// if (topic == $"/BusGateWayToClient/{MainPage.LoginUser.ID}" + PushNotifySqueeze)
// {
// var mMes = CommonPage.MyEncodingUTF8.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 = CommonPage.MyEncodingUTF8.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 = CommonPage.MyEncodingUTF8.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.");
// }
// }
// }
//}