public IActionResult LogIn([FromBody] LoginModel loginModel)
        {
            ResponseModel responseModel = new ResponseModel();

            try
            {
                if (loginModel == null)
                {
                    responseModel.Codigo  = CodeEN.Warning;
                    responseModel.Mensaje = "Datos inválidos";

                    return(BadRequest(responseModel));
                }

                Tuple <Boolean, String> Valid = loginModel.Validate();

                if (!Valid.Item1)
                {
                    responseModel.Codigo  = CodeEN.Warning;
                    responseModel.Mensaje = Valid.Item2;

                    return(BadRequest(responseModel));
                }

                ClienteBL clienteBL = new ClienteBL();

                Cliente cliente = clienteBL.Consultar(loginModel.Cuenta);

                if (cliente == null)
                {
                    responseModel.Codigo  = CodeEN.Warning;
                    responseModel.Mensaje = "Cuenta no encontrada";

                    return(BadRequest(responseModel));
                }

                Int32  MaxIntentosPermitidos = configuration.GetValue <Int32>("Variables:Seguridad:NroIntentosPermitidos");
                Double MaxTiempoEspera       = configuration.GetValue <Double>("Variables:Seguridad:TiempoEsperaIntentos");

                if (cliente.Estado != "3" ||
                    (cliente.Estado == "3" &&
                     (DateTime.UtcNow.AddHours(-5) - cliente.FechaUltimoIntento.GetValueOrDefault()).TotalHours > MaxTiempoEspera))
                {
                    DateTime fechaActual     = DateTime.UtcNow.AddHours(-5);
                    String   codigoResultado = GenerarCodigoHuffman(loginModel.Contrasena);

                    if (codigoResultado == cliente.Contrasena)
                    {
                        cliente.NroIntento         = null;
                        cliente.FechaUltimoIntento = null;
                        cliente.Estado             = "1";

                        clienteBL.ActualizarIntentos(cliente.ClienteId, cliente.Estado, cliente.NroIntento, cliente.FechaUltimoIntento);

                        String Token = GenerarToken(cliente);

                        //var clienteLogueado = new
                        //{
                        //    cliente.ClienteId,
                        //    cliente.Cuenta,
                        //    NombreCompleto = cliente.Nombre + " " + cliente.Apellido,
                        //    Token
                        //};

                        responseModel.Codigo  = CodeEN.Success;
                        responseModel.Mensaje = "El cliente ha accedido a la aplicación de manera satisfactoria";
                        responseModel.Data    = Token;

                        return(Ok(responseModel));
                    }
                    else
                    {
                        if (cliente.Estado == "3")
                        {
                            cliente.NroIntento         = 1;
                            cliente.FechaUltimoIntento = fechaActual;
                            cliente.Estado             = "1";
                        }
                        else if ((DateTime.UtcNow.AddHours(-5) - cliente.FechaUltimoIntento.GetValueOrDefault()).TotalHours > MaxTiempoEspera)
                        {
                            cliente.NroIntento         = 1;
                            cliente.FechaUltimoIntento = fechaActual;
                        }
                        else
                        {
                            cliente.NroIntento         = cliente.NroIntento == null ? 1 : cliente.NroIntento + 1;
                            cliente.FechaUltimoIntento = fechaActual;
                            cliente.Estado             = cliente.NroIntento == 5 ? "3" : cliente.Estado;
                        }

                        clienteBL.ActualizarIntentos(cliente.ClienteId, cliente.Estado, cliente.NroIntento, cliente.FechaUltimoIntento);

                        responseModel.Codigo  = CodeEN.Error;
                        responseModel.Mensaje = "Usuario y/o contraseña inválidos";
                        responseModel.Data    = null;

                        return(StatusCode(StatusCodes.Status500InternalServerError, responseModel));
                    }
                }
                else
                {
                    responseModel.Codigo  = CodeEN.Error;
                    responseModel.Mensaje = "Máximo número de intentos permitidos";
                    responseModel.Data    = null;

                    return(StatusCode(StatusCodes.Status500InternalServerError, responseModel));
                }
            }
            catch (Exception ex)
            {
                responseModel.Codigo  = CodeEN.Exception;
                responseModel.Mensaje = "Ocurrió una excepción";

                return(StatusCode(StatusCodes.Status500InternalServerError, responseModel));
            }
        }