fix: include InvalidSignature in JWT validation error handling
This commit is contained in:
@@ -5,7 +5,7 @@ use std::{collections::HashSet, sync::Arc};
|
|||||||
use argon2::password_hash::{SaltString, rand_core::OsRng};
|
use argon2::password_hash::{SaltString, rand_core::OsRng};
|
||||||
use jsonwebtoken::{
|
use jsonwebtoken::{
|
||||||
DecodingKey, EncodingKey, Header, Validation, decode, encode,
|
DecodingKey, EncodingKey, Header, Validation, decode, encode,
|
||||||
errors::ErrorKind::{ExpiredSignature, InvalidSubject, InvalidToken},
|
errors::ErrorKind::{ExpiredSignature, InvalidSignature, InvalidSubject, InvalidToken},
|
||||||
};
|
};
|
||||||
use sea_orm::prelude::Uuid;
|
use sea_orm::prelude::Uuid;
|
||||||
use serde::{Deserialize, Serialize};
|
use serde::{Deserialize, Serialize};
|
||||||
@@ -124,7 +124,7 @@ impl AuthenticationService for AuthenticationServiceImpl {
|
|||||||
match decode::<Claims>(token, &decoding_key, &validation) {
|
match decode::<Claims>(token, &decoding_key, &validation) {
|
||||||
Ok(data) => Ok(Some(data.claims)),
|
Ok(data) => Ok(Some(data.claims)),
|
||||||
Err(err) => match *err.kind() {
|
Err(err) => match *err.kind() {
|
||||||
InvalidToken | InvalidSubject | ExpiredSignature => Ok(None),
|
InvalidToken | InvalidSubject | ExpiredSignature | InvalidSignature => Ok(None),
|
||||||
_ => Err(ServiceError::InternalError(format!(
|
_ => Err(ServiceError::InternalError(format!(
|
||||||
"JWT validation error: {}",
|
"JWT validation error: {}",
|
||||||
err
|
err
|
||||||
|
|||||||
Reference in New Issue
Block a user