mirror of
https://github.com/neon-mmd/websurfx.git
synced 2024-11-23 06:28:23 -05:00
991f3f59de
* ♻️ refactor: initialize & store the config & cache structs as a constant (#486) - initializes & stores the config & cache structs as a static constant. - Pass the config & cache structs as a static reference to all the functions handling their respective route. * ⚡ perf: replace hashmaps with vectors for fetching & aggregating results (#486) - replace hashmaps with vectors for fetching, collecting & aggregating results as it tends to be contigous & cache efficient data structure. - refactor & redesign algorithms for fetching & aggregating results centered around vectors in aggregate function. * ➕ build: add the future crate (#486) * ⚡ perf: use `futureunordered` for collecting results fetched from the tokio spawn tasks (#486) - using the `futureunordered` instead of vector for collecting results reduces the time it takes to fetch the results as the results do not need to come in specific order so any result that gets fetched first gets collected in the `futureunordered` type. Co-authored-by: Spencerjibz <spencernajib2@gmail.com> * ⚡ perf: initialize new async connections parallely using tokio spawn tasks (#486) * ⚡ perf: initialize redis pipeline struct once with the default size of 3 (#486) * ⚡ perf: reduce branch predictions by reducing conditional code branches (#486) * ✅ test(unit): provide unit test for the `get_safesearch_level` function (#486) * ⚡ perf: reduce clones & use index based loop to improve search results filtering performance (#486) * 🚨 fix(clippy): make clippy/format checks happy (#486) * 🚨 fix(build): make the cargo build check happy (#486) * ⚡ perf: reduce the amount of clones, to_owneds & to_strings (#486) * ⚡ perf: use async crates & methods & make functions async (#486) * 🔖 chore(release): bump the app version (#486) --------- Co-authored-by: Spencerjibz <spencernajib2@gmail.com>
83 lines
2.8 KiB
Rust
83 lines
2.8 KiB
Rust
//! 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, http::header::ContentType, web, HttpRequest, HttpResponse};
|
|
use tokio::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<&'static Config>,
|
|
) -> Result<HttpResponse, Box<dyn std::error::Error>> {
|
|
Ok(HttpResponse::Ok().content_type(ContentType::html()).body(
|
|
crate::templates::views::index::index(
|
|
&config.style.colorscheme,
|
|
&config.style.theme,
|
|
&config.style.animation,
|
|
)
|
|
.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<&'static Config>,
|
|
) -> Result<HttpResponse, Box<dyn std::error::Error>> {
|
|
Ok(HttpResponse::Ok().content_type(ContentType::html()).body(
|
|
crate::templates::views::not_found::not_found(
|
|
&config.style.colorscheme,
|
|
&config.style.theme,
|
|
&config.style.animation,
|
|
)
|
|
.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<HttpResponse, Box<dyn std::error::Error>> {
|
|
let page_content: String =
|
|
read_to_string(format!("{}/robots.txt", file_path(FileType::Theme)?)).await?;
|
|
Ok(HttpResponse::Ok()
|
|
.content_type(ContentType::plaintext())
|
|
.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<&'static Config>,
|
|
) -> Result<HttpResponse, Box<dyn std::error::Error>> {
|
|
Ok(HttpResponse::Ok().content_type(ContentType::html()).body(
|
|
crate::templates::views::about::about(
|
|
&config.style.colorscheme,
|
|
&config.style.theme,
|
|
&config.style.animation,
|
|
)
|
|
.0,
|
|
))
|
|
}
|
|
|
|
/// Handles the route of settings page of the `websurfx` meta search engine website.
|
|
#[get("/settings")]
|
|
pub async fn settings(
|
|
config: web::Data<&'static Config>,
|
|
) -> Result<HttpResponse, Box<dyn std::error::Error>> {
|
|
Ok(HttpResponse::Ok().content_type(ContentType::html()).body(
|
|
crate::templates::views::settings::settings(
|
|
config.safe_search,
|
|
&config.style.colorscheme,
|
|
&config.style.theme,
|
|
&config.style.animation,
|
|
&config.upstream_search_engines,
|
|
)?
|
|
.0,
|
|
))
|
|
}
|