Compare commits

...

2 Commits

Author SHA1 Message Date
a22acb7c53 version bump
All checks were successful
Rust Build / Rustfmt (pull_request) Successful in 37s
Rust Build / Clippy (pull_request) Successful in 42s
Rust Build / Test Suite (pull_request) Successful in 47s
Rust Build / Check (pull_request) Successful in 41s
Rust Build / build (pull_request) Successful in 1m55s
2025-10-21 13:15:20 -04:00
2b824a268b Using file_type passed when getting the CoverArtQueue 2025-10-21 13:14:31 -04:00
4 changed files with 27 additions and 12 deletions

14
Cargo.lock generated
View File

@@ -498,10 +498,12 @@ dependencies = [
[[package]] [[package]]
name = "icarus_meta" name = "icarus_meta"
version = "0.4.0" version = "0.4.2"
source = "git+ssh://git@git.kundeng.us/phoenix/icarus_meta.git?tag=v0.4.0#f372d059155691c0bac52594fa0d14867078e461" source = "git+ssh://git@git.kundeng.us/phoenix/icarus_meta.git?tag=v0.4.2-main-71374eb731-680#71374eb73180966d11a7298df06fdc6e999c3c78"
dependencies = [ dependencies = [
"imghdr",
"lofty", "lofty",
"rand",
] ]
[[package]] [[package]]
@@ -625,6 +627,12 @@ dependencies = [
"icu_properties", "icu_properties",
] ]
[[package]]
name = "imghdr"
version = "0.7.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "c8b35f3ad95576ac81603375dfe47a0450b70a368aa34d2b6e5bb0a0d7f02428"
[[package]] [[package]]
name = "indexmap" name = "indexmap"
version = "2.12.0" version = "2.12.0"
@@ -1293,7 +1301,7 @@ dependencies = [
[[package]] [[package]]
name = "songparser" name = "songparser"
version = "0.4.3" version = "0.4.4"
dependencies = [ dependencies = [
"futures", "futures",
"icarus_envy", "icarus_envy",

View File

@@ -1,6 +1,6 @@
[package] [package]
name = "songparser" name = "songparser"
version = "0.4.3" version = "0.4.4"
edition = "2024" edition = "2024"
rust-version = "1.90" rust-version = "1.90"
@@ -13,6 +13,6 @@ serde_json = { version = "1.0.145" }
time = { version = "0.3.44", features = ["macros", "serde"] } time = { version = "0.3.44", features = ["macros", "serde"] }
uuid = { version = "1.18.1", features = ["v4", "serde"] } uuid = { version = "1.18.1", features = ["v4", "serde"] }
rand = { version = "0.9.2" } rand = { version = "0.9.2" }
icarus_meta = { git = "ssh://git@git.kundeng.us/phoenix/icarus_meta.git", tag = "v0.4.0" } icarus_meta = { git = "ssh://git@git.kundeng.us/phoenix/icarus_meta.git", tag = "v0.4.2-main-71374eb731-680" }
icarus_models = { git = "ssh://git@git.kundeng.us/phoenix/icarus_models.git", tag = "v0.8.0" } icarus_models = { git = "ssh://git@git.kundeng.us/phoenix/icarus_models.git", tag = "v0.8.0" }
icarus_envy = { git = "ssh://git@git.kundeng.us/phoenix/icarus_envy.git", tag = "v0.5.0" } icarus_envy = { git = "ssh://git@git.kundeng.us/phoenix/icarus_envy.git", tag = "v0.5.0" }

View File

@@ -158,6 +158,7 @@ pub mod get_coverart_queue {
#[derive(Debug, Deserialize, Serialize)] #[derive(Debug, Deserialize, Serialize)]
pub struct CoverArtQueue { pub struct CoverArtQueue {
pub id: uuid::Uuid, pub id: uuid::Uuid,
pub file_type: String,
pub song_queue_id: uuid::Uuid, pub song_queue_id: uuid::Uuid,
} }

View File

@@ -341,13 +341,14 @@ async fn prep_song(
Ok(response) => { Ok(response) => {
match response.json::<api::get_coverart_queue::response::Response>().await { match response.json::<api::get_coverart_queue::response::Response>().await {
Ok(response) => { Ok(response) => {
let coverart_queue_id = &response.data[0].id; let coverart_queue = &response.data[0];
let coverart_queue_id = coverart_queue.id;
println!("Coverart queue Id: {coverart_queue_id:?}"); println!("Coverart queue Id: {coverart_queue_id:?}");
match api::get_coverart_queue::get_data(app, coverart_queue_id).await { match api::get_coverart_queue::get_data(app, &coverart_queue_id).await {
Ok(response) => match api::parsing::parse_response_into_bytes(response).await { Ok(response) => match api::parsing::parse_response_into_bytes(response).await {
Ok(coverart_queue_bytes) => { Ok(coverart_queue_bytes) => {
let (directory, filename) = generate_coverart_queue_dir_and_filename().await; let (directory, filename) = generate_coverart_queue_dir_and_filename(&coverart_queue.file_type).await;
let coverart = icarus_models::coverart::CoverArt { let coverart = icarus_models::coverart::CoverArt {
directory, directory,
filename, filename,
@@ -367,7 +368,7 @@ async fn prep_song(
let coverart_queue_path = std::path::Path::new(&coverart_queue_fs_path); let coverart_queue_path = std::path::Path::new(&coverart_queue_fs_path);
println!("Saved coverart queue file at: {coverart_queue_path:?}"); println!("Saved coverart queue file at: {coverart_queue_path:?}");
Ok(((song.directory, song.filename), (coverart.directory, coverart.filename), metadata.clone(), *coverart_queue_id)) Ok(((song.directory, song.filename), (coverart.directory, coverart.filename), metadata.clone(), coverart_queue_id))
} }
Err(err) => { Err(err) => {
Err(err) Err(err)
@@ -413,7 +414,7 @@ pub async fn generate_song_queue_dir_and_filename() -> (String, String) {
} }
// TODO: Consider having something like this in icarus_models // TODO: Consider having something like this in icarus_models
pub async fn generate_coverart_queue_dir_and_filename() -> (String, String) { pub async fn generate_coverart_queue_dir_and_filename(file_type: &str) -> (String, String) {
use rand::Rng; use rand::Rng;
let mut filename: String = String::new(); let mut filename: String = String::new();
@@ -432,8 +433,13 @@ pub async fn generate_coverart_queue_dir_and_filename() -> (String, String) {
} }
} }
// TODO: Do not hard code the file extension filename += if file_type == "jpeg" || file_type == "jpg" {
filename += ".jpeg"; ".jpeg"
} else if file_type == "png" {
".png"
} else {
""
};
// TODO: Consider separating song and coverart when saving to the filesystem // TODO: Consider separating song and coverart when saving to the filesystem
let directory = icarus_envy::environment::get_root_directory().await.value; let directory = icarus_envy::environment::get_root_directory().await.value;