extract::{FromRequest, FromRequestParts},
http::{request::Parts, Request},
Json,
};
use serde::{de::DeserializeOwned, Serialize};
use super::prelude::CookieValue;
pub struct AuthWrapper<D: Serialize + DeserializeOwned> {
pub cookie: CookieValue,
pub json: Json<D>,
}
pub struct Auth<D, E = AuthWrapper<D>>
where
D: Serialize + DeserializeOwned,
{
pub extractors: E,
marker: PhantomData<D>,
}
#[async_trait]
impl<S, D, E> FromRequestParts<S> for Auth<D, E>
where
S: Send + Sync,
E: FromRequestParts<S>,
D: Serialize + DeserializeOwned,
{
type Rejection = E::Rejection;
async fn from_request_parts(parts: &mut Parts, state: &S) -> Result<Self, Self::Rejection> {
let extractors = E::from_request_parts(parts, state).await?;
Ok(Auth {
extractors,
marker: PhantomData,
})
}
}
#[async_trait]
impl<S, B, D, E> FromRequest<S, B> for Auth<D, E>
where
B: Send + 'static,
S: Send + Sync,
E: FromRequest<S, B>,
D: Serialize + DeserializeOwned,
{
type Rejection = E::Rejection;
async fn from_request(req: Request<B>, state: &S) -> Result<Self, Self::Rejection> {
let extractors = E::from_request(req, state).await?;
Ok(Auth {
extractors,
marker: PhantomData,
})
}
}
Это из-за констрейнта where E: FromRequestParts<S>, Если его убрать то он подцепится.
просто E убрать?
Я выше примел пример, он компилируется. От твоего отличается тем что нет констрейнта на Е (точнее я все убрал, но достаточно убрать только этот)
так как я выполню from_requests_parts без E?
Я порой думаю, что я тут забыл. Я горожу какой-то бред, а оказывается, всё можно было сделать проще👀
это обычный враппер
Я понимаю, просто я городил у себя в проекте мидлварю и расширял запрос, а оказывается, можно было проще сделать хд
Обсуждают сегодня