use crate::routes::Artist; use crate::AppState; use actix_web::{get, web, HttpResponse}; use serde::Deserialize; #[derive(Deserialize)] struct ArtistQueryOptions { id: Option, name: Option, } #[get("/artist")] pub async fn artist( app_state: web::Data, get_args: web::Query, ) -> HttpResponse { let search_attempt: sqlx::Result>; match true { _ if check_if_exists(&get_args.id) => { search_attempt = sqlx::query_as!( Artist, "SELECT name, id FROM artist WHERE id=?", &get_args.id, ) .fetch_all(&app_state.pool) .await; } _ if check_if_exists(&get_args.name) => { let new_name : String = format!("{}{}{}", "%", &get_args.name.clone().unwrap(), "%"); search_attempt = sqlx::query_as!( Artist, "SELECT name, id FROM artist WHERE LOWER(name) LIKE LOWER(?)", new_name, ) .fetch_all(&app_state.pool) .await; } _ => { search_attempt = sqlx::query_as!( Artist, "SELECT name, id FROM artist ", ) .fetch_all(&app_state.pool) .await; } }; match search_attempt { Ok(artist_list) => HttpResponse::Ok().json(artist_list), Err(e) => HttpResponse::Ok().body(format!("{}", e)), } } fn check_if_exists(value: &Option) -> bool { match value { Some(_) => true, None => false, } }