Compare commits
	
		
			6 Commits
		
	
	
		
			v0.7.2--ea
			...
			v0.8.0
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 860d684e7b | |||
| 97783568e9 | |||
| 5a8118726b | |||
| 9dcf46ec0a | |||
| 44d08cdb1f | |||
| 51c8b5c7b3 | 
| @@ -1,10 +1,9 @@ | |||||||
| name: Release Tagging | name: Release Tagging | ||||||
|  |  | ||||||
| on: | on: | ||||||
|   pull_request: |   push: | ||||||
|     branches: |     branches: | ||||||
|       - main |       - main | ||||||
|       - next-v0.8 |  | ||||||
|  |  | ||||||
| jobs: | jobs: | ||||||
|   release: |   release: | ||||||
| @@ -27,8 +26,7 @@ jobs: | |||||||
|           VERSION=$(grep '^version = "' Cargo.toml | sed -E 's/version = "([^"]+)"/\1/') |           VERSION=$(grep '^version = "' Cargo.toml | sed -E 's/version = "([^"]+)"/\1/') | ||||||
|           PROJECT_COMMIT_HASH=$(git rev-parse HEAD | cut -c 1-10) |           PROJECT_COMMIT_HASH=$(git rev-parse HEAD | cut -c 1-10) | ||||||
|           BRANCH_REF="${{ gitea.ref }}" |           BRANCH_REF="${{ gitea.ref }}" | ||||||
|           BRANCH_REF_NAME="${{ gitea.ref_name }}" |           BRANCH_NAME=$(echo "$BRANCH_REF" | cut -d '/' -f 3) | ||||||
|           BRANCH_NAME="${{ gitea.ref_type }}" |  | ||||||
|           PROJECT_TAG_RELEASE="v$VERSION-$BRANCH_NAME-$PROJECT_COMMIT_HASH-111" |           PROJECT_TAG_RELEASE="v$VERSION-$BRANCH_NAME-$PROJECT_COMMIT_HASH-111" | ||||||
|  |  | ||||||
|           echo "::set-output name=project_tag_release::$PROJECT_TAG_RELEASE" |           echo "::set-output name=project_tag_release::$PROJECT_TAG_RELEASE" | ||||||
| @@ -36,7 +34,6 @@ jobs: | |||||||
|           echo "Version: $VERSION" |           echo "Version: $VERSION" | ||||||
|           echo "Hash: $PROJECT_COMMIT_HASH" |           echo "Hash: $PROJECT_COMMIT_HASH" | ||||||
|           echo "Branh ref: $BRANCH_REF" |           echo "Branh ref: $BRANCH_REF" | ||||||
|           echo "Branh ref name: $BRANCH_REF_NAME" |  | ||||||
|           echo "Branch: $BRANCH_NAME" |           echo "Branch: $BRANCH_NAME" | ||||||
|           echo "Tag Release: $PROJECT_TAG_RELEASE" |           echo "Tag Release: $PROJECT_TAG_RELEASE" | ||||||
|  |  | ||||||
|   | |||||||
| @@ -7,7 +7,6 @@ on: | |||||||
|   pull_request: |   pull_request: | ||||||
|     branches: |     branches: | ||||||
|       - main  |       - main  | ||||||
|       - next-v0.8 |  | ||||||
|  |  | ||||||
| jobs: | jobs: | ||||||
|   check: |   check: | ||||||
| @@ -61,5 +60,3 @@ jobs: | |||||||
|         with: |         with: | ||||||
|           toolchain: 1.90.0 |           toolchain: 1.90.0 | ||||||
|       - run: cargo build |       - run: cargo build | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										53
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										53
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							| @@ -31,9 +31,9 @@ checksum = "72b3254f16251a8381aa12e40e3c4d2f0199f8c6508fbecb9d91f575e0fbb8c6" | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "bitflags" | name = "bitflags" | ||||||
| version = "2.9.4" | version = "2.10.0" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "2261d10cca569e4643e526d8dc2e62e433cc8aba21ab764233731f8d369bf394" | checksum = "812e12b5285cc515a9c72a5c1d3b6d46a19dac5acfef5265968c166106e31dd3" | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "bumpalo" | name = "bumpalo" | ||||||
| @@ -53,9 +53,9 @@ dependencies = [ | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "cfg-if" | name = "cfg-if" | ||||||
| version = "1.0.3" | version = "1.0.4" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "2fd1289c04a9ea8cb22300a459a72a385d7c73d3259e2ed7dcb2af674838cfa9" | checksum = "9330f8b2ff13f34540b44e946ef35111825727b38d33286ef986142615121801" | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "crc32fast" | name = "crc32fast" | ||||||
| @@ -131,14 +131,14 @@ checksum = "00b0228411908ca8685dba7fc2cdd70ec9990a6e753e89b6ac91a84c40fbaf4b" | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "getrandom" | name = "getrandom" | ||||||
| version = "0.3.3" | version = "0.3.4" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "26145e563e54f2cadc477553f1ec5ee650b00862f0a58bcd12cbdc5f0ea2d2f4" | checksum = "899def5c37c4fd7b2664648c28120ecec138e4d395b459e5ca34f9cce2dd77fd" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "cfg-if", |  "cfg-if", | ||||||
|  "libc", |  "libc", | ||||||
|  "r-efi", |  "r-efi", | ||||||
|  "wasi", |  "wasip2", | ||||||
| ] | ] | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| @@ -149,7 +149,7 @@ checksum = "5419bdc4f6a9207fbeba6d11b604d481addf78ecd10c11ad51e76c2f6482748d" | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "icarus_models" | name = "icarus_models" | ||||||
| version = "0.7.2" | version = "0.8.0" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "josekit", |  "josekit", | ||||||
|  "rand", |  "rand", | ||||||
| @@ -163,9 +163,9 @@ dependencies = [ | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "indexmap" | name = "indexmap" | ||||||
| version = "2.11.4" | version = "2.12.0" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "4b0f83760fb341a774ed326568e19f5a863af4a952def8c39f9ab92fd95b88e5" | checksum = "6717a8d2a5a929a1a2eb43a12812498ed141a0bcfb7e8f7844fbdbe4303bba9f" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "equivalent", |  "equivalent", | ||||||
|  "hashbrown", |  "hashbrown", | ||||||
| @@ -254,9 +254,9 @@ checksum = "42f5e15c9953c5e4ccceeb2e7382a716482c34515315f7b03532b8b4e8393d2d" | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "openssl" | name = "openssl" | ||||||
| version = "0.10.73" | version = "0.10.74" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "8505734d46c8ab1e19a1dce3aef597ad87dcb4c37e7188231769bd6bd51cebf8" | checksum = "24ad14dd45412269e1a30f52ad8f0664f0f4f4a89ee8fe28c3b3527021ebb654" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "bitflags", |  "bitflags", | ||||||
|  "cfg-if", |  "cfg-if", | ||||||
| @@ -280,9 +280,9 @@ dependencies = [ | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "openssl-sys" | name = "openssl-sys" | ||||||
| version = "0.9.109" | version = "0.9.110" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "90096e2e47630d78b7d1c20952dc621f957103f8bc2c8359ec81290d75238571" | checksum = "0a9f0075ba3c21b09f8e8b2026584b1d18d49388648f2fbbf3c97ea8deced8e2" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "cc", |  "cc", | ||||||
|  "libc", |  "libc", | ||||||
| @@ -366,9 +366,9 @@ dependencies = [ | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "regex" | name = "regex" | ||||||
| version = "1.12.1" | version = "1.12.2" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "4a52d8d02cacdb176ef4678de6c052efb4b3da14b78e4db683a4252762be5433" | checksum = "843bc0191f75f3e22651ae5f1e72939ab2f72a4bc30fa80a066bd66edefc24d4" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "aho-corasick", |  "aho-corasick", | ||||||
|  "memchr", |  "memchr", | ||||||
| @@ -378,9 +378,9 @@ dependencies = [ | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "regex-automata" | name = "regex-automata" | ||||||
| version = "0.4.12" | version = "0.4.13" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "722166aa0d7438abbaa4d5cc2c649dac844e8c56d82fb3d33e9c34b5cd268fc6" | checksum = "5276caf25ac86c8d810222b3dbb938e512c55c6831a10f3e6ed1c93b84041f1c" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "aho-corasick", |  "aho-corasick", | ||||||
|  "memchr", |  "memchr", | ||||||
| @@ -389,9 +389,9 @@ dependencies = [ | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "regex-syntax" | name = "regex-syntax" | ||||||
| version = "0.8.7" | version = "0.8.8" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "c3160422bbd54dd5ecfdca71e5fd59b7b8fe2b1697ab2baf64f6d05dcc66d298" | checksum = "7a2d987857b319362043e95f5353c0535c1f58eec5336fdfcf626430af7def58" | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "rustix" | name = "rustix" | ||||||
| @@ -476,9 +476,9 @@ checksum = "d66dc143e6b11c1eddc06d5c423cfc97062865baf299914ab64caa38182078fe" | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "syn" | name = "syn" | ||||||
| version = "2.0.106" | version = "2.0.107" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "ede7c438028d4436d71104916910f5bb611972c5cfd7f89b8300a8186e6fada6" | checksum = "2a26dbd934e5451d21ef060c018dae56fc073894c5a7896f882928a76e6d081b" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "proc-macro2", |  "proc-macro2", | ||||||
|  "quote", |  "quote", | ||||||
| @@ -597,15 +597,6 @@ version = "0.2.15" | |||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "accd4ea62f7bb7a82fe23066fb0957d48ef677f6eeb8215f372f52e48bb32426" | checksum = "accd4ea62f7bb7a82fe23066fb0957d48ef677f6eeb8215f372f52e48bb32426" | ||||||
|  |  | ||||||
| [[package]] |  | ||||||
| name = "wasi" |  | ||||||
| version = "0.14.7+wasi-0.2.4" |  | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" |  | ||||||
| checksum = "883478de20367e224c0090af9cf5f9fa85bed63a95c1abf3afc5c083ebc06e8c" |  | ||||||
| dependencies = [ |  | ||||||
|  "wasip2", |  | ||||||
| ] |  | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "wasip2" | name = "wasip2" | ||||||
| version = "1.0.1+wasi-0.2.4" | version = "1.0.1+wasi-0.2.4" | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| [package] | [package] | ||||||
| name = "icarus_models" | name = "icarus_models" | ||||||
| version = "0.7.2" | version = "0.8.0" | ||||||
| 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" | ||||||
|   | |||||||
| @@ -2,7 +2,7 @@ use std::default::Default; | |||||||
|  |  | ||||||
| use serde::{Deserialize, Serialize}; | use serde::{Deserialize, Serialize}; | ||||||
|  |  | ||||||
| #[derive(Clone, Debug, Deserialize, Serialize, utoipa::ToSchema)] | #[derive(Clone, Debug, Default, Deserialize, Serialize, utoipa::ToSchema)] | ||||||
| pub struct LoginResult { | pub struct LoginResult { | ||||||
|     pub id: uuid::Uuid, |     pub id: uuid::Uuid, | ||||||
|     pub username: String, |     pub username: String, | ||||||
| @@ -12,20 +12,14 @@ pub struct LoginResult { | |||||||
|     pub expiration: i64, |     pub expiration: i64, | ||||||
| } | } | ||||||
|  |  | ||||||
| impl Default for LoginResult { |  | ||||||
|     fn default() -> Self { |  | ||||||
|         LoginResult { |  | ||||||
|             id: uuid::Uuid::nil(), |  | ||||||
|             username: String::new(), |  | ||||||
|             token: String::new(), |  | ||||||
|             token_type: String::new(), |  | ||||||
|             expiration: -1, |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| impl LoginResult { | impl LoginResult { | ||||||
|     pub fn _to_json(&self) -> Result<String, serde_json::Error> { |     pub fn to_json(&self) -> Result<String, serde_json::Error> { | ||||||
|         serde_json::to_string_pretty(&self) |         serde_json::to_string_pretty(&self) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     pub fn token_expired(&self) -> bool { | ||||||
|  |         let current_time = time::OffsetDateTime::now_utc(); | ||||||
|  |         let expired = time::OffsetDateTime::from_unix_timestamp(self.expiration).unwrap(); | ||||||
|  |         current_time > expired | ||||||
|  |     } | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										30
									
								
								src/token.rs
									
									
									
									
									
								
							
							
						
						
									
										30
									
								
								src/token.rs
									
									
									
									
									
								
							| @@ -2,7 +2,7 @@ use std::default::Default; | |||||||
|  |  | ||||||
| use serde::{Deserialize, Serialize}; | use serde::{Deserialize, Serialize}; | ||||||
|  |  | ||||||
| #[derive(Clone, Debug, Deserialize, Serialize)] | #[derive(Clone, Debug, Default, Deserialize, Serialize)] | ||||||
| pub struct Token { | pub struct Token { | ||||||
|     pub scope: String, |     pub scope: String, | ||||||
|     pub expiration: i64, |     pub expiration: i64, | ||||||
| @@ -27,23 +27,16 @@ pub struct AccessToken { | |||||||
|     pub message: String, |     pub message: String, | ||||||
| } | } | ||||||
|  |  | ||||||
| impl Default for Token { | impl AccessToken { | ||||||
|     fn default() -> Self { |     /// Get the token fit for Bearer authentication | ||||||
|         Token { |     pub fn bearer_token(&self) -> String { | ||||||
|             scope: String::new(), |         format!("Bearer {}", self.token) | ||||||
|             expiration: -1, |  | ||||||
|             audience: String::new(), |  | ||||||
|             issuer: String::new(), |  | ||||||
|             issued: -1, |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
| impl AccessToken { |     pub fn token_expired(&self) -> bool { | ||||||
|     pub fn bearer_token(&self) -> String { |         let current_time = time::OffsetDateTime::now_utc(); | ||||||
|         let mut token: String = String::from("Bearer "); |         let expired = time::OffsetDateTime::from_unix_timestamp(self.expiration).unwrap(); | ||||||
|         token += &self.token.clone(); |         current_time > expired | ||||||
|         token |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -52,9 +45,10 @@ impl Token { | |||||||
|         serde_json::to_string_pretty(&self) |         serde_json::to_string_pretty(&self) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     // TODO: Implement |  | ||||||
|     pub fn token_expired(&self) -> bool { |     pub fn token_expired(&self) -> bool { | ||||||
|         false |         let current_time = time::OffsetDateTime::now_utc(); | ||||||
|  |         let expired = time::OffsetDateTime::from_unix_timestamp(self.expiration).unwrap(); | ||||||
|  |         current_time > expired | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub fn contains_scope(&self, des_scope: &String) -> bool { |     pub fn contains_scope(&self, des_scope: &String) -> bool { | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user