summaryrefslogtreecommitdiff
path: root/src/routes/search_results.rs
blob: 03bd079de2485fd672bc68c036937f5d24af1e1a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
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<String>,
    name: Option<String>,
}

#[get("/searchResults")]
pub async fn search_results(
    app_state: web::Data<AppState>,
    get_args: web::Query<SearchQueryOptions>,
) -> HttpResponse {
    let search_attempt: (
        sqlx::Result<Vec<Artist>, sqlx::Error>,
        sqlx::Result<Vec<Album>, sqlx::Error>,
        sqlx::Result<Vec<Song>, 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<String>) -> bool {
    match value {
        Some(_) => true,
        None => false,
    }
}