//! This module provides the functionality to handle different routes of the `websurfx` //! meta search engine website and provide appropriate response to each route/page //! when requested. use crate::{ config::parser::Config, handler::{file_path, FileType}, }; use actix_web::{get, web, HttpRequest, HttpResponse}; use std::fs::read_to_string; /// Handles the route of index page or main page of the `websurfx` meta search engine website. #[get("/")] pub async fn index(config: web::Data) -> Result> { Ok(HttpResponse::Ok().body( crate::templates::views::index::index(&config.style.colorscheme, &config.style.theme).0, )) } /// Handles the route of any other accessed route/page which is not provided by the /// website essentially the 404 error page. pub async fn not_found( config: web::Data, ) -> Result> { Ok(HttpResponse::Ok() .content_type("text/html; charset=utf-8") .body( crate::templates::views::not_found::not_found( &config.style.colorscheme, &config.style.theme, ) .0, )) } /// Handles the route of robots.txt page of the `websurfx` meta search engine website. #[get("/robots.txt")] pub async fn robots_data(_req: HttpRequest) -> Result> { let page_content: String = read_to_string(format!("{}/robots.txt", file_path(FileType::Theme)?))?; Ok(HttpResponse::Ok() .content_type("text/plain; charset=ascii") .body(page_content)) } /// Handles the route of about page of the `websurfx` meta search engine website. #[get("/about")] pub async fn about(config: web::Data) -> Result> { Ok(HttpResponse::Ok().body( crate::templates::views::about::about(&config.style.colorscheme, &config.style.theme).0, )) } /// Handles the route of settings page of the `websurfx` meta search engine website. #[get("/settings")] pub async fn settings( config: web::Data, ) -> Result> { Ok(HttpResponse::Ok().body( crate::templates::views::settings::settings( &config.style.colorscheme, &config.style.theme, &config .upstream_search_engines .keys() .collect::>(), )? .0, )) }