#jwt #basic #claim

basic-jwt

Basic JWT signing and verification library

3 releases (breaking)

Uses new Rust 2024

0.3.0 Mar 28, 2025
0.2.0 Apr 20, 2024
0.1.0 Apr 20, 2024

#5 in #claims

Download history 33/week @ 2025-01-31 7/week @ 2025-02-07 4/week @ 2025-02-21 28/week @ 2025-02-28 27/week @ 2025-03-07 12/week @ 2025-03-14 17/week @ 2025-03-21 374/week @ 2025-03-28 99/week @ 2025-04-04 69/week @ 2025-04-11 67/week @ 2025-04-18 54/week @ 2025-04-25 62/week @ 2025-05-02 75/week @ 2025-05-09 41/week @ 2025-05-16

241 downloads per month

MIT license

9KB
144 lines

Basic JWT

This crate provide basic functions to:

  • Sign JWT
  • Parse and validate JWT

Basic usage:

let claims = ...; // note : claims must be serializable

// Generate a key pair. Private and public key are both serializable
let priv_key = JWTPrivateKey::generate_ec384_signing_key().unwrap();
let pub_key = priv_key.to_public_key().unwrap();

// Create a JWT for the given claims (note: standard claims: sub, iss, ...) are not
// automatically added if they are missing
let jwt = priv_key.sign_jwt(&claims).expect("Failed to sign JWT!");

// Validate signed JWT
let claims_out = pub_key
            .validate_jwt::<Claims>(&jwt)
            .expect("Failed to validate JWT!");

Dependencies

~5–14MB
~196K SLoC