From cb3a9e58dbfa65da655c68e21d5bf270c4ccb7ef Mon Sep 17 00:00:00 2001 From: niliara-edu Date: Mon, 20 Jan 2025 01:32:52 +0100 Subject: add searchResults --- src/routes/search_results.rs | 55 ++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 55 insertions(+) create mode 100644 src/routes/search_results.rs (limited to 'src/routes/search_results.rs') diff --git a/src/routes/search_results.rs b/src/routes/search_results.rs new file mode 100644 index 0000000..03bd079 --- /dev/null +++ b/src/routes/search_results.rs @@ -0,0 +1,55 @@ +use crate::database::{Album, Artist, Song}; +use crate::AppState; +use actix_web::{get, web, HttpResponse}; +use serde::Deserialize; + +#[derive(Deserialize)] +struct SearchQueryOptions { + id: Option, + name: Option, +} + +#[get("/searchResults")] +pub async fn search_results( + app_state: web::Data, + get_args: web::Query, +) -> HttpResponse { + let search_attempt: ( + sqlx::Result, sqlx::Error>, + sqlx::Result, sqlx::Error>, + sqlx::Result, sqlx::Error>, + ) = match true { + _ if check_if_exists(&get_args.id) => { + app_state + .database + .search_results_by_id(&get_args.id.clone().unwrap()) + .await + } + _ if check_if_exists(&get_args.name) => { + app_state + .database + .search_results_by_name(&get_args.name.clone().unwrap()) + .await + } + _ => app_state + .database + .search_results() + .await + // Err(sqlx::Error::RowNotFound), + // Err(sqlx::Error::RowNotFound), + // Err(sqlx::Error::RowNotFound), + }; + + return HttpResponse::Ok().json(( + search_attempt.0.unwrap_or_else(|_| return Vec::new()), + search_attempt.1.unwrap_or_else(|_| return Vec::new()), + search_attempt.2.unwrap_or_else(|_| return Vec::new()) + )) +} + +fn check_if_exists(value: &Option) -> bool { + match value { + Some(_) => true, + None => false, + } +} -- cgit v1.2.3