aze 0.1.1

A time tracking tool heavenly inspired by watson
Documentation
use crate::database::establish_connection;

use diesel::prelude::*;

pub fn has_project(project: String) -> bool {
    use diesel::sql_types::VarChar;

    #[derive(QueryableByName)]
    struct Project {
        #[diesel(sql_type = VarChar)]
        name: String,
    }

    let mut conn = establish_connection();
    let results = diesel::sql_query(r#"SELECT DISTINCT project AS name FROM frames"#)
        .load::<Project>(&mut conn)
        .expect("Query failed");

    for result in results {
        if result.name == project {
            return true;
        }
    }

    false
}

pub fn find_all() -> Vec<String> {
    use diesel::sql_types::VarChar;

    #[derive(QueryableByName)]
    struct Project {
        #[diesel(sql_type = VarChar)]
        name: String,
    }

    let mut conn = establish_connection();
    let results = diesel::sql_query(r#"SELECT DISTINCT project AS name FROM frames"#)
        .load::<Project>(&mut conn)
        .expect("Query failed");

    let mut project_strings : Vec<String> = vec![];
    for result in results {
        project_strings.push(result.name)
    }

    project_strings
}