From ca59ac1f02ed7b6a12640852abdbf59514bee398 Mon Sep 17 00:00:00 2001 From: Mike Engel Date: Fri, 21 Apr 2017 15:16:52 -0600 Subject: [PATCH 1/4] Update serde, serde_json, and serde_derive to 1.0 --- Cargo.toml | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/Cargo.toml b/Cargo.toml index 06fd0a37..4ce20c9d 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -11,9 +11,9 @@ keywords = ["jwt", "web", "api", "token", "json"] [dependencies] error-chain = { version = "0.10", default-features = false } -serde_json = "0.9" -serde_derive = "0.9" -serde = "0.9" +serde_json = "1.0" +serde_derive = "1.0" +serde = "1.0" ring = { version = "0.7", features = ["rsa_signing", "dev_urandom_fallback"] } base64 = "0.4" untrusted = "0.3" From 0932f14bc2a97890732ce9f1799bdf40ebd40136 Mon Sep 17 00:00:00 2001 From: Mike Engel Date: Fri, 21 Apr 2017 23:21:04 -0600 Subject: [PATCH 2/4] Migrate `Deserialize` trait to `DeserializeOwned` for Serde 1.0 --- src/lib.rs | 4 ++-- src/serialization.rs | 8 ++++---- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/src/lib.rs b/src/lib.rs index 1f517cc8..e323eab9 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -31,7 +31,7 @@ pub use crypto::{ pub use validation::Validation; -use serde::de::Deserialize; +use serde::de::DeserializeOwned; use serde::ser::Serialize; use errors::{Result, ErrorKind}; @@ -101,7 +101,7 @@ macro_rules! expect_two { /// // Claims is a struct that implements Deserialize /// let token_data = decode::(&token, "secret", Algorithm::HS256, &Validation::default()); /// ``` -pub fn decode(token: &str, key: &[u8], algorithm: Algorithm, validation: &Validation) -> Result> { +pub fn decode(token: &str, key: &[u8], algorithm: Algorithm, validation: &Validation) -> Result> { let (signature, signing_input) = expect_two!(token.rsplitn(2, '.')); if validation.validate_signature && !verify(signature, signing_input, key, algorithm)? { diff --git a/src/serialization.rs b/src/serialization.rs index fe7529e2..5fce5265 100644 --- a/src/serialization.rs +++ b/src/serialization.rs @@ -1,5 +1,5 @@ use base64; -use serde::de::Deserialize; +use serde::de::DeserializeOwned; use serde::ser::Serialize; use serde_json::{from_str, to_string, Value}; use serde_json::map::Map; @@ -10,7 +10,7 @@ use header::Header; /// The return type of a successful call to decode #[derive(Debug)] -pub struct TokenData { +pub struct TokenData { pub header: Header, pub claims: T } @@ -22,7 +22,7 @@ pub fn to_jwt_part(input: &T) -> Result { } /// Decodes from base64 and deserializes from JSON to a struct -pub fn from_jwt_part, T: Deserialize>(encoded: B) -> Result { +pub fn from_jwt_part, T: DeserializeOwned>(encoded: B) -> Result { let decoded = base64::decode_config(encoded.as_ref(), base64::URL_SAFE_NO_PAD)?; let s = String::from_utf8(decoded)?; @@ -30,7 +30,7 @@ pub fn from_jwt_part, T: Deserialize>(encoded: B) -> Result { } /// Decodes from base64 and deserializes from JSON to a struct AND a hashmap -pub fn from_jwt_part_claims, T: Deserialize>(encoded: B) -> Result<(T, Map)> { +pub fn from_jwt_part_claims, T: DeserializeOwned>(encoded: B) -> Result<(T, Map)> { let decoded = base64::decode_config(encoded.as_ref(), base64::URL_SAFE_NO_PAD)?; let s = String::from_utf8(decoded)?; From 56e2f97c3b42aed5b1ee916fb8b92debede41e91 Mon Sep 17 00:00:00 2001 From: Mike Engel Date: Fri, 21 Apr 2017 23:27:27 -0600 Subject: [PATCH 3/4] Update the readme to suggest serde 1.0 over 0.9 --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index 6fbdb7fd..d67bf779 100644 --- a/README.md +++ b/README.md @@ -7,7 +7,7 @@ Add the following to Cargo.toml: ```toml jsonwebtoken = "2" -serde_derive = "0.9" +serde_derive = "1.0" ``` ## How to use From cbd9b236da17cff281e3b39dd3d1dd585dca2729 Mon Sep 17 00:00:00 2001 From: Mike Engel Date: Fri, 21 Apr 2017 23:41:25 -0600 Subject: [PATCH 4/4] Remove trait from `TokenData` struct --- src/serialization.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/serialization.rs b/src/serialization.rs index 5fce5265..12d5e5de 100644 --- a/src/serialization.rs +++ b/src/serialization.rs @@ -10,7 +10,7 @@ use header::Header; /// The return type of a successful call to decode #[derive(Debug)] -pub struct TokenData { +pub struct TokenData { pub header: Header, pub claims: T }