Add communication with user actor

This commit is contained in:
2022-03-30 12:41:22 +02:00
parent bfe4674f88
commit 6fdac7fbb1
6 changed files with 94 additions and 10 deletions

View File

@ -1,6 +1,9 @@
use actix_web::{HttpResponse, Responder};
use actix::Addr;
use actix_web::{HttpResponse, Responder, web};
use askama::Template;
use crate::actors::users_actor::{LoginResult, UsersActor};
use crate::actors::users_actor;
use crate::constants::APP_NAME;
#[derive(Template)]
@ -16,20 +19,42 @@ struct BaseLoginPage {
#[template(path = "login.html")]
struct LoginTemplate {
_parent: BaseLoginPage,
mail: String,
login: String,
}
#[derive(serde::Deserialize)]
pub struct LoginRequest {
login: String,
password: String,
}
/// Authenticate user
pub async fn login_route(users: web::Data<Addr<UsersActor>>,
req: Option<web::Form<LoginRequest>>) -> impl Responder {
let mut danger = String::new();
let mut login = String::new();
// Try to authenticate user
if let Some(req) = &req {
login = req.login.clone();
let response: LoginResult = users.send(users_actor::LoginRequest {
login: login.clone(),
password: req.password.clone(),
}).await.unwrap();
danger = format!("{:?}", response)
}
pub async fn login_route() -> impl Responder {
HttpResponse::Ok()
.content_type("text/html")
.body(LoginTemplate {
_parent: BaseLoginPage {
page_title: "Login",
danger: "".to_string(),
danger,
success: "".to_string(),
app_name: APP_NAME,
},
mail: "".to_string()
login,
}.render().unwrap())
}