mirror of
https://github.com/TECHNOFAB11/jwt-authorizer.git
synced 2025-12-12 16:10:06 +01:00
Add support for time crate.
This commit is contained in:
parent
7f9ad54694
commit
70d1ac3786
3 changed files with 24 additions and 7 deletions
9
Cargo.lock
generated
9
Cargo.lock
generated
|
|
@ -830,7 +830,7 @@ dependencies = [
|
||||||
"serde",
|
"serde",
|
||||||
"serde_json",
|
"serde_json",
|
||||||
"thiserror",
|
"thiserror",
|
||||||
"time 0.3.21",
|
"time 0.3.22",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
|
|
@ -875,6 +875,7 @@ dependencies = [
|
||||||
"serde",
|
"serde",
|
||||||
"serde_json",
|
"serde_json",
|
||||||
"thiserror",
|
"thiserror",
|
||||||
|
"time 0.3.22",
|
||||||
"tokio",
|
"tokio",
|
||||||
"tonic",
|
"tonic",
|
||||||
"tower",
|
"tower",
|
||||||
|
|
@ -1638,7 +1639,7 @@ dependencies = [
|
||||||
"num-bigint",
|
"num-bigint",
|
||||||
"num-traits",
|
"num-traits",
|
||||||
"thiserror",
|
"thiserror",
|
||||||
"time 0.3.21",
|
"time 0.3.22",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
|
|
@ -1756,9 +1757,9 @@ dependencies = [
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "time"
|
name = "time"
|
||||||
version = "0.3.21"
|
version = "0.3.22"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "8f3403384eaacbca9923fa06940178ac13e4edb725486d70e8e15881d0c836cc"
|
checksum = "ea9e1b3cf1243ae005d9e74085d4d542f3125458f3a81af210d901dcd7411efd"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"itoa",
|
"itoa",
|
||||||
"serde",
|
"serde",
|
||||||
|
|
|
||||||
|
|
@ -11,7 +11,7 @@ keywords = ["jwt","axum","authorisation","jwks"]
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
axum = { version = "0.6", features = ["headers"] }
|
axum = { version = "0.6", features = ["headers"] }
|
||||||
chrono = "0.4"
|
chrono = { version = "0.4", optional = true }
|
||||||
futures-util = "0.3"
|
futures-util = "0.3"
|
||||||
futures-core = "0.3"
|
futures-core = "0.3"
|
||||||
headers = "0.3"
|
headers = "0.3"
|
||||||
|
|
@ -29,6 +29,7 @@ tower-service = "0.3"
|
||||||
tracing = "0.1"
|
tracing = "0.1"
|
||||||
tracing-subscriber = { version = "0.3", features = ["env-filter"] }
|
tracing-subscriber = { version = "0.3", features = ["env-filter"] }
|
||||||
tonic = { version = "0.9.2", optional = true }
|
tonic = { version = "0.9.2", optional = true }
|
||||||
|
time = { version = "0.3.22", optional = true }
|
||||||
|
|
||||||
[dev-dependencies]
|
[dev-dependencies]
|
||||||
hyper = { version = "0.14", features = ["full"] }
|
hyper = { version = "0.14", features = ["full"] }
|
||||||
|
|
@ -38,7 +39,7 @@ tower = { version = "0.4", features = ["util", "buffer"] }
|
||||||
wiremock = "0.5"
|
wiremock = "0.5"
|
||||||
|
|
||||||
[features]
|
[features]
|
||||||
default = ["default-tls"]
|
default = ["default-tls", "chrono"]
|
||||||
default-tls = ["reqwest/default-tls"]
|
default-tls = ["reqwest/default-tls"]
|
||||||
native-tls = ["reqwest/native-tls"]
|
native-tls = ["reqwest/native-tls"]
|
||||||
native-tls-vendored = ["reqwest/native-tls-vendored"]
|
native-tls-vendored = ["reqwest/native-tls-vendored"]
|
||||||
|
|
@ -47,6 +48,8 @@ rustls-tls = ["reqwest/rustls-tls"]
|
||||||
rustls-tls-manual-roots = ["reqwest/rustls-tls-manual-roots"]
|
rustls-tls-manual-roots = ["reqwest/rustls-tls-manual-roots"]
|
||||||
rustls-tls-webpki-roots = ["reqwest/rustls-tls-webpki-roots"]
|
rustls-tls-webpki-roots = ["reqwest/rustls-tls-webpki-roots"]
|
||||||
rustls-tls-native-roots = ["reqwest/rustls-tls-native-roots"]
|
rustls-tls-native-roots = ["reqwest/rustls-tls-native-roots"]
|
||||||
|
time = ["dep:time"]
|
||||||
|
chrono = ["dep:chrono"]
|
||||||
|
|
||||||
[[test]]
|
[[test]]
|
||||||
name = "tonic"
|
name = "tonic"
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,3 @@
|
||||||
use chrono::{DateTime, TimeZone, Utc};
|
|
||||||
use std::fmt;
|
use std::fmt;
|
||||||
|
|
||||||
use serde::{de, Deserialize, Deserializer};
|
use serde::{de, Deserialize, Deserializer};
|
||||||
|
|
@ -7,12 +6,26 @@ use serde::{de, Deserialize, Deserializer};
|
||||||
#[derive(Deserialize, Clone, PartialEq, Eq, Debug)]
|
#[derive(Deserialize, Clone, PartialEq, Eq, Debug)]
|
||||||
pub struct NumericDate(i64);
|
pub struct NumericDate(i64);
|
||||||
|
|
||||||
|
#[cfg(feature = "chrono")]
|
||||||
|
use chrono::{DateTime, TimeZone, Utc};
|
||||||
|
|
||||||
|
#[cfg(feature = "chrono")]
|
||||||
impl From<NumericDate> for DateTime<Utc> {
|
impl From<NumericDate> for DateTime<Utc> {
|
||||||
fn from(t: NumericDate) -> Self {
|
fn from(t: NumericDate) -> Self {
|
||||||
Utc.timestamp_opt(t.0, 0).unwrap()
|
Utc.timestamp_opt(t.0, 0).unwrap()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[cfg(feature = "time")]
|
||||||
|
use time::OffsetDateTime;
|
||||||
|
|
||||||
|
#[cfg(feature = "time")]
|
||||||
|
impl From<NumericDate> for OffsetDateTime {
|
||||||
|
fn from(t: NumericDate) -> Self {
|
||||||
|
OffsetDateTime::from_unix_timestamp(t.0).unwrap()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#[derive(PartialEq, Debug, Clone)]
|
#[derive(PartialEq, Debug, Clone)]
|
||||||
pub struct StringList(Vec<String>);
|
pub struct StringList(Vec<String>);
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue