use actix_web::{web::Data, HttpRequest};
use awc::cookie::Cookie;
use crate::db::AppData;
pub struct BaseTemplate {
pub auth_state: bool,
pub guppy: String,
pub bundlrs: String,
pub body_embed: String,
}
pub fn get_base_values(token_cookie: bool) -> BaseTemplate {
let body_embed_req = std::env::var("BODY_EMBED");
let body_embed = if body_embed_req.is_ok() {
body_embed_req.unwrap()
} else {
String::new()
};
BaseTemplate {
auth_state: token_cookie,
guppy: std::env::var("GUPPY_ROOT").unwrap(),
bundlrs: std::env::var("BUNDLRS_ROOT").unwrap(),
body_embed,
}
}
pub async fn check_auth_status(
req: HttpRequest,
data: Data<AppData>,
) -> (
String,
Option<actix_web::cookie::Cookie<'static>>,
Option<dorsal::DefaultReturn<Option<dorsal::db::special::auth_db::FullUser<String>>>>,
) {
let token_cookie = req.cookie("__Secure-Token");
let mut set_cookie: &str = "";
let mut token_user: Option<
dorsal::DefaultReturn<Option<dorsal::db::special::auth_db::FullUser<String>>>,
> = if token_cookie.is_some() {
Option::Some(
data.db
.auth
.get_user_by_unhashed(token_cookie.as_ref().unwrap().value().to_string()) .await,
)
} else {
Option::None
};
if token_user.is_some() {
if token_user.as_ref().unwrap().success == false {
set_cookie = "__Secure-Token=refresh; SameSite=Strict; Secure; Path=/; HostOnly=true; HttpOnly=true; Max-Age=0";
token_user = Option::None;
}
}
(set_cookie.to_string(), token_cookie, token_user)
}
pub async fn check_auth_status_with_cookie(
token_cookie: Option<Cookie<'static>>,
data: Data<AppData>,
) -> (
String,
Option<actix_web::cookie::Cookie<'static>>,
Option<dorsal::DefaultReturn<Option<dorsal::db::special::auth_db::FullUser<String>>>>,
) {
let mut set_cookie: &str = "";
let mut token_user: Option<
dorsal::DefaultReturn<Option<dorsal::db::special::auth_db::FullUser<String>>>,
> = if token_cookie.is_some() {
Option::Some(
data.db
.auth
.get_user_by_unhashed(token_cookie.as_ref().unwrap().value().to_string()) .await,
)
} else {
Option::None
};
if token_user.is_some() {
if token_user.as_ref().unwrap().success == false {
set_cookie = "__Secure-Token=refresh; SameSite=Strict; Secure; Path=/; HostOnly=true; HttpOnly=true; Max-Age=0";
token_user = Option::None;
}
}
(set_cookie.to_string(), token_cookie, token_user)
}