Module axum_valid::typed_multipart
source · Expand description
Support for TypedMultipart<T> and BaseMultipart<T, R> from axum_typed_multipart
Feature
Enable the typed_multipart feature to use Valid<TypedMultipart<T>> and Valid<BaseMultipart<T, R>>.
Usage
- Implement
TryFromMultipartandValidatefor your data typeT. - In your handler function, use
Valid<TypedMultipart<T>>orValid<BaseMultipart<T, E>as some parameter’s type.
Example
use axum::routing::post;
use axum::Router;
use axum_typed_multipart::{BaseMultipart, TryFromMultipart, TypedMultipart, TypedMultipartError};
use axum_valid::Valid;
use validator::Validate;
#[tokio::main]
async fn main() -> anyhow::Result<()> {
let router = Router::new()
.route("/typed_multipart", post(handler))
.route("/base_multipart", post(base_handler));
axum::Server::bind(&([0u8, 0, 0, 0], 8080).into())
.serve(router.into_make_service())
.await?;
Ok(())
}
async fn handler(Valid(TypedMultipart(parameter)): Valid<TypedMultipart<Parameter>>) {
assert!(parameter.validate().is_ok());
}
async fn base_handler(
Valid(BaseMultipart {
data: parameter, ..
}): Valid<BaseMultipart<Parameter, TypedMultipartError>>,
) {
assert!(parameter.validate().is_ok());
}
#[derive(TryFromMultipart, Validate)]
struct Parameter {
#[validate(range(min = 5, max = 10))]
v0: i32,
#[validate(length(min = 1, max = 10))]
v1: String,
}