Добавлена проверка токена пользователя для перед обработкой запроса.
This commit is contained in:
2025-03-27 20:03:35 +04:00
parent f703cc8326
commit 1add903f36
6 changed files with 94 additions and 15 deletions

View File

@@ -10,20 +10,18 @@ use actix_web::{HttpRequest, web};
use derive_more::Display;
use serde::{Deserialize, Serialize};
use std::fmt::Debug;
use actix_web::http::header;
#[derive(Clone, Debug, Serialize, Deserialize, Display, ResponseErrorMessage)]
#[status_code = "actix_web::http::StatusCode::UNAUTHORIZED"]
#[serde(rename_all = "SCREAMING_SNAKE_CASE")]
pub enum Error {
#[display("No authorization header found")]
#[display("No Authorization header found")]
NoHeader,
#[display("Bearer token is required")]
UnknownAuthorizationType,
#[display("No bearer token provided")]
NoBearerToken,
#[display("Invalid or expired access token")]
InvalidAccessToken,
@@ -43,7 +41,7 @@ impl FromRequestSync for User {
fn from_request_sync(req: &HttpRequest, _: &mut Payload) -> Result<Self, Self::Error> {
let authorization = req
.headers()
.get("Authorization")
.get(header::AUTHORIZATION)
.ok_or(Error::NoHeader.into_err())?
.to_str()
.map_err(|_| Error::NoHeader.into_err())?
@@ -51,14 +49,10 @@ impl FromRequestSync for User {
let parts: Vec<&str> = authorization.split(' ').collect();
if parts.len() == 0 || parts[0] != "Bearer" {
if parts.len() != 2 || parts[0] != "Bearer" {
return Err(Error::UnknownAuthorizationType.into_err());
}
if parts.len() < 2 {
return Err(Error::NoBearerToken.into());
}
let user_id = jwt::verify_and_decode(&parts[1].to_string())
.map_err(|_| Error::InvalidAccessToken.into_err())?;