Improve documentation of axum::Form (#2289)

This commit is contained in:
Jonas Platte 2023-10-25 23:37:19 +02:00 committed by GitHub
parent a4133d0d4a
commit e84d563b26
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
11 changed files with 26 additions and 16 deletions

View file

@ -2,7 +2,7 @@ name: CI
env: env:
CARGO_TERM_COLOR: always CARGO_TERM_COLOR: always
MSRV: '1.63' MSRV: '1.65'
on: on:
push: push:

View file

@ -2,7 +2,7 @@
categories = ["asynchronous", "network-programming", "web-programming"] categories = ["asynchronous", "network-programming", "web-programming"]
description = "Extra utilities for axum" description = "Extra utilities for axum"
edition = "2021" edition = "2021"
rust-version = "1.63" rust-version = "1.65"
homepage = "https://github.com/tokio-rs/axum" homepage = "https://github.com/tokio-rs/axum"
keywords = ["http", "web", "framework"] keywords = ["http", "web", "framework"]
license = "MIT" license = "MIT"

View file

@ -14,7 +14,7 @@ This crate uses `#![forbid(unsafe_code)]` to ensure everything is implemented in
## Minimum supported Rust version ## Minimum supported Rust version
axum-extra's MSRV is 1.63. axum-extra's MSRV is 1.65.
## Getting Help ## Getting Help

View file

@ -105,7 +105,7 @@ where
} }
} }
/// Rejection used for [`TypedHeader`](TypedHeader). /// Rejection used for [`TypedHeader`].
#[cfg(feature = "typed-header")] #[cfg(feature = "typed-header")]
#[derive(Debug)] #[derive(Debug)]
pub struct TypedHeaderRejection { pub struct TypedHeaderRejection {

View file

@ -2,7 +2,7 @@
categories = ["asynchronous", "network-programming", "web-programming"] categories = ["asynchronous", "network-programming", "web-programming"]
description = "Macros for axum" description = "Macros for axum"
edition = "2021" edition = "2021"
rust-version = "1.63" rust-version = "1.65"
homepage = "https://github.com/tokio-rs/axum" homepage = "https://github.com/tokio-rs/axum"
keywords = ["axum"] keywords = ["axum"]
license = "MIT" license = "MIT"

View file

@ -14,7 +14,7 @@ This crate uses `#![forbid(unsafe_code)]` to ensure everything is implemented in
## Minimum supported Rust version ## Minimum supported Rust version
axum-macros's MSRV is 1.63. axum-macros's MSRV is 1.65.
## Getting Help ## Getting Help

View file

@ -61,7 +61,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
- **fixed:** Fix `.source()` of composite rejections ([#2030]) - **fixed:** Fix `.source()` of composite rejections ([#2030])
- **fixed:** Allow unreachable code in `#[debug_handler]` ([#2014]) - **fixed:** Allow unreachable code in `#[debug_handler]` ([#2014])
- **change:** Update tokio-tungstenite to 0.19 ([#2021]) - **change:** Update tokio-tungstenite to 0.19 ([#2021])
- **change:** axum's MSRV is now 1.63 ([#2021]) - **change:** axum's MSRV is now 1.65 ([#2021])
- **added:** Implement `Handler` for `T: IntoResponse` ([#2140]) - **added:** Implement `Handler` for `T: IntoResponse` ([#2140])
- **added:** Implement `IntoResponse` for `(R,) where R: IntoResponse` ([#2143]) - **added:** Implement `IntoResponse` for `(R,) where R: IntoResponse` ([#2143])
- **changed:** For SSE, add space between field and value for compatibility ([#2149]) - **changed:** For SSE, add space between field and value for compatibility ([#2149])

View file

@ -4,7 +4,7 @@ version = "0.6.16"
categories = ["asynchronous", "network-programming", "web-programming::http-server"] categories = ["asynchronous", "network-programming", "web-programming::http-server"]
description = "Web framework that focuses on ergonomics and modularity" description = "Web framework that focuses on ergonomics and modularity"
edition = "2021" edition = "2021"
rust-version = "1.63" rust-version = "1.65"
homepage = "https://github.com/tokio-rs/axum" homepage = "https://github.com/tokio-rs/axum"
keywords = ["http", "web", "framework"] keywords = ["http", "web", "framework"]
license = "MIT" license = "MIT"

View file

@ -112,7 +112,7 @@ This crate uses `#![forbid(unsafe_code)]` to ensure everything is implemented in
## Minimum supported Rust version ## Minimum supported Rust version
axum's MSRV is 1.63. axum's MSRV is 1.65.
## Examples ## Examples

View file

@ -348,7 +348,7 @@ impl fmt::Display for ErrorKind {
} }
} }
/// Rejection type for [`Path`](super::Path) if the captured routes params couldn't be deserialized /// Rejection type for [`Path`] if the captured routes params couldn't be deserialized
/// into the expected type. /// into the expected type.
#[derive(Debug)] #[derive(Debug)]
pub struct FailedToDeserializePathParams(PathDeserializationError); pub struct FailedToDeserializePathParams(PathDeserializationError);

View file

@ -12,9 +12,18 @@ use serde::Serialize;
/// ///
/// # As extractor /// # As extractor
/// ///
/// If used as an extractor `Form` will deserialize the query parameters for `GET` and `HEAD` /// If used as an extractor, `Form` will deserialize form data from the request,
/// requests and `application/x-www-form-urlencoded` encoded request bodies for other methods. It /// specifically:
/// supports any type that implements [`serde::Deserialize`]. ///
/// - If the request has a method of `GET` or `HEAD`, the form data will be read
/// from the query string (same as with [`Query`])
/// - If the request has a different method, the form will be read from the body
/// of the request. It must have a `content-type` of
/// `application/x-www-form-urlencoded` for this to work. If you want to parse
/// `multipart/form-data` request bodies, use [`Multipart`] instead.
///
/// This matches how HTML forms are sent by browsers by default.
/// In both cases, the inner type `T` must implement [`serde::Deserialize`].
/// ///
/// ⚠️ Since parsing form data might require consuming the request body, the `Form` extractor must be /// ⚠️ Since parsing form data might require consuming the request body, the `Form` extractor must be
/// *last* if there are multiple extractors in a handler. See ["the order of /// *last* if there are multiple extractors in a handler. See ["the order of
@ -37,11 +46,11 @@ use serde::Serialize;
/// } /// }
/// ``` /// ```
/// ///
/// Note that `Content-Type: multipart/form-data` requests are not supported. Use [`Multipart`]
/// instead.
///
/// # As response /// # As response
/// ///
/// `Form` can also be used to encode any type that implements
/// [`serde::Serialize`] as `application/x-www-form-urlencoded`
///
/// ```rust /// ```rust
/// use axum::Form; /// use axum::Form;
/// use serde::Serialize; /// use serde::Serialize;
@ -56,6 +65,7 @@ use serde::Serialize;
/// } /// }
/// ``` /// ```
/// ///
/// [`Query`]: crate::extract::Query
/// [`Multipart`]: crate::extract::Multipart /// [`Multipart`]: crate::extract::Multipart
#[cfg_attr(docsrs, doc(cfg(feature = "form")))] #[cfg_attr(docsrs, doc(cfg(feature = "form")))]
#[derive(Debug, Clone, Copy, Default)] #[derive(Debug, Clone, Copy, Default)]