tsk-61: Registration configuration #73
| @@ -10,3 +10,4 @@ POSTGRES_AUTH_PASSWORD=password | |||||||
| POSTGRES_AUTH_DB=icarus_auth_db | POSTGRES_AUTH_DB=icarus_auth_db | ||||||
| POSTGRES_AUTH_HOST=auth_db | POSTGRES_AUTH_HOST=auth_db | ||||||
| DATABASE_URL=postgresql://${POSTGRES_AUTH_USER}:${POSTGRES_AUTH_PASSWORD}@${POSTGRES_AUTH_HOST}:5432/${POSTGRES_AUTH_DB} | DATABASE_URL=postgresql://${POSTGRES_AUTH_USER}:${POSTGRES_AUTH_PASSWORD}@${POSTGRES_AUTH_HOST}:5432/${POSTGRES_AUTH_DB} | ||||||
|  | ENABLE_REGISTRATION=TRUE | ||||||
|   | |||||||
| @@ -10,3 +10,4 @@ POSTGRES_AUTH_PASSWORD=password | |||||||
| POSTGRES_AUTH_DB=icarus_auth_test_db | POSTGRES_AUTH_DB=icarus_auth_test_db | ||||||
| POSTGRES_AUTH_HOST=localhost | POSTGRES_AUTH_HOST=localhost | ||||||
| DATABASE_URL=postgresql://${POSTGRES_AUTH_USER}:${POSTGRES_AUTH_PASSWORD}@${POSTGRES_AUTH_HOST}:5432/${POSTGRES_AUTH_DB} | DATABASE_URL=postgresql://${POSTGRES_AUTH_USER}:${POSTGRES_AUTH_PASSWORD}@${POSTGRES_AUTH_HOST}:5432/${POSTGRES_AUTH_DB} | ||||||
|  | ENABLE_REGISTRATION=TRUE | ||||||
| @@ -76,6 +76,7 @@ jobs: | |||||||
|           SECRET_KEY: ${{ secrets.TOKEN_SECRET_KEY }} |           SECRET_KEY: ${{ secrets.TOKEN_SECRET_KEY }} | ||||||
|           # Make SSH agent available if tests fetch private dependencies |           # Make SSH agent available if tests fetch private dependencies | ||||||
|           SSH_AUTH_SOCK: ${{ env.SSH_AUTH_SOCK }} |           SSH_AUTH_SOCK: ${{ env.SSH_AUTH_SOCK }} | ||||||
|  |           ENABLE_REGISTRATION: 'TRUE' | ||||||
|         run: | |         run: | | ||||||
|           mkdir -p ~/.ssh |           mkdir -p ~/.ssh | ||||||
|           echo "${{ secrets.MYREPO_TOKEN }}" > ~/.ssh/icarus_models_deploy_key |           echo "${{ secrets.MYREPO_TOKEN }}" > ~/.ssh/icarus_models_deploy_key | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										2
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							| @@ -748,7 +748,7 @@ dependencies = [ | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "icarus_auth" | name = "icarus_auth" | ||||||
| version = "0.6.2" | version = "0.6.3" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "argon2", |  "argon2", | ||||||
|  "axum", |  "axum", | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| [package] | [package] | ||||||
| name = "icarus_auth" | name = "icarus_auth" | ||||||
| version = "0.6.2" | version = "0.6.3" | ||||||
| edition = "2024" | edition = "2024" | ||||||
| rust-version = "1.90" | rust-version = "1.90" | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										12
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								README.md
									
									
									
									
									
								
							| @@ -8,22 +8,26 @@ need to be modified. The `SECRET_KEY` variable should be changed since it will b | |||||||
| generation. The `SECRET_PASSPHASE` should also be changed when in production mode, but make sure | generation. The `SECRET_PASSPHASE` should also be changed when in production mode, but make sure | ||||||
| the respective `passphrase` database table record exists. | the respective `passphrase` database table record exists. | ||||||
|  |  | ||||||
| Build image | To enable or disable registrations, use `TRUE` or `FALSE` for the `ENABLE_REGISTRATION` variable. | ||||||
|  | By default it is `TRUE`. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | ### Build image | ||||||
| ``` | ``` | ||||||
| docker compose build | docker compose build | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| Start images | ### Start images | ||||||
| ``` | ``` | ||||||
| docker compose up -d --force-recreate | docker compose up -d --force-recreate | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| Bring it down | ### Bring it down | ||||||
| ``` | ``` | ||||||
| docker compose down -v | docker compose down -v | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| Pruning | ### Pruning | ||||||
| ``` | ``` | ||||||
| docker system prune -a | docker system prune -a | ||||||
| ``` | ``` | ||||||
|   | |||||||
| @@ -52,67 +52,108 @@ pub async fn register_user( | |||||||
|     axum::Extension(pool): axum::Extension<sqlx::PgPool>, |     axum::Extension(pool): axum::Extension<sqlx::PgPool>, | ||||||
|     Json(payload): Json<request::Request>, |     Json(payload): Json<request::Request>, | ||||||
| ) -> (StatusCode, Json<response::Response>) { | ) -> (StatusCode, Json<response::Response>) { | ||||||
|     let mut user = icarus_models::user::User { |     let registration_enabled = match is_registration_enabled().await { | ||||||
|         username: payload.username.clone(), |         Ok(value) => value, | ||||||
|         password: payload.password.clone(), |         Err(err) => { | ||||||
|         email: payload.email.clone(), |             eprintln!("Error: {err:?}"); | ||||||
|         phone: payload.phone.clone(), |             return ( | ||||||
|         firstname: payload.firstname.clone(), |                 axum::http::StatusCode::INTERNAL_SERVER_ERROR, | ||||||
|         lastname: payload.lastname.clone(), |                 Json(response::Response { | ||||||
|         status: String::from("Active"), |                     message: String::from("Registration check failed"), | ||||||
|         email_verified: true, |                     data: Vec::new(), | ||||||
|         ..Default::default() |                 }), | ||||||
|  |             ); | ||||||
|  |         } | ||||||
|     }; |     }; | ||||||
|  |  | ||||||
|     match repo::user::exists(&pool, &user.username).await { |     if registration_enabled { | ||||||
|         Ok(res) => { |         let mut user = icarus_models::user::User { | ||||||
|             if res { |             username: payload.username.clone(), | ||||||
|                 ( |             password: payload.password.clone(), | ||||||
|                     StatusCode::BAD_REQUEST, |             email: payload.email.clone(), | ||||||
|                     Json(response::Response { |             phone: payload.phone.clone(), | ||||||
|                         message: String::from("Error"), |             firstname: payload.firstname.clone(), | ||||||
|                         data: Vec::new(), |             lastname: payload.lastname.clone(), | ||||||
|                     }), |             status: String::from("Active"), | ||||||
|                 ) |             email_verified: true, | ||||||
|             } else { |             ..Default::default() | ||||||
|                 let salt_string = hashing::generate_salt().unwrap(); |         }; | ||||||
|                 let mut salt = icarus_models::user::salt::Salt::default(); |  | ||||||
|                 let generated_salt = salt_string; |  | ||||||
|                 salt.salt = generated_salt.to_string(); |  | ||||||
|                 salt.id = repo::salt::insert(&pool, &salt).await.unwrap(); |  | ||||||
|                 user.salt_id = salt.id; |  | ||||||
|                 let hashed_password = |  | ||||||
|                     hashing::hash_password(&user.password, &generated_salt).unwrap(); |  | ||||||
|                 user.password = hashed_password; |  | ||||||
|  |  | ||||||
|                 match repo::user::insert(&pool, &user).await { |         match repo::user::exists(&pool, &user.username).await { | ||||||
|                     Ok((id, date_created)) => { |             Ok(res) => { | ||||||
|                         user.id = id; |                 if res { | ||||||
|                         user.date_created = date_created; |                     ( | ||||||
|                         ( |  | ||||||
|                             StatusCode::CREATED, |  | ||||||
|                             Json(response::Response { |  | ||||||
|                                 message: String::from("User created"), |  | ||||||
|                                 data: vec![user], |  | ||||||
|                             }), |  | ||||||
|                         ) |  | ||||||
|                     } |  | ||||||
|                     Err(err) => ( |  | ||||||
|                         StatusCode::BAD_REQUEST, |                         StatusCode::BAD_REQUEST, | ||||||
|                         Json(response::Response { |                         Json(response::Response { | ||||||
|                             message: err.to_string(), |                             message: String::from("Error"), | ||||||
|                             data: vec![user], |                             data: Vec::new(), | ||||||
|                         }), |                         }), | ||||||
|                     ), |                     ) | ||||||
|  |                 } else { | ||||||
|  |                     let salt_string = hashing::generate_salt().unwrap(); | ||||||
|  |                     let mut salt = icarus_models::user::salt::Salt::default(); | ||||||
|  |                     let generated_salt = salt_string; | ||||||
|  |                     salt.salt = generated_salt.to_string(); | ||||||
|  |                     salt.id = repo::salt::insert(&pool, &salt).await.unwrap(); | ||||||
|  |                     user.salt_id = salt.id; | ||||||
|  |                     let hashed_password = | ||||||
|  |                         hashing::hash_password(&user.password, &generated_salt).unwrap(); | ||||||
|  |                     user.password = hashed_password; | ||||||
|  |  | ||||||
|  |                     match repo::user::insert(&pool, &user).await { | ||||||
|  |                         Ok((id, date_created)) => { | ||||||
|  |                             user.id = id; | ||||||
|  |                             user.date_created = date_created; | ||||||
|  |                             ( | ||||||
|  |                                 StatusCode::CREATED, | ||||||
|  |                                 Json(response::Response { | ||||||
|  |                                     message: String::from("User created"), | ||||||
|  |                                     data: vec![user], | ||||||
|  |                                 }), | ||||||
|  |                             ) | ||||||
|  |                         } | ||||||
|  |                         Err(err) => ( | ||||||
|  |                             StatusCode::BAD_REQUEST, | ||||||
|  |                             Json(response::Response { | ||||||
|  |                                 message: err.to_string(), | ||||||
|  |                                 data: vec![user], | ||||||
|  |                             }), | ||||||
|  |                         ), | ||||||
|  |                     } | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|  |             Err(err) => ( | ||||||
|  |                 StatusCode::BAD_REQUEST, | ||||||
|  |                 Json(response::Response { | ||||||
|  |                     message: err.to_string(), | ||||||
|  |                     data: vec![user], | ||||||
|  |                 }), | ||||||
|  |             ), | ||||||
|         } |         } | ||||||
|         Err(err) => ( |     } else { | ||||||
|             StatusCode::BAD_REQUEST, |         ( | ||||||
|  |             axum::http::StatusCode::NOT_ACCEPTABLE, | ||||||
|             Json(response::Response { |             Json(response::Response { | ||||||
|                 message: err.to_string(), |                 message: String::from("Registration is not enabled"), | ||||||
|                 data: vec![user], |                 data: Vec::new(), | ||||||
|             }), |             }), | ||||||
|         ), |         ) | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /// Checks to see if registration is enabled | ||||||
|  | async fn is_registration_enabled() -> Result<bool, std::io::Error> { | ||||||
|  |     let key = String::from("ENABLE_REGISTRATION"); | ||||||
|  |     let var = icarus_envy::environment::get_env(&key).await; | ||||||
|  |     let parsed_value = var.value.to_uppercase(); | ||||||
|  |  | ||||||
|  |     if parsed_value == "TRUE" { | ||||||
|  |         Ok(true) | ||||||
|  |     } else if parsed_value == "FALSE" { | ||||||
|  |         Ok(false) | ||||||
|  |     } else { | ||||||
|  |         Err(std::io::Error::other( | ||||||
|  |             "Could not determine value of ENABLE_REGISTRATION", | ||||||
|  |         )) | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user