Beispiel #1
0
        /// <summary>
        /// Metodo responsabile della ricerca in base ad una query prestabilita
        /// </summary>
        /// <param name="query">Stringa da cercare</param>
        /// <returns></returns>
        public IList <IUtente> Cerca(string query)
        {
            string         uppercaseQuery = query.ToUpper();
            List <IUtente> utenti         = new List <IUtente>();

            // Effettuo una ricerca CASE-INSENSITIVE sui campi email, nome, cognome ed username
            using (SQLiteCommand cmd = new SQLiteCommand("SELECT * FROM utenti WHERE UPPER(email) LIKE '%' || @query || '%' " +
                                                         "OR UPPER(nome) LIKE '%' || @query || '%' " +
                                                         "OR UPPER(cognome) LIKE '%' || @query || '%' " +
                                                         "OR UPPER(username) LIKE '%' || @query || '%' ", _connection))
            {
                cmd.Prepare();
                cmd.Parameters.AddWithValue("@query", uppercaseQuery);
                using (SQLiteDataReader reader = cmd.ExecuteReader())
                {
                    while (reader.Read())
                    {
                        // Converto la entry del database in una stazione
                        IUtente utenteCorrente = Utente.ConvertiRigaInUtente(reader);
                        if (utenteCorrente != null)
                        {
                            utenti.Add(utenteCorrente);
                        }
                    }
                }
            }

            return(utenti);
        }
Beispiel #2
0
        public IList <IUtente> ListaTutti()
        {
            List <IUtente> utenti = new List <IUtente>();

            using (SQLiteCommand cmd = new SQLiteCommand("SELECT * FROM utenti", _connection))
            {
                using (SQLiteDataReader reader = cmd.ExecuteReader())
                {
                    while (reader.Read())
                    {
                        IUtente utenteCorrente = Utente.ConvertiRigaInUtente(reader);
                        if (utenteCorrente != null)
                        {
                            utenti.Add(utenteCorrente);
                        }
                    }
                }
            }

            return(utenti);
        }
Beispiel #3
0
        public IUtente ValidaCredenziali(string username, string pass)
        {
            IUtente outputUtente = null;

            using (SQLiteCommand cmd = new SQLiteCommand("SELECT * FROM utenti WHERE username = @Username", _connection))
            {
                cmd.Prepare();
                cmd.Parameters.AddWithValue("@Username", username);

                using (SQLiteDataReader reader = cmd.ExecuteReader())
                {
                    while (reader.Read())
                    {
                        outputUtente = Utente.ConvertiRigaInUtente(reader);
                    }
                }
            }

            // Controllo che l'utente esista e la password corrisponda
            if (outputUtente == null)
            {
                return(null);
            }
            else
            {
                // Controllo che la password corrisponda
                string hashPrevisto = HashUtil.GeneraSHA256(pass + outputUtente.SaltPass);
                if (hashPrevisto == outputUtente.HashPass)
                {
                    return(outputUtente);
                }
                else
                {
                    return(null);
                }
            }
        }