fixed /users/create and /users/auth

This commit is contained in:
Martin Brodbeck 2023-09-26 12:40:52 +02:00
parent 0e96cb1bda
commit 41ece3063c

View file

@ -36,7 +36,7 @@ async fn root() -> &'static str {
"KOreader sync server"
}
async fn create_user(Json(payload): Json<User>) -> (StatusCode, String) {
async fn create_user(Json(payload): Json<User>) -> StatusCode {
let client = redis::Client::open("redis://127.0.0.1/").unwrap();
let mut con = client.get_connection().unwrap();
@ -50,26 +50,21 @@ async fn create_user(Json(payload): Json<User>) -> (StatusCode, String) {
if does_exist == false {
let _: () = con.set(&user_key, password).unwrap();
} else {
return (
StatusCode::PAYMENT_REQUIRED,
"Username is already registered.".to_owned(),
);
return StatusCode::PAYMENT_REQUIRED;
}
(StatusCode::CREATED, format!("username = {username}"))
StatusCode::CREATED
}
async fn auth_user(headers: HeaderMap) -> (StatusCode, String) {
async fn auth_user(headers: HeaderMap) -> StatusCode {
let client = redis::Client::open("redis://127.0.0.1/").unwrap();
let mut con = client.get_connection().unwrap();
let username = headers["x-auth-user"].to_str().unwrap_or("");
let password = headers["x-auth-key"].to_str().unwrap_or("");
println!("AHA");
if username.is_empty() || password.is_empty() {
return (StatusCode::UNAUTHORIZED, "Unauthorized".to_owned());
return StatusCode::UNAUTHORIZED;
}
let user_key = format!("user:{username}:key");
@ -77,10 +72,10 @@ async fn auth_user(headers: HeaderMap) -> (StatusCode, String) {
let redis_pw: String = con.get(&user_key).unwrap();
if password != redis_pw {
return (StatusCode::UNAUTHORIZED, "Unauthorized".to_owned());
return StatusCode::UNAUTHORIZED;
}
(StatusCode::OK, "authorized = 'OK'".to_owned())
StatusCode::OK
}
async fn update_progress() {}