2022-08-12 18:05:27 +02:00
|
|
|
use axum::{
|
|
|
|
async_trait,
|
2022-08-22 12:23:20 +02:00
|
|
|
extract::{rejection::ExtensionRejection, FromRequest},
|
|
|
|
http::{StatusCode, Request},
|
2022-08-12 18:05:27 +02:00
|
|
|
response::{IntoResponse, Response},
|
|
|
|
routing::get,
|
|
|
|
Extension, Router,
|
|
|
|
};
|
|
|
|
use axum_macros::FromRequest;
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
let _: Router = Router::new().route("/", get(handler).post(handler_result));
|
|
|
|
}
|
|
|
|
|
|
|
|
async fn handler(_: MyExtractor) {}
|
|
|
|
|
|
|
|
async fn handler_result(_: Result<MyExtractor, MyRejection>) {}
|
|
|
|
|
|
|
|
#[derive(FromRequest)]
|
|
|
|
#[from_request(rejection(MyRejection))]
|
|
|
|
struct MyExtractor {
|
|
|
|
one: Extension<String>,
|
|
|
|
#[from_request(via(Extension))]
|
|
|
|
two: String,
|
|
|
|
three: OtherExtractor,
|
|
|
|
}
|
|
|
|
|
|
|
|
struct OtherExtractor;
|
|
|
|
|
|
|
|
#[async_trait]
|
2022-08-17 17:13:31 +02:00
|
|
|
impl<S, B> FromRequest<S, B> for OtherExtractor
|
2022-08-12 18:05:27 +02:00
|
|
|
where
|
|
|
|
B: Send + 'static,
|
2022-08-17 22:08:24 +02:00
|
|
|
S: Send + Sync,
|
2022-08-12 18:05:27 +02:00
|
|
|
{
|
|
|
|
// this rejection doesn't implement `Display` and `Error`
|
|
|
|
type Rejection = (StatusCode, String);
|
|
|
|
|
2022-08-22 12:23:20 +02:00
|
|
|
async fn from_request(_req: Request<B>, _state: &S) -> Result<Self, Self::Rejection> {
|
2022-08-12 18:05:27 +02:00
|
|
|
todo!()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
struct MyRejection {}
|
|
|
|
|
|
|
|
impl From<ExtensionRejection> for MyRejection {
|
|
|
|
fn from(_: ExtensionRejection) -> Self {
|
|
|
|
todo!()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl From<(StatusCode, String)> for MyRejection {
|
|
|
|
fn from(_: (StatusCode, String)) -> Self {
|
|
|
|
todo!()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl IntoResponse for MyRejection {
|
|
|
|
fn into_response(self) -> Response {
|
|
|
|
todo!()
|
|
|
|
}
|
|
|
|
}
|