コード例 #1
0
        public static void mtdProcesarInformacion(string Topic, string Mensaje)
        {
            foreach (Gpr_GalponDTO galpon in galpones)
            {
                //foreach (Gpr_Tipo_ServicioDTO tiposervicio in tiposervicios)
                //{
                //    if (tiposervicio.IdGprTipoServicio == 2)
                //    {
                //        foreach (Dom_Componente_ElectronicoDTO componenteelectronico in componenteselectronicos.Where(X => X.IdGprServicio == tiposervicio.IdGprTipoServicio && X.IdGprGalpon == galpon.IdGprGalpon))
                //        {
                //            if (Topic == componenteelectronico.Topic)
                //            {
                //                Console.WriteLine("Servicio: " + tiposervicio.Descripcion);
                //                Console.WriteLine(Mensaje);
                //            }
                //        }
                //    }
                //}
                foreach (Gpr_ServicioDTO servicio in servicios)
                {
                    if (servicio.IdGprTipoServicio == 1 || servicio.IdGprTipoServicio == 2)
                    {
                        foreach (Dom_Componente_ElectronicoDTO componenteelectronico in componenteselectronicos.Where(X => X.IdGprServicio == servicio.IdGprServicio && X.IdGprGalpon == galpon.IdGprGalpon))
                        {
                            if (Topic == componenteelectronico.Topic)
                            {
                                Console.WriteLine(galpon.Descripcion + ":");

                                Console.WriteLine("Servicio: " + servicio.Descripcion);
                                Console.WriteLine(Mensaje);

                                Gpr_Medicion_HorariaDTO medicionTemporal = new Gpr_Medicion_HorariaDTO();
                                try
                                {
                                    medicionTemporal.IdGprGalpon   = galpon.IdGprGalpon;
                                    medicionTemporal.IdGprServicio = servicio.IdGprServicio;
                                    medicionTemporal.Medicion      = Convert.ToDecimal(Mensaje);
                                }
                                catch
                                {
                                }

                                if (medicionTemporal.Medicion != 0)
                                {
                                    medicionHorariaTemporal.Add(medicionTemporal);
                                }
                            }
                        }
                    }
                }
            }
        }
コード例 #2
0
        public static void GuardarMedicionHoraria(Gpr_Medicion_HorariaDTO data)
        {
            var request = new RestRequest("Gpr_Medicion_Horaria", Method.POST);

            request.RequestFormat = DataFormat.Json;
            request.AddHeader("Content-type", "application/json");
            request.AddJsonBody(data);
            //request.AddBody(data);

            //request.AddParameter("Gpr_Galpon", request.JsonSerializer.Serialize(gpr_Galpon));
            //request.AddBody(gpr_Galpon);

            var response = client.Execute <object>(request);

            //return response.Data;
        }
コード例 #3
0
        public static void client_MqttMsgPublishReceived(object sender, MqttMsgPublishEventArgs e)
        {
            //foreach (Gpr_ServicioDTO servicio in servicios)
            //{
            //    if(galpon.IdGprGalpon == servicio.)
            //}

            //if (e.Topic == "temp")
            //{
            //    //Debug.WriteLine("Received = " + Encoding.UTF8.GetString(e.Message) + " on topic " + e.Topic);

            //    Console.WriteLine(Encoding.UTF8.GetString(e.Message) + "°C");
            //}

            //if (e.Topic == "hum")
            //{
            //    //Debug.WriteLine("Received = " + Encoding.UTF8.GetString(e.Message) + " on topic " + e.Topic);

            //    Console.WriteLine(Encoding.UTF8.GetString(e.Message) + "%");
            //}

            foreach (Gpr_GalponDTO galpon in galpones)
            {
                foreach (Gpr_ServicioDTO servicio in servicios)
                {
                    foreach (Gpr_Tipo_ServicioDTO tiposervicio in tiposervicios)
                    {
                        if (tiposervicio.Descripcion == "Control")
                        {
                            foreach (Dom_Componente_ElectronicoDTO componenteelectronico in componenteselectronicos.Where(X => X.IdGprServicio == servicio.IdGprServicio))
                            {
                                foreach (Dom_Control_Componente_ElectronicoDTO controlcomponente in contolcomponenteelectronico.Where(X => X.IdDomComponenteElectronico == componenteelectronico.IdDomComponenteElectronico))
                                {
                                    //Hora
                                    if (controlcomponente.IdDomTipoControlComponenteElectronico == 3)
                                    {
                                        DateTime horaInicio = Convert.ToDateTime(controlcomponente.Inicio);
                                        DateTime horaFin    = Convert.ToDateTime(controlcomponente.Fin);

                                        bool activado = false;

                                        if (e.Topic == componenteelectronico.Topic)
                                        {
                                            if (horaInicio <= DateTime.Now && DateTime.Now <= horaFin) //&& horaFin.Hour >= DateTime.Now.Hour && horaFin.Minute > DateTime.Now.Minute)
                                            {
                                                if (Encoding.UTF8.GetString(e.Message) == "0")
                                                {
                                                    client.Publish(componenteelectronico.Topic, Encoding.UTF8.GetBytes("1"));
                                                    activado = true;
                                                }
                                                if (Encoding.UTF8.GetString(e.Message) == "1")
                                                {
                                                    activado = true;
                                                }
                                            }
                                            //else if (DateTime.Now <= horaFin) //&& horaFin.Minute <= DateTime.Now.Minute || horaInicio > DateTime.Now)
                                            //{
                                            //    if (Encoding.UTF8.GetString(e.Message) == "1")
                                            //    {
                                            //        client.Publish(componenteelectronico.Topic, Encoding.UTF8.GetBytes("0"));
                                            //    }
                                            //}
                                        }

                                        if (activado == false)
                                        {
                                            if (Encoding.UTF8.GetString(e.Message) == "1")
                                            {
                                                client.Publish(componenteelectronico.Topic, Encoding.UTF8.GetBytes("0"));
                                            }
                                        }
                                    }
                                    //Temperatura
                                    else if (controlcomponente.IdDomTipoControlComponenteElectronico == 2)
                                    {
                                        decimal Promedio = 0;
                                        int     contador = 0;
                                        foreach (Gpr_Medicion_HorariaDTO medicion in medicionHorariaTemporal)
                                        {
                                            if (medicion.IdGprGalpon == galpon.IdGprGalpon && medicion.IdGprServicio == 9)
                                            {
                                                Promedio = Promedio + medicion.Medicion;
                                                contador++;
                                            }
                                        }

                                        if (Promedio > 0)
                                        {
                                            Promedio = Promedio / contador;

                                            if (e.Topic == componenteelectronico.Topic)
                                            {
                                                if (Convert.ToInt32(controlcomponente.Inicio) <= Promedio)
                                                {
                                                    if (Encoding.UTF8.GetString(e.Message) == "0")
                                                    {
                                                        client.Publish(componenteelectronico.Topic, Encoding.UTF8.GetBytes("1"));
                                                    }
                                                }
                                                else if (Promedio <= Convert.ToInt32(controlcomponente.Fin))
                                                {
                                                    if (Encoding.UTF8.GetString(e.Message) == "1")
                                                    {
                                                        client.Publish(componenteelectronico.Topic, Encoding.UTF8.GetBytes("0"));
                                                    }
                                                }
                                            }
                                        }
                                    }
                                    //Humedad
                                    else if (controlcomponente.IdDomTipoControlComponenteElectronico == 1)
                                    {
                                        decimal Promedio = 0;
                                        int     contador = 0;
                                        foreach (Gpr_Medicion_HorariaDTO medicion in medicionHorariaTemporal)
                                        {
                                            if (medicion.IdGprGalpon == galpon.IdGprGalpon && medicion.IdGprServicio == 10)
                                            {
                                                Promedio = Promedio + medicion.Medicion;
                                                contador++;
                                            }
                                        }

                                        if (Promedio > 0)
                                        {
                                            Promedio = Promedio / contador;

                                            if (e.Topic == componenteelectronico.Topic)
                                            {
                                                if (Convert.ToInt32(controlcomponente.Inicio) <= Promedio)
                                                {
                                                    if (Encoding.UTF8.GetString(e.Message) == "0")
                                                    {
                                                        client.Publish(componenteelectronico.Topic, Encoding.UTF8.GetBytes("1"));
                                                    }
                                                }
                                                else if (Promedio <= Convert.ToInt32(controlcomponente.Fin))
                                                {
                                                    if (Encoding.UTF8.GetString(e.Message) == "1")
                                                    {
                                                        client.Publish(componenteelectronico.Topic, Encoding.UTF8.GetBytes("0"));
                                                    }
                                                }
                                            }
                                        }
                                    }
                                }
                            }
                        }
                    }
                }
            }

            mtdProcesarInformacion(e.Topic, Encoding.UTF8.GetString(e.Message));

            //Console.WriteLine(DateTime.Now.Second);

            DateTime hoy    = DateTime.Now;
            DateTime ayer   = DateTime.Now.AddDays(-1);
            int      minuto = hoy.Minute;
            int      hora   = int.Parse(hoy.ToString("HH"));

            Console.WriteLine(hora.ToString() + ":" + minuto.ToString());
            Console.WriteLine(hoy);

            //flip asegura que solo se ejecute el metodo 1 vez en la hora que se indique
            if (minuto == 0 && hora != 0 && flip == 0)
            {
                foreach (Gpr_GalponDTO galpon in galpones)
                {
                    foreach (Gpr_ServicioDTO servicio in servicios.Where(X => X.IdGprTipoServicio != 3))
                    {
                        try
                        {
                            if (servicio.IdGprServicio == 7 || servicio.IdGprServicio == 8)
                            {
                                Gpr_Medicion_HorariaDTO medicion = medicionHorariaTemporal.Where(MHT => MHT.IdGprServicio == servicio.IdGprServicio && MHT.IdGprGalpon == galpon.IdGprGalpon).OrderBy(MHT => MHT.Medicion).FirstOrDefault();

                                medicion.Fecha         = hoy.ToString("dd-MM-yyyy");
                                medicion.Hora          = hora;
                                medicion.IdGprGalpon   = galpon.IdGprGalpon;
                                medicion.IdGprServicio = servicio.IdGprServicio;

                                medicionHoraria.Add(medicion);

                                Gpr_Medicion_Horaria_Controlador.GuardarMedicionHoraria(medicion);
                            }
                            else
                            {
                                decimal PromedioHorario = 0;
                                int     contador        = 0;
                                foreach (Gpr_Medicion_HorariaDTO medicion in medicionHorariaTemporal)
                                {
                                    if (medicion.IdGprGalpon == galpon.IdGprGalpon && servicio.IdGprServicio == medicion.IdGprServicio)
                                    {
                                        PromedioHorario = PromedioHorario + medicion.Medicion;
                                        contador++;
                                    }
                                }

                                if (PromedioHorario > 0)
                                {
                                    PromedioHorario = PromedioHorario / contador;

                                    //ejecutar el metodo para guardar lo almacenado por hora

                                    Gpr_Medicion_HorariaDTO medicionH = new Gpr_Medicion_HorariaDTO();
                                    medicionH.Fecha         = hoy.ToString("dd-MM-yyyy");
                                    medicionH.Hora          = hora;
                                    medicionH.IdGprGalpon   = galpon.IdGprGalpon;
                                    medicionH.IdGprServicio = servicio.IdGprServicio;
                                    medicionH.Medicion      = PromedioHorario;

                                    medicionHoraria.Add(medicionH);

                                    Gpr_Medicion_Horaria_Controlador.GuardarMedicionHoraria(medicionH);
                                }
                            }
                        }
                        catch
                        {
                        }
                    }
                }

                // se cancela el ciclo
                flip = 1;
                medicionHorariaTemporal.Clear();
                Console.WriteLine("IF 1");
            }
            else if (minuto == 0 && hora == 0 && flip == 0)
            {
                //ejecutar el metodo para guardar lo almacenado por hora a las 12
                foreach (Gpr_GalponDTO galpon in galpones)
                {
                    foreach (Gpr_ServicioDTO servicio in servicios.Where(X => X.IdGprTipoServicio != 3))
                    {
                        try
                        {
                            if (servicio.IdGprServicio == 7 || servicio.IdGprServicio == 8)
                            {
                                Gpr_Medicion_HorariaDTO medicion = medicionHorariaTemporal.Where(MHT => MHT.IdGprServicio == servicio.IdGprServicio && MHT.IdGprGalpon == galpon.IdGprGalpon).OrderBy(MHT => MHT.Medicion).FirstOrDefault();

                                medicion.Fecha         = hoy.ToString("dd-MM-yyyy");
                                medicion.Hora          = hora;
                                medicion.IdGprGalpon   = galpon.IdGprGalpon;
                                medicion.IdGprServicio = servicio.IdGprServicio;

                                medicionHoraria.Add(medicion);

                                Gpr_Medicion_Horaria_Controlador.GuardarMedicionHoraria(medicion);
                            }
                            else
                            {
                                decimal PromedioHorario = 0;
                                int     contador        = 0;
                                foreach (Gpr_Medicion_HorariaDTO medicion in medicionHorariaTemporal)
                                {
                                    if (medicion.IdGprGalpon == galpon.IdGprGalpon && servicio.IdGprServicio == medicion.IdGprServicio)
                                    {
                                        PromedioHorario = PromedioHorario + medicion.Medicion;
                                        contador++;
                                    }
                                }

                                if (PromedioHorario > 0)
                                {
                                    PromedioHorario = PromedioHorario / contador;

                                    //ejecutar el metodo para guardar lo almacenado por hora

                                    Gpr_Medicion_HorariaDTO medicionH = new Gpr_Medicion_HorariaDTO();
                                    medicionH.Fecha         = ayer.ToString("dd-MM-yyyy");;
                                    medicionH.Hora          = 24;
                                    medicionH.IdGprGalpon   = galpon.IdGprGalpon;
                                    medicionH.IdGprServicio = servicio.IdGprServicio;
                                    medicionH.Medicion      = PromedioHorario;

                                    medicionHoraria.Add(medicionH);

                                    Gpr_Medicion_Horaria_Controlador.GuardarMedicionHoraria(medicionH);
                                }
                            }
                        }
                        catch
                        {
                        }
                    }
                }

                foreach (Gpr_GalponDTO galpon in galpones)
                {
                    foreach (Gpr_ServicioDTO servicio in servicios.Where(X => X.Descripcion != "Control"))
                    {
                        try
                        {
                            if (servicio.IdGprServicio == 7 || servicio.IdGprServicio == 8)
                            {
                                Gpr_Medicion_HorariaDTO medicionMaxima = medicionHoraria.Where(MHT => MHT.IdGprServicio == servicio.IdGprServicio && MHT.IdGprGalpon == galpon.IdGprGalpon).OrderByDescending(MHT => MHT.Medicion).FirstOrDefault();
                                Gpr_Medicion_HorariaDTO medicionMinima = medicionHoraria.Where(MHT => MHT.IdGprServicio == servicio.IdGprServicio && MHT.IdGprGalpon == galpon.IdGprGalpon).OrderBy(MHT => MHT.Medicion).FirstOrDefault();

                                decimal PromedioDiario = medicionMaxima.Medicion - medicionMinima.Medicion;

                                Gpr_Medicion_DiariaDTO medicionD = new Gpr_Medicion_DiariaDTO();
                                medicionD.Fecha         = ayer.ToString("dd-MM-yyyy");;
                                medicionD.IdGprGalpon   = galpon.IdGprGalpon;
                                medicionD.IdGprServicio = servicio.IdGprServicio;
                                medicionD.Medicion      = PromedioDiario;

                                //medicionDiaria.Add(medicionD);

                                medicionDiaria.Add(Gpr_Medicion_Diaria_Controlador.GuardarMedicionDiaria(medicionD));
                            }
                            else
                            {
                                decimal PromedioDiario = 0;
                                int     contador       = 0;
                                foreach (Gpr_Medicion_HorariaDTO medicion in medicionHoraria)
                                {
                                    if (medicion.IdGprGalpon == galpon.IdGprGalpon && servicio.IdGprServicio == medicion.IdGprServicio)
                                    {
                                        PromedioDiario = PromedioDiario + medicion.Medicion;
                                        contador++;
                                    }
                                }

                                if (PromedioDiario > 0)
                                {
                                    PromedioDiario = PromedioDiario / contador;

                                    //ejecutar el metodo para guardar lo almacenado por dia

                                    Gpr_Medicion_DiariaDTO medicionD = new Gpr_Medicion_DiariaDTO();
                                    medicionD.Fecha         = ayer.ToString("dd-MM-yyyy");
                                    medicionD.IdGprGalpon   = galpon.IdGprGalpon;
                                    medicionD.IdGprServicio = servicio.IdGprServicio;
                                    medicionD.Medicion      = PromedioDiario;

                                    //medicionDiaria.Add(medicionD);

                                    medicionDiaria.Add(Gpr_Medicion_Diaria_Controlador.GuardarMedicionDiaria(medicionD));
                                }
                            }
                        }
                        catch
                        {
                        }
                    }

                    foreach (Gpr_Medicion_DiariaDTO mediciondiaria in medicionDiaria)
                    {
                        try
                        {
                            Gpr_Costo_ServicioDTO costo = costoServicios.Where(CS => CS.IdGprServicio == mediciondiaria.IdGprServicio).FirstOrDefault();

                            decimal gasto = costo.Costo * mediciondiaria.Medicion;

                            Gpr_Gasto_DiarioDTO gastoDiario = new Gpr_Gasto_DiarioDTO
                            {
                                IdGprMedicionDiaria = mediciondiaria.IdGprMedicionDiaria,
                                Gasto = gasto,
                                IdGprCostoServicio = costo.IdGprCostoServicio,
                            };

                            Gpr_Gasto_Diario_Controlador.GuardarGastoDiario(gastoDiario);
                        }
                        catch
                        {
                        }
                    }
                }

                // se cancela el ciclo
                flip = 1;
                medicionDiaria.Clear();
                medicionHoraria.Clear();
                Console.WriteLine("IF 2");
            }
            else if (minuto == 1)
            {
                flip = 0;
                Console.WriteLine("IF 3");
            }
            else
            {
                Console.WriteLine("EN ESPERA");
            }

            //Refresco de información

            if ((DateTime.Now.Second >= 0 && DateTime.Now.Second < 10) && flipMinuto == 0)
            {
                mtdCargarInfo();
                flipMinuto = 1;
            }
            else if (DateTime.Now.Second >= 10)
            {
                flipMinuto = 0;
            }
        }