summaryrefslogtreecommitdiff
path: root/src/services/db.rs
diff options
context:
space:
mode:
authormrw1593 <botahamec@outlook.com>2023-03-19 13:23:20 -0400
committermrw1593 <botahamec@outlook.com>2023-05-29 10:45:26 -0400
commit8ec105595db9d2957c7327112e7a0b63d9d59400 (patch)
treea53e2e2c375d2d7155c30058a69dd713be4e5905 /src/services/db.rs
parentf149374e2c6682ea5b9b1d692b001d6ab5faea4a (diff)
Create user
Diffstat (limited to 'src/services/db.rs')
-rw-r--r--src/services/db.rs50
1 files changed, 49 insertions, 1 deletions
diff --git a/src/services/db.rs b/src/services/db.rs
index a8e4918..efa9584 100644
--- a/src/services/db.rs
+++ b/src/services/db.rs
@@ -1,8 +1,56 @@
use exun::*;
-use sqlx::MySqlPool;
+use sqlx::{query, query_scalar, Executor, MySql, MySqlPool};
+use uuid::Uuid;
+
+use crate::models::User;
/// Intialize the connection pool
pub async fn initialize(db: &str, user: &str, password: &str) -> Result<MySqlPool, RawUnexpected> {
let url = format!("mysql://{user}:{password}@localhost/{db}");
MySqlPool::connect(&url).await.unexpect()
}
+
+pub async fn user_id_exists<'c>(
+ conn: impl Executor<'c, Database = MySql>,
+ id: Uuid,
+) -> Result<bool, RawUnexpected> {
+ let exists = query_scalar!(
+ r#"SELECT EXISTS(SELECT user_id FROM users WHERE user_id = ?) as "e: bool""#,
+ id
+ )
+ .fetch_one(conn)
+ .await?;
+
+ Ok(exists)
+}
+
+pub async fn username_is_used<'c>(
+ conn: impl Executor<'c, Database = MySql>,
+ username: &str,
+) -> Result<bool, RawUnexpected> {
+ let exists = query_scalar!(
+ r#"SELECT EXISTS(SELECT user_id FROM users WHERE username = ?) as "e: bool""#,
+ username
+ )
+ .fetch_one(conn)
+ .await?;
+
+ Ok(exists)
+}
+
+pub async fn new_user<'c>(
+ conn: impl Executor<'c, Database = MySql>,
+ user: User,
+) -> Result<sqlx::mysql::MySqlQueryResult, sqlx::Error> {
+ query!(
+ r"INSERT INTO users (user_id, username, password_hash, password_salt, password_version)
+ VALUES (?, ?, ?, ?, ?)",
+ user.user_id,
+ user.username(),
+ user.password_hash(),
+ user.password_salt(),
+ user.password_version()
+ )
+ .execute(conn)
+ .await
+}