use crate::api::{get_response_from_query, Response}; use crate::database::{Artist, ArtistPost, ArtistPut, Delete}; use crate::AppState; use actix_web::{delete, get, post, put, web, HttpResponse}; use serde::Deserialize; /* Possible arguments ( /artist?arg=value ) */ #[derive(Deserialize)] struct ArtistQueryOptions { id: Option, name: Option, } #[get("/artist")] pub async fn get_artist( app_state: web::Data, get_args: web::Query, ) -> HttpResponse { /* Avoid lifespan issues */ let default = String::default(); /* Handle individual result for search-by-id */ if get_args.id.is_some() { let id: &str = get_args.id.as_ref().unwrap_or(&default); let query_result: sqlx::Result> = app_state.database.select_artist_by_id(id).await; return match query_result { Ok(song_list) => HttpResponse::Ok().json(song_list), Err(e) => HttpResponse::Ok().body(format!("{}", e)), }; } /* Handle N results */ let query_result: sqlx::Result, sqlx::Error> = match true { _ if get_args.name.is_some() => { let name: &str = &get_args.name.as_ref().unwrap_or(&default); app_state.database.select_artists_by_name(name).await } _ => app_state.database.select_artists().await, }; match query_result { Ok(artist_list) => HttpResponse::Ok().json(artist_list), Err(e) => HttpResponse::Ok().body(format!("{}", e)), } } #[post("/artist")] pub async fn post_artist( app_state: web::Data, request_data: web::Json, ) -> HttpResponse { get_response_from_query( app_state .database .create_artist(request_data.into_inner()) .await, "POST".to_string(), ) } #[put("/artist")] pub async fn put_artist( app_state: web::Data, request_data: web::Json, ) -> HttpResponse { get_response_from_query( app_state.database.edit_artist(request_data.into_inner()).await, "PUT".to_string(), ) } #[delete("/artist")] pub async fn delete_artist( app_state: web::Data, request_data: web::Json, ) -> HttpResponse { /* Check if ID is valid (return -1 if invalid) */ let id: i32 = request_data .into_inner() .id .unwrap_or(String::default()) .parse::() .unwrap_or(-1); if id == -1 { return HttpResponse::BadRequest().json(Response { message: "Invalid id value, code not executed\n".to_owned(), }); } get_response_from_query( app_state.database.delete_artist(id).await, "DELETE".to_string(), ) }