summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMatthias Beyer <mail@beyermatthias.de>2020-11-05 19:31:29 +0100
committerMatthias Beyer <mail@beyermatthias.de>2020-11-05 19:42:59 +0100
commit7d582367e0ad341e5ee67c63cd2b53eeaaa98132 (patch)
tree23e07a6db76f83091ea2d34d79bedc126916efbf
parent09ca98cc77abbec3b511d79c0a966a1527e9b880 (diff)
Add model types for EnvVar inserting
Signed-off-by: Matthias Beyer <mail@beyermatthias.de>
-rw-r--r--src/db/models/envvar.rs34
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)
+ }
+}
+