wei
2021-01-27 7232642ff48a7fbde2018cde652f3e771fa58025
HDL_ON/DAL/Mqtt/MqttClient.cs
@@ -21,7 +21,7 @@
        /// </summary>
        static string mqttEncryptKey = "";
        //static string checkGatewayTopicBase64 = "";
        static bool hadGateway = true;
        /// <summary>
        /// 挤下线主题
        /// </summary>
@@ -32,18 +32,18 @@
        /// </summary>
        static string RandomKey = "";
        /// <summary>
        /// 随机生成字符
        /// </summary>
        /// <returns></returns>
        static string GetRandomKey()
        {
            if (string.IsNullOrEmpty(RandomKey))
            {
                //随机2位字符串
                Random random = new Random(Guid.NewGuid().GetHashCode());
                int num = random.Next(65, 91);
                RandomKey = Convert.ToChar(num).ToString();
                RandomKey = Utlis.CreateRandomString(2);
            }
            return RandomKey;
        }
        /// <summary>
@@ -119,7 +119,7 @@
        /// <summary>
        /// 外网的MQTT是否正在连接
        /// </summary>
        public static bool remoteMqttIsConnecting;
        public static bool RemoteMqttIsConnecting;
        static bool remoteIsConnected;
        static MqttClient()
@@ -138,6 +138,8 @@
                    {
                        System.Threading.Thread.Sleep(500);
                        if (!Control.Ins.IsRemote) continue;
                        //进入后台不处理
                        if (MainPage.IsEnterBackground) continue;
                        await StartCloudMqtt();
                        await SubscribeTopics();
@@ -158,6 +160,10 @@
        }
        static bool isSubscribeSuccess;
        /// <summary>
        /// 订阅主题
        /// </summary>
        /// <returns></returns>
        static async Task SubscribeTopics()
        {
            if (remoteIsConnected && !isSubscribeSuccess)
@@ -181,14 +187,20 @@
                    var topicAlinkStatus = new MqttTopicFilter()
                    {
                        Topic = $"/user/{MqttInfoConfig.Current.HomeGatewayInfo.gatewayId}/app/thing/property/#",
                        Topic = $"/user/{MqttInfoConfig.Current.HomeGatewayInfo.gatewayId}/app/thing/property/send",
                        QualityOfServiceLevel = MQTTnet.Protocol.MqttQualityOfServiceLevel.AtMostOnce
                    };
                    //var topicBusStatus = new MqttTopicFilter()
                    //{
                    //    Topic = $"/BusGateWayToClient/{}/Common",
                    //    QualityOfServiceLevel = MQTTnet.Protocol.MqttQualityOfServiceLevel.AtMostOnce
                    //};
                    Utlis.WriteLine("开始订阅!");
                    var result = await RemoteMqttClient.SubscribeAsync(new MqttTopicFilter[] { topicFilterBusGateWayToClient, topicFilterPush2 , topicAlinkStatus });
                    var result = await RemoteMqttClient.SubscribeAsync(new MqttTopicFilter[] { topicFilterBusGateWayToClient, topicFilterPush2, topicAlinkStatus });
                    if (result.Items[0].ResultCode == MQTTnet.Client.Subscribing.MqttClientSubscribeResultCode.GrantedQoS0)
                    {
                        Control.Ins.GatewayOnline = true;
                        isSubscribeSuccess = true;
                        Utlis.WriteLine("订阅成功!");
@@ -210,8 +222,7 @@
        /// </summary>
        public static async Task StartCloudMqtt()
        {
            if (OnAppConfig.Instance.internetStatus == 0)
            if (MainPage.InternetStatus == 0)
            {
                return;
            }
@@ -222,7 +233,7 @@
            }
            //追加:没有远程连接的权限
            if (remoteMqttIsConnecting || remoteIsConnected)
            if (RemoteMqttIsConnecting || remoteIsConnected)
            {
                return;
            }
@@ -233,7 +244,7 @@
                try
                {
                    #region 初始化远程Mqtt
                    RemoteMqttIsConnecting = true;
                    RemoteMqttClient = new MqttFactory().CreateMqttClient();
@@ -263,13 +274,17 @@
                                }
                                else if (topic == $"/BusGateWayToClient/{MqttInfoConfig.Current.HomeGatewayInfo.gatewayId}/Common/CheckGateway")
                                {
                                    var ss = Encoding.UTF8.GetString(e.ApplicationMessage.Payload);
                                    ReceiveCheckGateway(ss);
                                }
                                else
                                {
                                    SetGatewayOnlineResetCheck();
                                    if (Entity.DB_ResidenceData.residenceData.GatewayType == 0)
                                    var bytes = Securitys.EncryptionService.AesDecryptPayload(e.ApplicationMessage.Payload, DB_ResidenceData.Instance.HomeGateway.aesKey);
                                    //bus数据解析
                                    if (DB_ResidenceData.Instance.GatewayType == 0)
                                    {
                                        var packet = new Packet();
@@ -281,166 +296,22 @@
                                        {
                                            packet.Bytes = e.ApplicationMessage.Payload;
                                        }
#if DEBUG
                                        //string ddd = "";
                                        //foreach (var bb in packet.Bytes)
                                        //{
                                        //    ddd += bb + ",";
                                        //}
                                        //MainPage.Log($"mqtt bus data:{ddd}");
#endif
                                        packet.Manager();
                                    }
                                    else
                                    {
                                        MainPage.Log($"mqtt A-Link data");
                                        //A协议数据处理
                                        var revString = System.Text.Encoding.UTF8.GetString(e.ApplicationMessage.Payload);
                                        var temp = Newtonsoft.Json.JsonConvert.DeserializeObject<GatewayAlinkControlObj>(revString);
                                        if (temp != null)
                                        {
                                            var allLocalFuntion = FunctionList.List.GetAllDeviceFunctionList();
                                            foreach (var updateTemp in temp.objects)
                                            {
                                                bool hadChange = false;//状态有变化再更新界面
                                                var updataObj = allLocalFuntion.Find((obj) => obj.sid == updateTemp.sid);
                                                if (updataObj != null)
                                                {
                                                    foreach (var attr in updateTemp.status)
                                                    {
                                                        foreach (var locatAttr in updataObj.attributes)
                                                        {
                                                            if (attr.key == locatAttr.key)
                                                            {
                                                                if (locatAttr.curValue.ToString() == attr.value)
                                                                {
                                                                    continue;
                                                                }
                                                                locatAttr.curValue = attr.value;
                                                                hadChange = true;
                                                            }
                                                        }
                                                    }
                                                    if(!hadChange)//状态有变化再更新界面
                                                    {
                                                        continue;
                                                    }
                                                    //更新界面状态
                                                    switch (updataObj.spk)
                                                    {
                                                        case SPK.LightSwitch:
                                                            RelayPage.UpdataState(updataObj as Light);
                                                            break;
                                                        case SPK.LightDimming:
                                                            var dimming = updataObj as Light;
                                                            dimming.lastState = Language.StringByID(StringId.Brightness) + " : " + dimming.brightness + "%";
                                                            DimmerPage.UpdataStates(dimming);
                                                            break;
                                                        case SPK.ElectricFan:
                                                            var fan = updataObj as Fan;
                                                            fan.lastState = Language.StringByID(StringId.Level) + " : " + fan.openLevel;
                                                            FanPage.UpdataState(fan);
                                                            break;
                                                        case SPK.LightRGB:
                                                            var rgb = updataObj as Light;
                                                            rgb.lastState = Language.StringByID(StringId.Brightness) + " : " + rgb.brightness + "%";
                                                            RGBPage.UpdataStates(rgb);
                                                            break;
                                                        case SPK.LightRGBW:
                                                        case SPK.LightCCT:
                                                            break;
                                                        case SPK.CurtainSwitch:
                                                            var curtain = updataObj as Curtain;
                                                            curtain.lastState = curtain.trait_on_off.curValue.ToString() == "on" ? Language.StringByID(StringId.Open) : Language.StringByID(StringId.Close);
                                                            CurtainModulePage.UpdataState(curtain);
                                                            break;
                                                        case SPK.CurtainTrietex:
                                                            var trietex = updataObj as Curtain;
                                                            trietex.lastState = Language.StringByID(StringId.Open) + trietex.percent + "%";
                                                            MotorCurtainPage.UpdataState(trietex);
                                                            break;
                                                        case SPK.CurtainRoller:
                                                            var roller = updataObj as Curtain;
                                                            roller.lastState = Language.StringByID(StringId.Open) + roller.percent + "%";
                                                            RollingShutterPage.UpdataState(roller);
                                                            break;
                                                        case SPK.CurtainShades:
                                                            break;
                                                        case SPK.AcStandard:
                                                            var ac = updataObj as AC;
                                                            ac.lastState = "";
                                                            switch (ac.trait_mode.curValue.ToString())
                                                            {
                                                                case "cool":
                                                                    ac.lastState = Language.StringByID(StringId.Cool);
                                                                    break;
                                                                case "heat":
                                                                    ac.lastState = Language.StringByID(StringId.Heat);
                                                                    break;
                                                                case "dry":
                                                                    ac.lastState = Language.StringByID(StringId.Dry);
                                                                    break;
                                                                case "auto":
                                                                    ac.lastState = Language.StringByID(StringId.Auto);
                                                                    break;
                                                                case "fan":
                                                                    ac.lastState = Language.StringByID(StringId.AirSupply);
                                                                    break;
                                                            }
                                                            switch (ac.trait_fan.curValue.ToString())
                                                            {
                                                                case "high":
                                                                    ac.lastState += " " + Language.StringByID(StringId.HighWindSpeed);
                                                                    break;
                                                                case "medium":
                                                                    ac.lastState += " " + Language.StringByID(StringId.MiddleWindSpeed);
                                                                    break;
                                                                case "low":
                                                                    ac.lastState += " " + Language.StringByID(StringId.LowWindSpeed);
                                                                    break;
                                                                case "auto":
                                                                    ac.lastState += " " + Language.StringByID(StringId.Auto);
                                                                    break;
                                                            }
                                                            ac.lastState += " " + ac.trait_temp.curValue + ac.tempUnitString;
                                                            ACPage.UpdataStates(ac);
                                                            break;
                                                        case SPK.FloorHeatStandard:
                                                            var fh = updataObj as FloorHeating;
                                                            switch (fh.trait_mode.curValue)
                                                            {
                                                                case "normal":
                                                                    fh.lastState = Language.StringByID(StringId.Normal);
                                                                    break;
                                                                case "day":
                                                                    fh.lastState = Language.StringByID(StringId.Day);
                                                                    break;
                                                                case "night":
                                                                    fh.lastState = Language.StringByID(StringId.Night);
                                                                    break;
                                                                case "timer":
                                                                    fh.lastState = Language.StringByID(StringId.Auto);
                                                                    break;
                                                                case "away":
                                                                    fh.lastState = Language.StringByID(StringId.Away);
                                                                    break;
                                                            }
                                                            fh.lastState += " " + fh.trait_temp.curValue + fh.tempUnitString;
                                                            FloorHeatingPage.UpdataStates(fh);
                                                            break;
                                                        case SPK.SensorPm25:
                                                        case SPK.SensorCO2:
                                                        case SPK.SensorTVOC:
                                                        case SPK.SensorTemperature:
                                                        case SPK.SensorHumidity:
                                                            var sensor = updataObj as Sensor;
                                                            EnvironmentalSciencePage.LoadEvent_UpdataStatus(sensor);
                                                            break;
                                                        case SPK.ElectricSocket:
                                                            break;
                                                        case SPK.ElectricTV:
                                                            break;
                                                        default:
                                                            break;
                                                    }
                                                    HomePage.UpdataFunctionStates(updataObj);
                                                    RoomPage.UpdataStates(updataObj);
                                                    FunctionPage.UpdataStates(updataObj);
                                                    ClassificationPage.UpdataInfo(updataObj);
                                                }
                                            }
                                        }
                                        var revString = Encoding.UTF8.GetString(bytes);
                                        Control.Ins.UpdataFunctionStatus(revString,null);
                                    }
                                }
                            }
@@ -460,11 +331,11 @@
                    //(3)ConnectedHandler
                    if (RemoteMqttClient.ConnectedHandler == null)
                    {
                        RemoteMqttClient.UseConnectedHandler(async (e) => {
                        RemoteMqttClient.UseConnectedHandler(async (e) =>
                        {
                            IfNeedReadAllDeviceStatus = true;
                            Utlis.WriteLine($"============>Mqtt远程连接成功");
                            SendPushSignOut();
                            FunctionList.List.ReadAllFunctionStatus();
                        });
                    }
                    #endregion
@@ -491,7 +362,7 @@
                finally
                {
                    //最终要释放连接状态
                    remoteMqttIsConnecting = false;
                    RemoteMqttIsConnecting = false;
                    Utlis.WriteLine($"StartCloudMqtt: 结束");
                }
@@ -521,7 +392,7 @@
        {
            try
            {
                if (MqttInfoConfig.Current.HomeGatewayInfo != null && MqttInfoConfig.Current.HomeGatewayInfo.mac == Entity.DB_ResidenceData.residenceData.residenceGatewayMAC)
                if (MqttInfoConfig.Current.HomeGatewayInfo != null && MqttInfoConfig.Current.HomeGatewayInfo.mac == Entity.DB_ResidenceData.Instance.residenceGatewayMAC)
                {
                    await MQTTConnectAsync();
                }
@@ -674,7 +545,6 @@
        /// </summary>
        static void ReceiveNotifySqueezeAsync(string mMes)
        {
            if (mMes == PushSignStr) return;//是自己的登录推送不处理
            //断开远程连接
@@ -686,13 +556,20 @@
            DisConnectRemoteMqttClient("挤下线");
            UserInfo.Current.LastTime = DateTime.MinValue;
            UserInfo.Current.SaveUserInfo();
            Application.RunOnMainThread(() => {
                MainPage.GoLoginPage(UserInfo.Current);
            Application.RunOnMainThread(() =>
            {
                //弹窗提示被挤下线
                HDLCommon.Current.CheckLogout();
            });
            //UserInfo.Current.LastTime = DateTime.MinValue;
            //UserInfo.Current.SaveUserInfo();
            //Application.RunOnMainThread(() => {
            //    MainPage.GoLoginPage(UserInfo.Current);
            //    //弹窗提示被挤下线
            //});
            //2020-08-11 删除推送数据
            //HDLRequest.Current.PushserivceSignOut ();
@@ -730,8 +607,6 @@
        /// <returns></returns>
        public static async Task MqttRemoteSend(byte[] message, int optionType = 0)
        {
            //return;
            try
            {
                string topicName;
@@ -777,7 +652,6 @@
        /// 是否需要读取一次所有设备状态
        /// </summary>
        static bool IfNeedReadAllDeviceStatus = true;
        //public static bool IsGatewayOnline = true;
        /// <summary>
        /// 设置网关在线标志,并重置CheckGateway参数
@@ -786,7 +660,18 @@
        {
            if (Control.Ins.IsRemote)
            {
                Control.Ins.GatewayOnline = true;
                if (!Control.Ins.GatewayOnline)
                {
                    try
                    {
                        if (DB_ResidenceData.Instance.HomeGateway != null)
                        {
                            DB_ResidenceData.Instance.HomeGateway.gatewayStatus = true;
                        }
                        Control.Ins.GatewayOnline = true;
                    }
                    catch { }
                }
            }
        }
@@ -803,16 +688,17 @@
                MqttInfoConfig.Current.mMqttInfo = mqttInfoRequestResult_Obj;
                await MQTTConnectAsync();
                //1.判断是否绑定了网关,获取网关远程连接的加密KEY
                if (DB_ResidenceData.residenceData.CheckWhetherGatewayIsBound())
                if (DB_ResidenceData.Instance.CheckWhetherGatewayIsBound())
                {
                    //2.找出是否存在匹配当前住宅的mac,存在再进行远程。
                    MqttInfoConfig.Current.HomeGatewayInfo = DB_ResidenceData.residenceData.HomeGateway;
                    MqttInfoConfig.Current.HomeGatewayInfo = DB_ResidenceData.Instance.HomeGateway;
                    //3.开始连接
                    await MQTTConnectAsync();
                }
                else
                {
                    Utlis.WriteLine("============>还没绑定网关");
                    hadGateway = false;
                }
            }
        }