diff options
author | Matthias Beyer <mail@beyermatthias.de> | 2020-11-05 19:31:29 +0100 |
---|---|---|
committer | Matthias Beyer <mail@beyermatthias.de> | 2020-11-05 19:42:59 +0100 |
commit | 7d582367e0ad341e5ee67c63cd2b53eeaaa98132 (patch) | |
tree | 23e07a6db76f83091ea2d34d79bedc126916efbf | |
parent | 09ca98cc77abbec3b511d79c0a966a1527e9b880 (diff) |
Add model types for EnvVar inserting
Signed-off-by: Matthias Beyer <mail@beyermatthias.de>
-rw-r--r-- | src/db/models/envvar.rs | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/src/db/models/envvar.rs b/src/db/models/envvar.rs index c70b406..24403d6 100644 --- a/src/db/models/envvar.rs +++ b/src/db/models/envvar.rs @@ -1,6 +1,40 @@ +use std::ops::Deref; + +use anyhow::Error; +use anyhow::Result; +use diesel::PgConnection; +use diesel::prelude::*; + +use crate::schema::envvars::*; +use crate::schema::envvars; + #[derive(Queryable)] pub struct EnvVar { pub id: i32, pub name: String, pub value: String, } + +#[derive(Insertable)] +#[table_name="envvars"] +struct NewEnvVar<'a> { + pub name: &'a str, + pub value: &'a str, +} + +impl EnvVar { + pub fn create_or_fetch(database_connection: &PgConnection, k: &str, v: &str) -> Result<EnvVar> { + let new_envvar = NewEnvVar { name: k, value: v }; + + diesel::insert_into(envvars::table) + .values(&new_envvar) + .on_conflict_do_nothing() + .execute(database_connection)?; + + dsl::envvars + .filter(name.eq(k).and(value.eq(v))) + .first::<EnvVar>(database_connection) + .map_err(Error::from) + } +} + |