Crates.io | auth0-jwt |
lib.rs | auth0-jwt |
version | 0.1.0 |
source | src |
created_at | 2022-12-19 18:34:09.32064 |
updated_at | 2022-12-19 18:34:09.32064 |
description | Library to validate JWTs from Auth0 |
homepage | https://github.com/rawnly/auth0-jwt |
repository | https://github.com/rawnly/auth0-jwt |
max_upload_size | |
id | 741456 |
size | 11,224 |
Auth0 utility to check if the given JWT is valid.
use auth0_jwt::get_claims;
#[tokio::async]
async fn main() {
let token = env!("JWT_TOKEN");
let claims = get_claims(&token).unwrap();
println!("Claims {}", claims);
}
claims
- Exports the Claims
struct which is useful for deserialization.axum
- Implements the FromRequestParts<T>
trait for Claims
and provides a Token(String)
extractor for convenience.use auth0_jwt::claims::Claims;
use axum::{response::IntoResponse, routing::get, Json, Router};
use dotenv::dotenv;
use serde::{Deserialize, Serialize};
use std::net::SocketAddr;
#[tokio::main]
async fn main() {
dotenv().ok();
// build our application with a route
let app = Router::new().route("/", get(handler));
// run it
let addr = SocketAddr::from(([127, 0, 0, 1], 3000));
println!("listening on {}", addr);
axum::Server::bind(&addr)
.serve(app.into_make_service())
.await
.unwrap();
}
#[derive(Serialize)]
struct ResponseBody {
message: &'static str,
}
#[derive(Deserialize, Serialize)]
struct ClaimsContent {
pub exp: usize,
pub iat: usize
}
async fn handler(Claims(claims): Claims<ClaimsContent>) -> impl IntoResponse {
println!("{:?}", claims.exp);
Json(ResponseBody {
message: "hello world",
})
}