achubb_website/src/html/root.rs

167 lines
4.6 KiB
Rust
Raw Normal View History

2024-12-18 07:26:21 -05:00
use std:: sync::{Arc, Mutex};
2024-04-28 11:02:16 -04:00
use axum::{
2024-12-18 07:26:21 -05:00
http::{Response, StatusCode},
2024-04-28 11:02:16 -04:00
response::{IntoResponse, Redirect},
2024-12-18 07:26:21 -05:00
routing::{get, post, Router},
Extension,
2024-04-28 11:02:16 -04:00
};
2024-12-18 07:26:21 -05:00
use rand::{seq::SliceRandom, thread_rng, RngCore, SeedableRng};
use rand_chacha::ChaCha8Rng;
use rand_core::OsRng;
use sqlx::PgPool;
use std::error::Error;
2024-03-24 10:45:16 -04:00
use tower_http::services::ServeDir;
2024-12-18 07:26:21 -05:00
use crate::{
auth::{auth, logout_response, post_login, post_signup},
database::{
link::{Link, LinkType},
PsqlData,
},
};
use super::{
2024-12-18 07:26:21 -05:00
admin, blog::{self, get_articles_date_sorted}, garden, templates::{
AboutTemplate, AiTemplate, BlogrollTemplate, ContactTemplate, GiftsTemplate, HomeTemplate, HtmlTemplate, InterestsTemplate, LinksPageTemplate, LoginTemplate, NowTemplate, ResumeTemplate, SignupTemplate, UsesTemplate, WorkTemplate
}
};
pub fn get_router(pool: PgPool) -> Router {
2024-03-24 10:45:16 -04:00
let assets_path = std::env::current_dir().unwrap();
2024-12-18 07:26:21 -05:00
let random = ChaCha8Rng::seed_from_u64(OsRng.next_u64());
let middleware_database = pool.clone();
2024-03-24 10:45:16 -04:00
Router::new()
.nest("/blog", blog::get_router())
.nest("/garden", garden::get_router())
2024-12-18 07:26:21 -05:00
.nest("/admin", admin::get_router())
.nest_service(
"/assets",
ServeDir::new(format!("{}/assets", assets_path.to_str().unwrap())),
)
2024-03-24 10:45:16 -04:00
.route("/", get(home))
.route("/now", get(now))
.route("/about", get(about))
.route("/contact", get(contact))
2024-07-05 20:00:43 -04:00
.route("/uses", get(uses))
2024-08-09 16:22:14 -04:00
.route("/ai", get(ai))
2024-08-09 21:42:46 -04:00
.route("/blogroll", get(blogroll))
.route("/links", get(links))
.route("/interests", get(interests))
.route("/resume", get(resume))
.route("/gifts", get(gifts))
.route("/hire", get(work))
2024-12-18 07:26:21 -05:00
.route("/login", get(get_login).post(post_login))
.route("/signup", get(get_signup).post(post_signup))
.route("/logout", post(logout_response))
2024-04-28 11:02:16 -04:00
.route(
"/robots.txt",
get(|| async { Redirect::permanent("/assets/robots.txt") }),
)
2024-12-18 07:26:21 -05:00
.layer(axum::middleware::from_fn(move |req, next| {
auth(req, next, middleware_database.clone())
}))
.layer(Extension(pool))
2024-12-18 07:26:21 -05:00
.layer(Extension(Arc::new(Mutex::new(random))))
2024-03-24 10:45:16 -04:00
}
async fn home(Extension(pool): Extension<PgPool>) -> impl IntoResponse {
let mut articles = get_articles_date_sorted(&pool).await.unwrap();
articles.truncate(5);
HtmlTemplate(HomeTemplate {
recent_articles: articles,
})
}
2024-03-24 10:45:16 -04:00
async fn now() -> impl IntoResponse {
HtmlTemplate(NowTemplate {})
2024-03-24 10:45:16 -04:00
}
async fn about() -> impl IntoResponse {
HtmlTemplate(AboutTemplate {})
2024-03-24 10:45:16 -04:00
}
async fn contact() -> impl IntoResponse {
HtmlTemplate(ContactTemplate {})
2024-03-24 10:45:16 -04:00
}
async fn uses() -> impl IntoResponse {
HtmlTemplate(UsesTemplate {})
2024-07-05 20:00:43 -04:00
}
2024-08-09 16:22:14 -04:00
async fn ai() -> impl IntoResponse {
HtmlTemplate(AiTemplate {})
2024-08-09 16:22:14 -04:00
}
2024-08-09 21:42:46 -04:00
async fn interests() -> impl IntoResponse {
HtmlTemplate(InterestsTemplate {})
}
async fn resume() -> impl IntoResponse {
HtmlTemplate(ResumeTemplate {})
}
async fn work() -> impl IntoResponse {
HtmlTemplate(WorkTemplate {})
}
async fn gifts() -> impl IntoResponse {
HtmlTemplate(GiftsTemplate {})
}
async fn blogroll(Extension(pool): Extension<PgPool>) -> impl IntoResponse {
let blogroll_page = BlogrollTemplate {
blogs: match get_links_as_list(&pool, LinkType::BLOG).await {
Ok(list) => list,
Err(_) => Vec::new(),
},
};
HtmlTemplate(blogroll_page)
2024-08-09 21:42:46 -04:00
}
async fn links(Extension(pool): Extension<PgPool>) -> impl IntoResponse {
let links_page = LinksPageTemplate {
articles: match get_links_as_list(&pool, LinkType::ARTICLE).await {
Ok(list) => list,
Err(_) => Vec::new(),
},
};
HtmlTemplate(links_page)
}
pub async fn get_links_as_list(
pool: &PgPool,
link_type: LinkType,
) -> Result<Vec<Link>, Box<dyn Error>> {
let mut links: Vec<Link> = match Link::read_all(pool).await {
Ok(a) => a.iter().map(|x| *x.clone()).collect(),
Err(_) => Vec::new(),
};
let mut rng = thread_rng();
links.shuffle(&mut rng);
let list: Vec<Link> = links
.into_iter()
.filter(|link| link.link_type == link_type)
.collect();
Ok(list)
}
2024-12-18 07:26:21 -05:00
pub fn error_page(err: &dyn std::error::Error) -> impl IntoResponse {
Response::builder()
.status(StatusCode::INTERNAL_SERVER_ERROR)
.body(format!("Err: {}", err))
.unwrap()
}
pub async fn get_login() -> impl IntoResponse {
HtmlTemplate(LoginTemplate { username: None })
}
pub async fn get_signup() -> impl IntoResponse {
HtmlTemplate(SignupTemplate {})
}