about summary refs log tree commit diff stats
path: root/crates/rocie-server/src/api/set/auth/user.rs
diff options
context:
space:
mode:
Diffstat (limited to 'crates/rocie-server/src/api/set/auth/user.rs')
-rw-r--r--crates/rocie-server/src/api/set/auth/user.rs63
1 files changed, 63 insertions, 0 deletions
diff --git a/crates/rocie-server/src/api/set/auth/user.rs b/crates/rocie-server/src/api/set/auth/user.rs
new file mode 100644
index 0000000..1f262d5
--- /dev/null
+++ b/crates/rocie-server/src/api/set/auth/user.rs
@@ -0,0 +1,63 @@
+use actix_identity::Identity;
+use actix_web::{HttpResponse, Responder, Result, post, web};
+use serde::Deserialize;
+use utoipa::ToSchema;
+
+use crate::{
+    app::App,
+    storage::sql::{
+        insert::Operations,
+        user::{PasswordHash, User, UserId},
+    },
+};
+
+#[derive(Deserialize, ToSchema)]
+pub(crate) struct UserStub {
+    /// The name of the new user.
+    pub(crate) name: String,
+
+    /// The password of the new user.
+    pub(crate) password: String,
+
+    /// An optional description of the new user.
+    #[schema(nullable = false)]
+    pub(crate) description: Option<String>,
+}
+
+/// Register an new User
+#[utoipa::path(
+    responses(
+        (
+            status = OK,
+            description = "User successfully registered in database",
+            body = UserId,
+        ),
+        (
+            status = UNAUTHORIZED,
+            description = "You did not login before calling this endpoint",
+        ),
+        (
+            status = INTERNAL_SERVER_ERROR,
+            description = "Server encountered error",
+            body = String,
+        )
+    ),
+    request_body = UserStub,
+)]
+#[post("/user/new")]
+pub(crate) async fn register_user(
+    app: web::Data<App>,
+    new_user: web::Json<UserStub>,
+    _user: Identity,
+) -> Result<impl Responder> {
+    let user = new_user.into_inner();
+
+    let mut ops = Operations::new("register user");
+
+    let password_hash = PasswordHash::from_password(&user.password);
+    let user = User::register(user.name, password_hash, user.description, &mut ops);
+
+    ops.apply(&app).await?;
+
+    Ok(HttpResponse::Ok().json(user.id))
+}