rename modules for users

This commit is contained in:
Joe Ardent 2023-05-28 13:31:45 -07:00
parent 41a7abbe13
commit e5d66769dc
4 changed files with 15 additions and 15 deletions

View File

@ -4,5 +4,5 @@ extern crate justerror;
pub mod db; pub mod db;
pub mod generic_handlers; pub mod generic_handlers;
pub mod session_store; pub mod session_store;
pub mod signup;
pub(crate) mod templates; pub(crate) mod templates;
pub mod users;

0
src/login.rs Normal file
View File

View File

@ -8,7 +8,7 @@ use witch_watch::{
db, db,
generic_handlers::{handle_slash, handle_slash_redir}, generic_handlers::{handle_slash, handle_slash_redir},
session_store::SqliteSessionStore, session_store::SqliteSessionStore,
users::{get_create_user, get_login, handle_signup_success, post_create_user, post_login}, signup::{get_create_user, get_login, handle_signup_success, post_create_user, post_login},
}; };
#[tokio::main] #[tokio::main]

View File

@ -20,7 +20,6 @@ use crate::templates::{CreateUser, LoginGet};
const CREATE_QUERY: &str = const CREATE_QUERY: &str =
"insert into witches (id, username, displayname, email, pwhash) values ($1, $2, $3, $4, $5)"; "insert into witches (id, username, displayname, email, pwhash) values ($1, $2, $3, $4, $5)";
const ID_QUERY: &str = "select * from witches where id = $1"; const ID_QUERY: &str = "select * from witches where id = $1";
// const PW_QUERY: &str = "select pwhash from witches where id = $1";
#[derive(Debug, Default, Clone, PartialEq, Eq, sqlx::FromRow)] #[derive(Debug, Default, Clone, PartialEq, Eq, sqlx::FromRow)]
pub struct User { pub struct User {
@ -57,9 +56,9 @@ impl AuthUser<Uuid> for User {
} }
} }
//-------------------------------------------------------------------------- //-************************************************************************
// Result types for user creation // Result types for user creation
//-------------------------------------------------------------------------- //-************************************************************************
#[derive(Debug, Clone, Template)] #[derive(Debug, Clone, Template)]
#[template(path = "signup_success.html")] #[template(path = "signup_success.html")]
@ -96,9 +95,9 @@ pub enum CreateUserErrorKind {
UnknownDBError, UnknownDBError,
} }
//-------------------------------------------------------------------------- //-************************************************************************
// User creation route handlers // User creation route handlers
//-------------------------------------------------------------------------- //-************************************************************************
/// Get Handler: displays the form to create a user /// Get Handler: displays the form to create a user
pub async fn get_create_user() -> CreateUser { pub async fn get_create_user() -> CreateUser {
@ -174,13 +173,13 @@ pub async fn post_create_user(
Ok(resp) Ok(resp)
} }
/// Get handler for successful signup /// Generic handler for successful signup
pub async fn handle_signup_success( pub async fn handle_signup_success(
Path(id): Path<String>, Path(id): Path<String>,
State(pool): State<SqlitePool>, State(pool): State<SqlitePool>,
) -> Response { ) -> Response {
let user: User = {
let id = id.trim(); let id = id.trim();
let user: User = {
let id = Uuid::try_parse(id).unwrap_or_default(); let id = Uuid::try_parse(id).unwrap_or_default();
query_as(ID_QUERY) query_as(ID_QUERY)
.bind(id) .bind(id)
@ -196,12 +195,13 @@ pub async fn handle_signup_success(
*resp.status_mut() = StatusCode::TEMPORARY_REDIRECT; *resp.status_mut() = StatusCode::TEMPORARY_REDIRECT;
resp.headers_mut().insert("Location", "/".parse().unwrap()); resp.headers_mut().insert("Location", "/".parse().unwrap());
} }
resp resp
} }
//-------------------------------------------------------------------------- //-************************************************************************
// Login error and success types // Login error and success types
//-------------------------------------------------------------------------- //-************************************************************************
#[Error] #[Error]
pub struct LoginError(#[from] LoginErrorKind); pub struct LoginError(#[from] LoginErrorKind);
@ -226,9 +226,9 @@ impl IntoResponse for LoginError {
} }
} }
//-------------------------------------------------------------------------- //-************************************************************************
// Login handlers // Login handlers
//-------------------------------------------------------------------------- //-************************************************************************
/// Handle login queries /// Handle login queries
#[axum::debug_handler] #[axum::debug_handler]
@ -243,9 +243,9 @@ pub async fn get_login() -> impl IntoResponse {
LoginGet::default() LoginGet::default()
} }
//------------------------------------------------------------------------- //-************************************************************************
// private fns // private fns
//------------------------------------------------------------------------- //-************************************************************************
async fn create_user( async fn create_user(
username: &str, username: &str,