docbox_database/models/
user.rs1use crate::{DbExecutor, DbResult};
2use serde::Serialize;
3use sqlx::prelude::FromRow;
4use utoipa::ToSchema;
5
6pub type UserId = String;
7
8#[derive(Debug, Clone, Serialize, FromRow, ToSchema, sqlx::Type, PartialEq, Eq)]
9#[sqlx(type_name = "docbox_user")]
10pub struct User {
11 pub id: String,
13 pub name: Option<String>,
15 pub image_id: Option<String>,
17}
18
19impl User {
20 pub async fn store(
22 db: impl DbExecutor<'_>,
23 id: UserId,
24 name: Option<String>,
25 image_id: Option<String>,
26 ) -> DbResult<User> {
27 sqlx::query(
28 r#"
29 INSERT INTO "docbox_users" ("id", "name", "image_id")
30 VALUES ($1, $2, $3)
31 ON CONFLICT ("id")
32 DO UPDATE SET "name" = EXCLUDED."name", "image_id" = EXCLUDED."image_id"
33 "#,
34 )
35 .bind(id.as_str())
36 .bind(name.as_ref())
37 .bind(image_id.as_ref())
38 .execute(db)
39 .await?;
40
41 Ok(User { id, name, image_id })
42 }
43
44 pub async fn find(db: impl DbExecutor<'_>, id: UserId) -> DbResult<Option<User>> {
46 sqlx::query_as(r#"SELECT * FROM "docbox_users" WHERE "id" = $1"#)
47 .bind(id)
48 .fetch_optional(db)
49 .await
50 }
51}