libreddit/src/search.rs

45 lines
1.1 KiB
Rust
Raw Normal View History

2021-01-01 00:54:13 +01:00
// CRATES
2021-01-01 06:03:44 +01:00
use crate::utils::{error, fetch_posts, param, Post};
use actix_web::{HttpRequest, HttpResponse, Result};
2021-01-01 00:54:13 +01:00
use askama::Template;
// STRUCTS
#[derive(Template)]
#[allow(dead_code)]
#[template(path = "search.html", escape = "none")]
struct SearchTemplate {
posts: Vec<Post>,
query: String,
sub: String,
sort: (String, String),
ends: (String, String),
}
// SERVICES
2021-01-01 06:03:44 +01:00
pub async fn find(req: HttpRequest) -> Result<HttpResponse> {
2021-01-01 00:54:13 +01:00
let path = format!("{}.json?{}", req.path(), req.query_string());
2021-01-01 21:33:57 +01:00
let q = param(&path, "q");
let sort = if param(&path, "sort").is_empty() {
2021-01-01 00:54:13 +01:00
"relevance".to_string()
} else {
2021-01-01 21:33:57 +01:00
param(&path, "sort")
2021-01-01 00:54:13 +01:00
};
let sub = req.match_info().get("sub").unwrap_or("").to_string();
2021-01-02 00:28:13 +01:00
match fetch_posts(&path, String::new()).await {
Ok(posts) => {
let s = SearchTemplate {
posts: posts.0,
query: q,
sub,
sort: (sort, param(&path, "t")),
ends: (param(&path, "after"), posts.1),
}
.render()
.unwrap();
Ok(HttpResponse::Ok().content_type("text/html").body(s))
2021-01-02 07:21:43 +01:00
}
Err(msg) => error(msg.to_string()).await,
2021-01-01 00:54:13 +01:00
}
}