Skip to content

Commit

Permalink
Merge pull request #28 from mike-engel/serde-1.0
Browse files Browse the repository at this point in the history
Update Serde to 1.0
  • Loading branch information
Keats authored Apr 22, 2017
2 parents d343e9c + cbd9b23 commit d8439b1
Show file tree
Hide file tree
Showing 4 changed files with 10 additions and 10 deletions.
6 changes: 3 additions & 3 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -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"
Expand Down
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ Add the following to Cargo.toml:

```toml
jsonwebtoken = "2"
serde_derive = "0.9"
serde_derive = "1.0"
```

## How to use
Expand Down
4 changes: 2 additions & 2 deletions src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -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};
Expand Down Expand Up @@ -101,7 +101,7 @@ macro_rules! expect_two {
/// // Claims is a struct that implements Deserialize
/// let token_data = decode::<Claims>(&token, "secret", Algorithm::HS256, &Validation::default());
/// ```
pub fn decode<T: Deserialize>(token: &str, key: &[u8], algorithm: Algorithm, validation: &Validation) -> Result<TokenData<T>> {
pub fn decode<T: DeserializeOwned>(token: &str, key: &[u8], algorithm: Algorithm, validation: &Validation) -> Result<TokenData<T>> {
let (signature, signing_input) = expect_two!(token.rsplitn(2, '.'));

if validation.validate_signature && !verify(signature, signing_input, key, algorithm)? {
Expand Down
8 changes: 4 additions & 4 deletions src/serialization.rs
Original file line number Diff line number Diff line change
@@ -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;
Expand All @@ -10,7 +10,7 @@ use header::Header;

/// The return type of a successful call to decode
#[derive(Debug)]
pub struct TokenData<T: Deserialize> {
pub struct TokenData<T> {
pub header: Header,
pub claims: T
}
Expand All @@ -22,15 +22,15 @@ pub fn to_jwt_part<T: Serialize>(input: &T) -> Result<String> {
}

/// Decodes from base64 and deserializes from JSON to a struct
pub fn from_jwt_part<B: AsRef<str>, T: Deserialize>(encoded: B) -> Result<T> {
pub fn from_jwt_part<B: AsRef<str>, T: DeserializeOwned>(encoded: B) -> Result<T> {
let decoded = base64::decode_config(encoded.as_ref(), base64::URL_SAFE_NO_PAD)?;
let s = String::from_utf8(decoded)?;

Ok(from_str(&s)?)
}

/// Decodes from base64 and deserializes from JSON to a struct AND a hashmap
pub fn from_jwt_part_claims<B: AsRef<str>, T: Deserialize>(encoded: B) -> Result<(T, Map<String, Value>)> {
pub fn from_jwt_part_claims<B: AsRef<str>, T: DeserializeOwned>(encoded: B) -> Result<(T, Map<String, Value>)> {
let decoded = base64::decode_config(encoded.as_ref(), base64::URL_SAFE_NO_PAD)?;
let s = String::from_utf8(decoded)?;

Expand Down

0 comments on commit d8439b1

Please sign in to comment.