예제 #1
0
 protected void Page_Load(object sender, EventArgs e)
 {
     if (!IsPostBack)
     {
         _sesion       = new Sesion();
         _cookieActual = _sesion.verificarValidez(Request.Cookies["PS"]);
         if (_cookieActual == null)                 // Si la cookie expira redirecciona a la pantalla de Login
         {
             Response.Redirect("../Autentificacion/Login.aspx");
         }
         else                 // Volver a crear la cookie en el cliente, con el nuevo tiempo de expiración
         {
             Response.SetCookie(_cookieActual);
         }
         _controladorPEUL = new ControladorPEUL();
         String grupoUsuario = _sesion.obtenerGrupoUsuario(_cookieActual);
         if ((grupoUsuario.Equals("prof")) || (grupoUsuario.Equals("users")) || (grupoUsuario.Equals("ests")) ||
             (grupoUsuario.Equals("operadores")))                             // Reportar si un usuario autenticado intenta hacer ingreso a una página que no tiene permiso
         {
             Notificacion notificacion = new Notificacion();
             notificacion.enviarCorreo("Se ha intentado realizar un acceso no permitido por parte del usuario " + _sesion.obtenerLoginUsuario(_cookieActual) + " a la página de ConsultarReporteUso.aspx", "*****@*****.**", "Violación de Seguridad");
             Response.Redirect("../Compartido/AccesoDenegado.aspx");
         }
         _listaLaboratorios = _controladorPEUL.obtenerLaboratorios(); // Obtener laboratorios
         if (_listaLaboratorios != null)
         {
             _ddlLaboratorios.Items.Add("Seleccionar");
             for (int i = 0; i < _listaLaboratorios.Count; i++)
             {
                 _ddlLaboratorios.Items.Add(_listaLaboratorios.ElementAt(i).ElementAt(1).ToString()); // Llenar el _ddlLaboratorios con los nombres de los labs
             }
         }
         else
         {
             _ddlLaboratorios.Items.Clear();
             _ddlLaboratorios.Items.Add("No hay laboratorios disponibles");
             _imgMensaje.ImageUrl = "~/Imagenes/Error.png";
             _lblMensaje.Text     = "Se ha producido un error al obtener los laboratorios.";
             _imgMensaje.Visible  = true;
             _lblMensaje.Visible  = true;
         }
     }
 }
예제 #2
0
        protected void Page_Load(object sender, EventArgs e)
        {
            if (!IsPostBack) // Solo cargar los datos la primera vez que la página ha sido cargada
            {
                _sesion       = new Sesion();
                _cookieActual = _sesion.verificarValidez(Request.Cookies["PS"]);
                if (_cookieActual == null)                              // Si la cookie expira redirecciona a la pantalla de Login
                {
                    Response.Redirect("../Autentificacion/Login.aspx"); //
                }
                else // Volver a crear la cookie en el cliente, con el nuevo tiempo de expiración
                {
                    Response.SetCookie(_cookieActual);
                }
                _controlador = new ControladorPEUL();
                string grupoUsuario = _sesion.obtenerGrupoUsuario(_cookieActual);
                string loginUsuario = _sesion.obtenerLoginUsuario(_cookieActual);
                if ((grupoUsuario.Equals("prof")) || (grupoUsuario.Equals("users")) || (grupoUsuario.Equals("ests")) ||
                    (grupoUsuario.Equals("operadores")))
                {
                    _controlador.insertarBitacoraError("Se ha intentado realizar un acceso no permitido por parte del usuario " + loginUsuario + " a la página de GenerarEstadisticaUso.aspx", "");
                    Response.Redirect("../Compartido/AccesoDenegado.aspx");
                }
                _laboratorios = _controlador.obtenerLaboratorios();
                _Semestres    = _controlador.obtenerSemestres();
                var _errores = new int[2];
                _errores[0] = 0;           //Error al cargar Laboratorios
                _errores[1] = 0;           //Error al cargar Semestres

                if (_laboratorios != null) // Llenar _ddlLaboratorios si se encontraton datos
                {
                    for (int i = 0; i < _laboratorios.Count; i++)
                    {
                        var item = new ListItem(_laboratorios.ElementAt(i).ElementAt(1).ToString(), Convert.ToString(_laboratorios.ElementAt(i).ElementAt(0)));
                        _ddlLaboratorios.Items.Add(item); // Obtiene los nombres de los laboratorios encontrados
                    }
                }
                else // No se encontraron laboratorios
                {
                    _errores [0] = 1;
                }

                if (_Semestres != null) // Llenar _ddlSemestreInicio y final si se encontraton datos
                {
                    for (int i = 0; i < _Semestres.Count; i++)
                    {
                        var item = new ListItem(_Semestres.ElementAt(i).ElementAt(1).ToString(), _Semestres.ElementAt(i).ElementAt(2).ToString());
                        _ddlSemestreInicio.Items.Add(item);
                        // Obtiene los nombres de los Semestres encontrados
                        item = new ListItem(_Semestres.ElementAt(i).ElementAt(1).ToString(), _Semestres.ElementAt(i).ElementAt(3).ToString());
                        _ddlSemestreFinal.Items.Add(item);
                    }
                }
                else // No se encontraron semestres
                {
                    _errores[1] = 1;
                }

                if (_errores[0] == 1) // Detectar errores
                {
                    if (_errores[1] == 1)
                    {
                        _ddlLaboratorios.Items.Clear();
                        _ddlSemestreFinal.Items.Clear();
                        _ddlSemestreInicio.Items.Clear();
                        _ddlLaboratorios.Items.Add("No hay laboratorios disponibles");
                        _ddlSemestreInicio.Items.Add("No hay semestres disponibles");
                        _ddlSemestreFinal.Items.Add("No hay semestres disponibles");

                        _imgMensaje.ImageUrl = "~/Imagenes/Error.png";
                        _lblMensaje.Text     = "Error al cargar los de semestres y laboratorios";
                        _imgMensaje.Visible  = true;
                        _lblMensaje.Visible  = true;
                    }
                    else
                    {
                        _ddlLaboratorios.Items.Clear();
                        _ddlLaboratorios.Items.Add("No hay laboratorios disponibles");

                        _imgMensaje.ImageUrl = "~/Imagenes/Error.png";
                        _lblMensaje.Text     = "Error al cargar los laboratorios.";
                        _imgMensaje.Visible  = true;
                        _lblMensaje.Visible  = true;
                    }
                }
                if (_errores[1] == 1) // Detectar errores
                {
                    if (_errores[0] == 1)
                    {
                        _ddlLaboratorios.Items.Clear();
                        _ddlSemestreFinal.Items.Clear();
                        _ddlSemestreInicio.Items.Clear();
                        _ddlLaboratorios.Items.Add("No hay laboratorios disponibles");
                        _ddlSemestreInicio.Items.Add("No hay semestres disponibles");
                        _ddlSemestreFinal.Items.Add("No hay semestres disponibles");

                        _imgMensaje.ImageUrl = "~/Imagenes/Error.png";
                        _lblMensaje.Text     = "Error al cargar los de semestres y laboratorios";
                        _imgMensaje.Visible  = true;
                        _lblMensaje.Visible  = true;
                    }
                    else
                    {
                        _ddlLaboratorios.Items.Clear();
                        _ddlLaboratorios.Items.Add("No hay semestres disponibles");

                        _imgMensaje.ImageUrl = "~/Imagenes/Error.png";
                        _lblMensaje.Text     = "Erro al cargar los semestres";
                        _imgMensaje.Visible  = true;
                        _lblMensaje.Visible  = true;
                    }
                }

                var dt = new DataTable("Datos");
                dt.Columns.Add(new DataColumn("Uso"));
                dt.Columns.Add(new DataColumn("Periodos"));

                dt.Rows.Add(15, "Enero-2010");
                dt.Rows.Add(10, "Febrero-2010");
                dt.Rows.Add(5, "Marzo-2010");
                dt.Rows.Add(35, "Abril-2010");
                dt.Rows.Add(90, "Mayo-2010");
                dt.Rows.Add(50, "Junio-2010");

                //Cargar los datos de la base y define ejes X y Y
                _chtEstadisticas.DataSource = dt;
                _chtEstadisticas.Series["_serieUso"].XValueMember  = "Periodos";
                _chtEstadisticas.Series["_serieUso"].YValueMembers = "Uso";
                _chtEstadisticas.DataBind();

                _chtEstadisticas.Series["_serieUso"]["ShowMarkerLines"]           = "True";
                _chtEstadisticas.ChartAreas["_chartAreaEstadisticas"].AxisX.Title = "Fechas";
                _chtEstadisticas.ChartAreas["_chartAreaEstadisticas"].AxisY.Title = "Porcentaje de uso";

                dt = new DataTable("Datos");
                dt.Columns.Add(new DataColumn("Uso"));
                dt.Columns.Add(new DataColumn("Periodos"));

                dt.Rows.Add(8, "Enero-2010");
                dt.Rows.Add(2, "Febrero-2010");
                dt.Rows.Add(6, "Marzo-2010");
                dt.Rows.Add(5, "Abril-2010");
                dt.Rows.Add(15, "Mayo-2010");
                dt.Rows.Add(10, "Junio-2010");

                //Cargar los datos de la base y define ejes X y Y
                _chtEstadisticasLaptops.DataSource = dt;
                _chtEstadisticasLaptops.Series["_serieUsoLaptop"].XValueMember  = "Periodos";
                _chtEstadisticasLaptops.Series["_serieUsoLaptop"].YValueMembers = "Uso";
                _chtEstadisticasLaptops.DataBind();

                _chtEstadisticasLaptops.Series["_serieUsoLaptop"]["ShowMarkerLines"]            = "True";
                _chtEstadisticasLaptops.ChartAreas["_chartAreaEstadisticasLaptops"].AxisX.Title = "Fechas";
                _chtEstadisticasLaptops.ChartAreas["_chartAreaEstadisticasLaptops"].AxisY.Title = "Cantidad de laptops";

                UpdatePanel.Update();
            }
        }
        private int _errorCarga;                            // Para manejo de errores en el tiempo de carga de la página
        // 0: No se cargaron laboratorios
        // 1: No se cargaron los estados (Comentarios predefinidos)
        // 2: No se han cargado ni estados ni laboratorios
        // 3: No se obtuvieron datos del uso de los laboratorios
        // 4: No se pudo cargar ninguno de los elementos de la pagina
        #endregion

        protected void Page_Load(object sender, EventArgs e)
        {
            try
            {
                if (!IsPostBack) // Solo cargar los datos la primera vez que la página ha sido cargada
                {
                    _sesion       = new Sesion();
                    _cookieActual = _sesion.verificarValidez(Request.Cookies["PS"]);
                    if (_cookieActual == null)                              // Si la cookie expira redirecciona a la pantalla de Login
                    {
                        Response.Redirect("../Autentificacion/Login.aspx"); //
                    }
                    else // Volver a crear la cookie en el cliente, con el nuevo tiempo de expiración
                    {
                        Response.SetCookie(_cookieActual);
                    }
                    _errorCarga  = -1;
                    _controlador = new ControladorPEUL();
                    string grupoUsuario = _sesion.obtenerGrupoUsuario(Request.Cookies["PS"]);
                    if ((grupoUsuario.Equals("prof")) || (grupoUsuario.Equals("users")) || (grupoUsuario.Equals("ests")))
                    {
                        _controlador.insertarBitacoraError("Se ha intentado realizar un acceso no permitido por parte del usuario " + _sesion.obtenerLoginUsuario(Request.Cookies["PS"]) + " a la página de RegistroUsoLaboratorio.aspx", "");
                        Response.Redirect("../Compartido/AccesoDenegado.aspx");
                    }
                    _laboratorios = _controlador.obtenerLaboratorios(); //Obtener los laboratorios
                    if (_laboratorios != null)
                    {
                        foreach (List <object> lab in _laboratorios)
                        {
                            _ddlLaboratorio.Items.Add(lab[1].ToString());    //Inserta los nombres de los laboratorios en _ddlLaboratorio
                        }
                    }
                    else
                    {
                        _errorCarga = 0;
                    }

                    _estados = _controlador.obtenerEstadoLaboratorio(); //Obtener los estados de los laboratorios
                    if (_estados.Count > 0)
                    {
                        foreach (List <object> estado in _estados)
                        {
                            _ddlEstado.Items.Add(estado[1].ToString()); //Insertar las descripciones de los estados en _ddlEstado
                        }
                    }
                    else
                    {
                        if (_errorCarga == 0)
                        {
                            _errorCarga = 2;
                        }
                        else
                        {
                            _errorCarga = 1;
                        }
                    }

                    _usoLaboratorios = _controlador.calcularUsoActual();    //Obtener los datos del uso de los laboratorios
                    if (_usoLaboratorios != null)
                    {
                        cargarDatos(_usoLaboratorios);  //Llama al método que se encarga de cargar los datos en el grid y en el grafico
                    }
                    else
                    {
                        if (_errorCarga == 2)
                        {
                            _errorCarga = 4;
                        }
                        else
                        {
                            _errorCarga = 3;
                        }
                    }

                    switch (_errorCarga)    //Verificar si hubo algun error
                    {
                    case 0:
                        _ddlLaboratorio.Items.Clear();
                        _ddlLaboratorio.Items.Add("No hay lugares disponibles");
                        _imgMensaje.ImageUrl = "~/Imagenes/Advertencia.png";
                        _lblMensaje.Text     = "No hay lugares disponibles.";
                        _imgMensaje.Visible  = true;
                        _lblMensaje.Visible  = true;
                        break;

                    case 1:
                        _ddlEstado.Items.Clear();
                        _ddlEstado.Items.Add("No hay estados disponibles");
                        _imgMensaje.ImageUrl = "~/Imagenes/Advertencia.png";
                        _lblMensaje.Text     = "No hay estados disponibles.";
                        _imgMensaje.Visible  = true;
                        _lblMensaje.Visible  = true;
                        break;

                    case 2:
                        _ddlLaboratorio.Items.Clear();
                        _ddlLaboratorio.Items.Add("No hay lugares disponibles");
                        _ddlEstado.Items.Clear();
                        _ddlEstado.Items.Add("No hay estados disponibles");
                        _imgMensaje.ImageUrl = "~/Imagenes/Advertencia.png";
                        _lblMensaje.Text     = "No hay lugares y estados disponibles.";
                        _imgMensaje.Visible  = true;
                        _lblMensaje.Visible  = true;
                        break;

                    case 3:
                        _imgMensaje.ImageUrl = "~/Imagenes/Advertencia.png";
                        _lblMensaje.Text     = "No hay registro del uso de los laboratorios.";
                        _imgMensaje.Visible  = true;
                        _lblMensaje.Visible  = true;
                        break;

                    case 4:
                        _ddlLaboratorio.Items.Clear();
                        _ddlLaboratorio.Items.Add("No hay lugares disponibles");
                        _ddlEstado.Items.Clear();
                        _ddlEstado.Items.Add("No hay estados disponibles");
                        _imgMensaje.ImageUrl = "~/Imagenes/Advertencia.png";
                        _lblMensaje.Text     = "No hay lugares, estados y registro de uso de los laboratorios disponibles.";
                        _imgMensaje.Visible  = true;
                        _lblMensaje.Visible  = true;
                        break;
                    }
                }
            }
            catch (Exception ex)
            {
                _controlador = new ControladorPEUL();
                _controlador.insertarBitacoraError(ex.ToString(), "");
            }
        }