Compare commits
3 Commits
9b2b8af0e1
...
v0.9.2-mai
| Author | SHA1 | Date | |
|---|---|---|---|
| 0552561851 | |||
| 678d2c2b3d | |||
| b5429f80b0 |
@@ -4,6 +4,9 @@ on:
|
|||||||
push:
|
push:
|
||||||
branches:
|
branches:
|
||||||
- main
|
- main
|
||||||
|
pull_request:
|
||||||
|
branches:
|
||||||
|
- main
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
release:
|
release:
|
||||||
|
|||||||
2
Cargo.lock
generated
2
Cargo.lock
generated
@@ -149,7 +149,7 @@ checksum = "5419bdc4f6a9207fbeba6d11b604d481addf78ecd10c11ad51e76c2f6482748d"
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "icarus_models"
|
name = "icarus_models"
|
||||||
version = "0.9.0"
|
version = "0.9.2"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"josekit",
|
"josekit",
|
||||||
"rand",
|
"rand",
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
[package]
|
[package]
|
||||||
name = "icarus_models"
|
name = "icarus_models"
|
||||||
version = "0.9.0"
|
version = "0.9.2"
|
||||||
edition = "2024"
|
edition = "2024"
|
||||||
rust-version = "1.90"
|
rust-version = "1.90"
|
||||||
description = "models used for the icarus project"
|
description = "models used for the icarus project"
|
||||||
|
|||||||
@@ -11,6 +11,7 @@ pub struct CoverArt {
|
|||||||
#[serde(skip)]
|
#[serde(skip)]
|
||||||
pub directory: String,
|
pub directory: String,
|
||||||
pub filename: String,
|
pub filename: String,
|
||||||
|
pub file_type: String,
|
||||||
#[serde(skip)]
|
#[serde(skip)]
|
||||||
pub data: Vec<u8>,
|
pub data: Vec<u8>,
|
||||||
pub song_id: uuid::Uuid,
|
pub song_id: uuid::Uuid,
|
||||||
@@ -86,20 +87,20 @@ impl CoverArt {
|
|||||||
|
|
||||||
/// Generates filename for a CoverArt
|
/// Generates filename for a CoverArt
|
||||||
pub fn generate_filename(
|
pub fn generate_filename(
|
||||||
typ: crate::types::CoverArtTypes,
|
typ: crate::types::CoverArtType,
|
||||||
randomize: bool,
|
randomize: bool,
|
||||||
) -> Result<String, std::io::Error> {
|
) -> Result<String, std::io::Error> {
|
||||||
let file_extension = match typ {
|
let file_extension = match typ {
|
||||||
crate::types::CoverArtTypes::PngExtension => {
|
crate::types::CoverArtType::PngExtension => {
|
||||||
String::from(crate::constants::file_extensions::image::PNGEXTENSION)
|
String::from(crate::constants::file_extensions::image::PNGEXTENSION)
|
||||||
}
|
}
|
||||||
crate::types::CoverArtTypes::JpegExtension => {
|
crate::types::CoverArtType::JpegExtension => {
|
||||||
String::from(crate::constants::file_extensions::image::JPEGEXTENSION)
|
String::from(crate::constants::file_extensions::image::JPEGEXTENSION)
|
||||||
}
|
}
|
||||||
crate::types::CoverArtTypes::JpgExtension => {
|
crate::types::CoverArtType::JpgExtension => {
|
||||||
String::from(crate::constants::file_extensions::image::JPGEXTENSION)
|
String::from(crate::constants::file_extensions::image::JPGEXTENSION)
|
||||||
}
|
}
|
||||||
crate::types::CoverArtTypes::None => {
|
crate::types::CoverArtType::None => {
|
||||||
return Err(std::io::Error::other("Unsupported CoverArtTypes"));
|
return Err(std::io::Error::other("Unsupported CoverArtTypes"));
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|||||||
15
src/song.rs
15
src/song.rs
@@ -126,24 +126,21 @@ impl Song {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// Generates a filename. In order to save a song to the filesystem
|
/// Generates a filename. In order to save a song to the filesystem
|
||||||
pub fn generate_filename(
|
pub fn generate_filename(typ: types::MusicType, randomize: bool) -> Result<String, std::io::Error> {
|
||||||
typ: types::MusicTypes,
|
|
||||||
randomize: bool,
|
|
||||||
) -> Result<String, std::io::Error> {
|
|
||||||
let file_extension = match typ {
|
let file_extension = match typ {
|
||||||
types::MusicTypes::DefaultMusicExtension => {
|
types::MusicType::DefaultMusicExtension => {
|
||||||
String::from(constants::file_extensions::audio::DEFAULTMUSICEXTENSION)
|
String::from(constants::file_extensions::audio::DEFAULTMUSICEXTENSION)
|
||||||
}
|
}
|
||||||
types::MusicTypes::WavExtension => {
|
types::MusicType::WavExtension => {
|
||||||
String::from(constants::file_extensions::audio::WAVEXTENSION)
|
String::from(constants::file_extensions::audio::WAVEXTENSION)
|
||||||
}
|
}
|
||||||
types::MusicTypes::FlacExtension => {
|
types::MusicType::FlacExtension => {
|
||||||
String::from(constants::file_extensions::audio::FLACEXTENSION)
|
String::from(constants::file_extensions::audio::FLACEXTENSION)
|
||||||
}
|
}
|
||||||
types::MusicTypes::MPThreeExtension => {
|
types::MusicType::MPThreeExtension => {
|
||||||
String::from(constants::file_extensions::audio::MPTHREEEXTENSION)
|
String::from(constants::file_extensions::audio::MPTHREEEXTENSION)
|
||||||
}
|
}
|
||||||
types::MusicTypes::None => return Err(std::io::Error::other("Unsupported MusicTypes")),
|
types::MusicType::None => return Err(std::io::Error::other("Unsupported MusicTypes")),
|
||||||
};
|
};
|
||||||
|
|
||||||
let filename: String = if randomize {
|
let filename: String = if randomize {
|
||||||
|
|||||||
40
src/token.rs
40
src/token.rs
@@ -1,8 +1,8 @@
|
|||||||
use std::default::Default;
|
use std::default::Default;
|
||||||
|
|
||||||
use serde::{Deserialize, Serialize};
|
use serde::Deserialize;
|
||||||
|
|
||||||
#[derive(Clone, Debug, Default, Deserialize, Serialize)]
|
#[derive(Clone, Debug, Default, Deserialize, serde::Serialize)]
|
||||||
pub struct Token {
|
pub struct Token {
|
||||||
pub scope: String,
|
pub scope: String,
|
||||||
pub expiration: i64,
|
pub expiration: i64,
|
||||||
@@ -11,7 +11,7 @@ pub struct Token {
|
|||||||
pub issued: i64,
|
pub issued: i64,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Clone, Debug, Deserialize, Serialize)]
|
#[derive(Clone, Debug, Deserialize, serde::Serialize)]
|
||||||
pub struct AccessToken {
|
pub struct AccessToken {
|
||||||
#[serde(alias = "init::is_uuid_nil")]
|
#[serde(alias = "init::is_uuid_nil")]
|
||||||
pub user_id: uuid::Uuid,
|
pub user_id: uuid::Uuid,
|
||||||
@@ -27,6 +27,21 @@ pub struct AccessToken {
|
|||||||
pub message: String,
|
pub message: String,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, serde::Serialize, Deserialize)]
|
||||||
|
pub struct UserClaims {
|
||||||
|
pub iss: String,
|
||||||
|
pub aud: String, // Audience
|
||||||
|
pub sub: String, // Subject (user ID)
|
||||||
|
#[serde(deserialize_with = "deserialize_i64_from_f64")]
|
||||||
|
pub exp: i64, // Expiration time (UTC timestamp)
|
||||||
|
#[serde(deserialize_with = "deserialize_i64_from_f64")]
|
||||||
|
pub iat: i64, // Issued at (UTC timestamp)
|
||||||
|
// pub azp: String,
|
||||||
|
// pub gty: String,
|
||||||
|
#[serde(skip_serializing_if = "Option::is_none")]
|
||||||
|
pub roles: Option<Vec<String>>, // Optional roles
|
||||||
|
}
|
||||||
|
|
||||||
impl AccessToken {
|
impl AccessToken {
|
||||||
/// Get the token fit for Bearer authentication
|
/// Get the token fit for Bearer authentication
|
||||||
pub fn bearer_token(&self) -> String {
|
pub fn bearer_token(&self) -> String {
|
||||||
@@ -56,6 +71,25 @@ impl Token {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn deserialize_i64_from_f64<'de, D>(deserializer: D) -> Result<i64, D::Error>
|
||||||
|
where
|
||||||
|
D: serde::Deserializer<'de>,
|
||||||
|
{
|
||||||
|
let val = f64::deserialize(deserializer)?;
|
||||||
|
// Handle NaN and infinity cases
|
||||||
|
if val.is_nan() || val.is_infinite() {
|
||||||
|
return Err(serde::de::Error::custom("invalid float value"));
|
||||||
|
}
|
||||||
|
// Round to nearest integer and convert
|
||||||
|
let rounded = val.round();
|
||||||
|
// Check if the rounded value can fit in i64
|
||||||
|
if rounded < (i64::MIN as f64) || rounded > (i64::MAX as f64) {
|
||||||
|
Err(serde::de::Error::custom("float out of i64 range"))
|
||||||
|
} else {
|
||||||
|
Ok(rounded as i64)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
pub fn get_issued() -> time::Result<time::OffsetDateTime> {
|
pub fn get_issued() -> time::Result<time::OffsetDateTime> {
|
||||||
Ok(time::OffsetDateTime::now_utc())
|
Ok(time::OffsetDateTime::now_utc())
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -107,7 +107,7 @@ mod song_tests {
|
|||||||
};
|
};
|
||||||
|
|
||||||
assert_eq!(song.directory.is_empty(), false);
|
assert_eq!(song.directory.is_empty(), false);
|
||||||
match song::generate_filename(types::MusicTypes::FlacExtension, true) {
|
match song::generate_filename(types::MusicType::FlacExtension, true) {
|
||||||
Ok(filename) => {
|
Ok(filename) => {
|
||||||
song_cpy.filename = filename;
|
song_cpy.filename = filename;
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user