Compare commits
	
		
			3 Commits
		
	
	
		
			v0.7.2-77-
			...
			1e51cc0c5f
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 1e51cc0c5f | |||
| ebe74868fa | |||
| 4a4e3593a7 | 
| @@ -4,21 +4,20 @@ on: | |||||||
|   pull_request: |   pull_request: | ||||||
|     branches: |     branches: | ||||||
|       - main |       - main | ||||||
|       - next-v0.8 |  | ||||||
|  |  | ||||||
| jobs: | jobs: | ||||||
|   release: |   release: | ||||||
|     runs-on: ubuntu-24.04 |     runs-on: ubuntu-24.04 | ||||||
|     steps: |     steps: | ||||||
|       - name: Checkout code |       - name: Checkout code | ||||||
|         uses: actions/checkout@v5 |         uses: actions/checkout@v3 | ||||||
|         with: |         with: | ||||||
|           fetch-depth: 0 # Important for git describe --tags |           fetch-depth: 0 # Important for git describe --tags | ||||||
|  |  | ||||||
|       - name: Install Rust |       - name: Install Rust | ||||||
|         uses: actions-rs/toolchain@v1 |         uses: actions-rs/toolchain@v1 | ||||||
|         with: |         with: | ||||||
|           toolchain: 1.90.0 |           toolchain: 1.88.0 | ||||||
|           components: cargo |           components: cargo | ||||||
|  |  | ||||||
|       - name: Extract Version from Cargo.toml |       - name: Extract Version from Cargo.toml | ||||||
|   | |||||||
| @@ -7,37 +7,36 @@ on: | |||||||
|   pull_request: |   pull_request: | ||||||
|     branches: |     branches: | ||||||
|       - main  |       - main  | ||||||
|       - next-v0.8 |  | ||||||
|  |  | ||||||
| jobs: | jobs: | ||||||
|   check: |   check: | ||||||
|     name: Check |     name: Check | ||||||
|     runs-on: ubuntu-24.04 |     runs-on: ubuntu-24.04 | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v5 |       - uses: actions/checkout@v4 | ||||||
|       - uses: actions-rust-lang/setup-rust-toolchain@v1 |       - uses: actions-rust-lang/setup-rust-toolchain@v1 | ||||||
|         with: |         with: | ||||||
|           toolchain: 1.90.0 |           toolchain: 1.88.0 | ||||||
|       - run: cargo check |       - run: cargo check | ||||||
|  |  | ||||||
|   test: |   test: | ||||||
|     name: Test Suite |     name: Test Suite | ||||||
|     runs-on: ubuntu-24.04 |     runs-on: ubuntu-24.04 | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v5 |       - uses: actions/checkout@v4 | ||||||
|       - uses: actions-rust-lang/setup-rust-toolchain@v1 |       - uses: actions-rust-lang/setup-rust-toolchain@v1 | ||||||
|         with: |         with: | ||||||
|           toolchain: 1.90.0 |           toolchain: 1.88.0 | ||||||
|       - run: cargo test |       - run: cargo test | ||||||
|  |  | ||||||
|   fmt: |   fmt: | ||||||
|     name: Rustfmt |     name: Rustfmt | ||||||
|     runs-on: ubuntu-24.04 |     runs-on: ubuntu-24.04 | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v5 |       - uses: actions/checkout@v4 | ||||||
|       - uses: actions-rust-lang/setup-rust-toolchain@v1 |       - uses: actions-rust-lang/setup-rust-toolchain@v1 | ||||||
|         with: |         with: | ||||||
|           toolchain: 1.90.0 |           toolchain: 1.88.0 | ||||||
|       - run: rustup component add rustfmt |       - run: rustup component add rustfmt | ||||||
|       - run: cargo fmt --all -- --check |       - run: cargo fmt --all -- --check | ||||||
|  |  | ||||||
| @@ -45,10 +44,10 @@ jobs: | |||||||
|     name: Clippy |     name: Clippy | ||||||
|     runs-on: ubuntu-24.04 |     runs-on: ubuntu-24.04 | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v5 |       - uses: actions/checkout@v4 | ||||||
|       - uses: actions-rust-lang/setup-rust-toolchain@v1 |       - uses: actions-rust-lang/setup-rust-toolchain@v1 | ||||||
|         with: |         with: | ||||||
|           toolchain: 1.90.0 |           toolchain: 1.88.0 | ||||||
|       - run: rustup component add clippy |       - run: rustup component add clippy | ||||||
|       - run: cargo clippy -- -D warnings |       - run: cargo clippy -- -D warnings | ||||||
|  |  | ||||||
| @@ -56,10 +55,10 @@ jobs: | |||||||
|     name: build |     name: build | ||||||
|     runs-on: ubuntu-24.04 |     runs-on: ubuntu-24.04 | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v5 |       - uses: actions/checkout@v4 | ||||||
|       - uses: actions-rust-lang/setup-rust-toolchain@v1 |       - uses: actions-rust-lang/setup-rust-toolchain@v1 | ||||||
|         with: |         with: | ||||||
|           toolchain: 1.90.0 |           toolchain: 1.88.0 | ||||||
|       - run: cargo build |       - run: cargo build | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										2
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							| @@ -149,7 +149,7 @@ checksum = "5419bdc4f6a9207fbeba6d11b604d481addf78ecd10c11ad51e76c2f6482748d" | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "icarus_models" | name = "icarus_models" | ||||||
| version = "0.7.2" | version = "0.6.7" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "josekit", |  "josekit", | ||||||
|  "rand", |  "rand", | ||||||
|   | |||||||
| @@ -1,8 +1,8 @@ | |||||||
| [package] | [package] | ||||||
| name = "icarus_models" | name = "icarus_models" | ||||||
| version = "0.7.2" | version = "0.6.7" | ||||||
| edition = "2024" | edition = "2024" | ||||||
| rust-version = "1.90" | rust-version = "1.88" | ||||||
| description = "models used for the icarus project" | description = "models used for the icarus project" | ||||||
| license = "MIT" | license = "MIT" | ||||||
|  |  | ||||||
|   | |||||||
| @@ -7,22 +7,22 @@ pub struct CoverArt { | |||||||
|     pub id: uuid::Uuid, |     pub id: uuid::Uuid, | ||||||
|     pub title: String, |     pub title: String, | ||||||
|     #[serde(skip)] |     #[serde(skip)] | ||||||
|     pub directory: String, |     pub path: String, | ||||||
|     pub filename: String, |  | ||||||
|     #[serde(skip)] |     #[serde(skip)] | ||||||
|     pub data: Vec<u8>, |     pub data: Vec<u8>, | ||||||
|     pub song_id: uuid::Uuid, |     pub song_id: uuid::Uuid, | ||||||
| } | } | ||||||
|  |  | ||||||
| pub mod init { | pub mod init { | ||||||
|     use super::CoverArt; |     use crate::coverart::CoverArt; | ||||||
|  |  | ||||||
|     /// Initializes the CoverArt with just the directory and filename |     pub fn init_coverart_only_path(path: String) -> CoverArt { | ||||||
|     pub fn init_coverart_dir_and_filename(directory: &str, filename: &str) -> CoverArt { |  | ||||||
|         CoverArt { |         CoverArt { | ||||||
|             directory: String::from(directory), |             id: uuid::Uuid::nil(), | ||||||
|             filename: String::from(filename), |             title: String::new(), | ||||||
|             ..Default::default() |             path: path.clone(), | ||||||
|  |             data: Vec::new(), | ||||||
|  |             song_id: uuid::Uuid::nil(), | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -30,12 +30,9 @@ pub mod init { | |||||||
| impl CoverArt { | impl CoverArt { | ||||||
|     /// Saves the coverart to the filesystem |     /// Saves the coverart to the filesystem | ||||||
|     pub fn save_to_filesystem(&self) -> Result<(), std::io::Error> { |     pub fn save_to_filesystem(&self) -> Result<(), std::io::Error> { | ||||||
|         match self.get_path() { |         match std::fs::File::create(&self.path) { | ||||||
|             Ok(path) => match std::fs::File::create(&path) { |             Ok(mut file) => match file.write_all(&self.data) { | ||||||
|                 Ok(mut file) => match file.write_all(&self.data) { |                 Ok(_) => Ok(()), | ||||||
|                     Ok(_) => Ok(()), |  | ||||||
|                     Err(err) => Err(err), |  | ||||||
|                 }, |  | ||||||
|                 Err(err) => Err(err), |                 Err(err) => Err(err), | ||||||
|             }, |             }, | ||||||
|             Err(err) => Err(err), |             Err(err) => Err(err), | ||||||
| @@ -44,46 +41,15 @@ impl CoverArt { | |||||||
|  |  | ||||||
|     /// Removes the coverart from the filesystem |     /// Removes the coverart from the filesystem | ||||||
|     pub fn remove_from_filesystem(&self) -> Result<(), std::io::Error> { |     pub fn remove_from_filesystem(&self) -> Result<(), std::io::Error> { | ||||||
|         match self.get_path() { |         let p = std::path::Path::new(&self.path); | ||||||
|             Ok(path) => { |         if p.exists() { | ||||||
|                 let p = std::path::Path::new(&path); |             match std::fs::remove_file(p) { | ||||||
|                 if p.exists() { |                 Ok(_) => Ok(()), | ||||||
|                     match std::fs::remove_file(p) { |                 Err(err) => Err(err), | ||||||
|                         Ok(_) => Ok(()), |  | ||||||
|                         Err(err) => Err(err), |  | ||||||
|                     } |  | ||||||
|                 } else { |  | ||||||
|                     Err(std::io::Error::other( |  | ||||||
|                         "Cannot delete file that does not exist", |  | ||||||
|                     )) |  | ||||||
|                 } |  | ||||||
|             } |             } | ||||||
|             Err(err) => Err(err), |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /// Gets the path of the CoverArt |  | ||||||
|     pub fn get_path(&self) -> Result<String, std::io::Error> { |  | ||||||
|         if self.directory.is_empty() { |  | ||||||
|             return Err(std::io::Error::other("Directory has not been initialized")); |  | ||||||
|         } else if self.filename.is_empty() { |  | ||||||
|             return Err(std::io::Error::other("Filename has not bee initialized")); |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         let directory = &self.directory; |  | ||||||
|         let last_index = directory.len() - 1; |  | ||||||
|  |  | ||||||
|         if let Some(character) = directory.chars().nth(last_index) { |  | ||||||
|             let buffer = if character != '/' { |  | ||||||
|                 directory.clone() + "/" |  | ||||||
|             } else { |  | ||||||
|                 directory.clone() |  | ||||||
|             }; |  | ||||||
|  |  | ||||||
|             Ok(buffer + &self.filename.clone()) |  | ||||||
|         } else { |         } else { | ||||||
|             Err(std::io::Error::other( |             Err(std::io::Error::other( | ||||||
|                 "Could not access last character of directory", |                 "Cannot delete file that does not exist", | ||||||
|             )) |             )) | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| @@ -94,15 +60,11 @@ pub mod io { | |||||||
|  |  | ||||||
|     /// Gets the raw data of the cover art |     /// Gets the raw data of the cover art | ||||||
|     pub fn to_data(coverart: &super::CoverArt) -> Result<Vec<u8>, std::io::Error> { |     pub fn to_data(coverart: &super::CoverArt) -> Result<Vec<u8>, std::io::Error> { | ||||||
|         match coverart.get_path() { |         let path: &String = &coverart.path; | ||||||
|             Ok(path) => { |         let mut file = std::fs::File::open(path)?; | ||||||
|                 let mut file = std::fs::File::open(path)?; |         let mut buffer = Vec::new(); | ||||||
|                 let mut buffer = Vec::new(); |         match file.read_to_end(&mut buffer) { | ||||||
|                 match file.read_to_end(&mut buffer) { |             Ok(_) => Ok(buffer), | ||||||
|                     Ok(_) => Ok(buffer), |  | ||||||
|                     Err(err) => Err(err), |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|             Err(err) => Err(err), |             Err(err) => Err(err), | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| @@ -114,11 +76,9 @@ mod tests { | |||||||
|  |  | ||||||
|     #[test] |     #[test] | ||||||
|     fn test_cover_art_image() { |     fn test_cover_art_image() { | ||||||
|         let dir = String::from("./"); |         let path: String = String::from("somepath"); | ||||||
|         let filename = String::from("CoverArt.png"); |         let coverart = coverart::init::init_coverart_only_path(path.clone()); | ||||||
|         let coverart = coverart::init::init_coverart_dir_and_filename(&dir, &filename); |  | ||||||
|  |  | ||||||
|         assert_eq!(dir, coverart.directory); |         assert_eq!(path, coverart.path); | ||||||
|         assert_eq!(filename, coverart.filename); |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										21
									
								
								src/song.rs
									
									
									
									
									
								
							
							
						
						
									
										21
									
								
								src/song.rs
									
									
									
									
									
								
							| @@ -39,8 +39,8 @@ pub struct Song { | |||||||
|     pub track_count: i32, |     pub track_count: i32, | ||||||
|     #[serde(skip_serializing_if = "String::is_empty")] |     #[serde(skip_serializing_if = "String::is_empty")] | ||||||
|     pub audio_type: String, |     pub audio_type: String, | ||||||
|     #[serde(with = "time::serde::rfc3339::option")] |     #[serde(skip_serializing_if = "String::is_empty")] | ||||||
|     pub date_created: Option<time::OffsetDateTime>, |     pub date_created: String, | ||||||
|     #[serde(skip_serializing_if = "String::is_empty")] |     #[serde(skip_serializing_if = "String::is_empty")] | ||||||
|     pub filename: String, |     pub filename: String, | ||||||
|     #[serde(skip_serializing_if = "init::is_uuid_nil")] |     #[serde(skip_serializing_if = "init::is_uuid_nil")] | ||||||
| @@ -71,22 +71,21 @@ impl Song { | |||||||
|  |  | ||||||
|     pub fn song_path(&self) -> Result<String, std::io::Error> { |     pub fn song_path(&self) -> Result<String, std::io::Error> { | ||||||
|         if self.directory.is_empty() { |         if self.directory.is_empty() { | ||||||
|             return Err(std::io::Error::other("Directory has not been initialized")); |             return Err(std::io::Error::other("Directory does not exist")); | ||||||
|         } else if self.filename.is_empty() { |  | ||||||
|             return Err(std::io::Error::other("Filename has not bee initialized")); |  | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         let directory = &self.directory; |         let directory = &self.directory; | ||||||
|  |         let mut buffer: String = directory.clone(); | ||||||
|         let last_index = directory.len() - 1; |         let last_index = directory.len() - 1; | ||||||
|  |  | ||||||
|         if let Some(character) = directory.chars().nth(last_index) { |         if let Some(character) = directory.chars().nth(last_index) { | ||||||
|             let buffer: String = if character != '/' { |             if character != '/' { | ||||||
|                 directory.clone() + "/" |                 buffer += "/"; | ||||||
|             } else { |             } | ||||||
|                 directory.clone() |  | ||||||
|             }; |  | ||||||
|  |  | ||||||
|             Ok(buffer + &self.filename.clone()) |             buffer += &self.filename.clone(); | ||||||
|  |  | ||||||
|  |             Ok(buffer) | ||||||
|         } else { |         } else { | ||||||
|             Err(std::io::Error::other( |             Err(std::io::Error::other( | ||||||
|                 "Could not access last character of directory", |                 "Could not access last character of directory", | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user