mirror of
https://github.com/tokio-rs/axum.git
synced 2025-01-07 19:12:13 +01:00
7705ef6661
* Add missing leading double colon * Separate handling of last element in FromRequest derive * FromRequestParts derive * fix it and add lots of tests * docs * changelog * Update axum-macros/src/lib.rs Co-authored-by: Jonas Platte <jplatte+git@posteo.de> Co-authored-by: David Pedersen <david.pdrsn@gmail.com>
39 lines
826 B
Rust
39 lines
826 B
Rust
use axum::{
|
|
extract::rejection::JsonRejection,
|
|
response::{IntoResponse, Response},
|
|
routing::get,
|
|
Router,
|
|
};
|
|
use axum_macros::FromRequest;
|
|
use std::collections::HashMap;
|
|
use serde::Deserialize;
|
|
|
|
fn main() {
|
|
let _: Router = Router::new().route("/", get(handler).post(handler_result));
|
|
}
|
|
|
|
async fn handler(_: MyJson) {}
|
|
|
|
async fn handler_result(_: Result<MyJson, MyJsonRejection>) {}
|
|
|
|
#[derive(FromRequest, Deserialize)]
|
|
#[from_request(
|
|
via(axum::extract::Json),
|
|
rejection(MyJsonRejection),
|
|
)]
|
|
#[serde(transparent)]
|
|
struct MyJson(HashMap<String, String>);
|
|
|
|
struct MyJsonRejection {}
|
|
|
|
impl From<JsonRejection> for MyJsonRejection {
|
|
fn from(_: JsonRejection) -> Self {
|
|
todo!()
|
|
}
|
|
}
|
|
|
|
impl IntoResponse for MyJsonRejection {
|
|
fn into_response(self) -> Response {
|
|
todo!()
|
|
}
|
|
}
|