mylloon.fr/src/routes/agreements.rs

59 lines
1.5 KiB
Rust
Raw Normal View History

2023-04-09 19:02:06 +02:00
use crate::{config::Config, template::render};
2023-02-16 21:44:00 +01:00
use actix_web::{dev::ConnectionInfo, get, routes, web, HttpRequest, HttpResponse, Responder};
2023-04-09 19:02:06 +02:00
use ramhorns::Content;
2023-02-08 22:14:57 +01:00
#[routes]
#[get("/.well-known/security.txt")]
#[get("/security.txt")]
pub async fn security(req: HttpRequest, config: web::Data<Config>) -> impl Responder {
2023-02-16 21:44:00 +01:00
HttpResponse::Ok().body(get_security(
config.get_ref().clone(),
req.connection_info().to_owned(),
))
2023-02-08 22:14:57 +01:00
}
2023-04-09 19:02:06 +02:00
#[derive(Content)]
2023-02-08 22:14:57 +01:00
struct SecurityTemplate {
contact: String,
pref_lang: String,
url: String,
}
2023-02-16 21:44:00 +01:00
fn get_security(config: Config, info: ConnectionInfo) -> String {
2023-04-09 19:02:06 +02:00
render(
config.templates_location,
"security.txt",
SecurityTemplate {
contact: config.fc.mail.unwrap_or_default(),
pref_lang: config.fc.lang.unwrap_or_default(),
url: format!(
"{}://{}/.well-known/security.txt",
info.scheme(),
info.host()
),
},
)
2023-02-08 22:14:57 +01:00
}
2023-02-08 22:22:20 +01:00
#[get("/humans.txt")]
pub async fn humans() -> impl Responder {
2023-02-09 12:01:35 +01:00
// TODO, see https://humanstxt.org/humans.txt
2023-02-08 22:22:20 +01:00
actix_web::web::Redirect::to("/")
}
#[get("/robots.txt")]
pub async fn robots() -> impl Responder {
2023-02-09 12:01:35 +01:00
HttpResponse::Ok().body(get_robots())
}
fn get_robots() -> String {
// TODO, see https://www.robotstxt.org/orig.html
"User-agent: * Allow: /".to_string()
2023-02-08 22:22:20 +01:00
}
#[get("/sitemap.xml")]
pub async fn sitemap() -> impl Responder {
// TODO
actix_web::web::Redirect::to("/")
}