# Changelog All notable changes to this project will be documented in this file. The format is based on [Keep a Changelog], and this project adheres to [Semantic Versioning]. # Unreleased - None. # 0.9.3 (24. March, 2024) - **added:** New `tracing` feature which enables logging rejections from built-in extractor with the `axum::rejection=trace` target ([#2596]) [#2596]: https://github.com/tokio-rs/axum/pull/2596 # 0.9.2 (13. January, 2024) - **added:** Implement `TypedPath` for `WithRejection` - **fixed:** Documentation link to `serde::Deserialize` in `JsonDeserializer` extractor ([#2498]) - **added:** Add `is_missing` function for `TypedHeaderRejection` and `TypedHeaderRejectionReason` ([#2503]) [#2498]: https://github.com/tokio-rs/axum/pull/2498 [#2503]: https://github.com/tokio-rs/axum/pull/2503 # 0.9.1 (29. December, 2023) - **change:** Update version of multer used internally for multipart ([#2433]) - **added:** `JsonDeserializer` extractor ([#2431]) [#2433]: https://github.com/tokio-rs/axum/pull/2433 [#2431]: https://github.com/tokio-rs/axum/pull/2431 # 0.9.0 (27. November, 2023) - **added:** `OptionalQuery` extractor ([#2310]) - **added:** `TypedHeader` which used to be in `axum` ([#1850]) - **breaking:** Update to prost 0.12. Used for the `Protobuf` extractor - **breaking:** Make `tokio` an optional dependency - **breaking:** Upgrade `cookie` dependency to 0.18 ([#2343]) - **breaking:** Functions and methods that previously accepted a `Cookie` now accept any `T: Into` ([#2348]) [#1850]: https://github.com/tokio-rs/axum/pull/1850 [#2310]: https://github.com/tokio-rs/axum/pull/2310 [#2343]: https://github.com/tokio-rs/axum/pull/2343 [#2348]: https://github.com/tokio-rs/axum/pull/2348 # 0.8.0 (16. September, 2023) - **breaking:** Update to prost 0.12. Used for the `Protobuf` extractor ([#2224]) [#2224]: https://github.com/tokio-rs/axum/pull/2224 # 0.7.7 (03. August, 2023) - **added:** `Clone` implementation for `ErasedJson` ([#2142]) [#2142]: https://github.com/tokio-rs/axum/pull/2142 # 0.7.6 (02. August, 2023) - **fixed:** Remove unused dependency ([#2135]) [#2135]: https://github.com/tokio-rs/axum/pull/2135 # 0.7.5 (17. July, 2023) - **fixed:** Remove explicit auto deref from `PrivateCookieJar` example ([#2028]) [#2028]: https://github.com/tokio-rs/axum/pull/2028 # 0.7.4 (18. April, 2023) - **added:** Add `Html` response type ([#1921]) - **added:** Add `Css` response type ([#1921]) - **added:** Add `JavaScript` response type ([#1921]) - **added:** Add `Wasm` response type ([#1921]) [#1921]: https://github.com/tokio-rs/axum/pull/1921 # 0.7.3 (11. April, 2023) - **added:** Implement `Deref` and `DerefMut` for built-in extractors ([#1922]) - **added:** Add `OptionalPath` extractor ([#1889]) [#1889]: https://github.com/tokio-rs/axum/pull/1889 [#1922]: https://github.com/tokio-rs/axum/pull/1922 # 0.7.2 (22. March, 2023) - **added:** Implement `IntoResponse` for `MultipartError` ([#1861]) [#1861]: https://github.com/tokio-rs/axum/pull/1861 # 0.7.1 (13. March, 2023) - Updated to latest `axum-macros` # 0.7.0 (03. March, 2023) - **breaking:** Remove the `spa` feature which should have been removed in 0.6.0 ([#1802]) - **added:** Add `Multipart`. This is similar to `axum::extract::Multipart` except that it enforces field exclusivity at runtime instead of compile time, as this improves usability ([#1692]) - **added:** Implement `Clone` for `CookieJar`, `PrivateCookieJar` and `SignedCookieJar` ([#1808]) - **fixed:** Add `#[must_use]` attributes to types that do nothing unless used ([#1809]) [#1692]: https://github.com/tokio-rs/axum/pull/1692 [#1802]: https://github.com/tokio-rs/axum/pull/1802 [#1808]: https://github.com/tokio-rs/axum/pull/1808 [#1809]: https://github.com/tokio-rs/axum/pull/1809 # 0.6.0 (24. February, 2022) - **breaking:** Change casing of `ProtoBuf` to `Protobuf` ([#1595]) - **breaking:** `SpaRouter` has been removed. Use `ServeDir` and `ServeFile` from `tower-http` instead: ```rust // before Router::new().merge(SpaRouter::new("/assets", "dist")); // with ServeDir Router::new().nest_service("/assets", ServeDir::new("dist")); // before with `index_file` Router::new().merge(SpaRouter::new("/assets", "dist").index_file("index.html")); // with ServeDir + ServeFile Router::new().nest_service( "/assets", ServeDir::new("dist").not_found_service(ServeFile::new("dist/index.html")), ); ``` See the [static-file-server-example] for more examples ([#1784]) [#1595]: https://github.com/tokio-rs/axum/pull/1595 [#1784]: https://github.com/tokio-rs/axum/pull/1784 [static-file-server-example]: https://github.com/tokio-rs/axum/blob/main/examples/static-file-server/src/main.rs # 0.5.0 (12. February, 2022) - **added:** Add `option_layer` for converting an `Option` into a `Layer` ([#1696]) - **added:** Implement `Layer` and `Service` for `Either` ([#1696]) - **added:** Add `TypedPath::with_query_params` ([#1744]) - **breaking:** Update to [`cookie`] 0.17 ([#1747]) [#1696]: https://github.com/tokio-rs/axum/pull/1696 [#1744]: https://github.com/tokio-rs/axum/pull/1744 [#1747]: https://github.com/tokio-rs/axum/pull/1747 [`cookie`]: https://crates.io/crates/cookie # 0.4.2 (02. December, 2022) - **fixed:** Bug fixes for `RouterExt:{route_with_tsr, route_service_with_tsr}` ([#1608]): - Redirects to the correct URI if the route contains path parameters - Keeps query parameters when redirecting - Better improved error message if adding route for `/` [#1608]: https://github.com/tokio-rs/axum/pull/1608 # 0.4.1 (29. November, 2022) - **fixed:** Fix wrong `From` impl for `Resource` ([#1589]) [#1589]: https://github.com/tokio-rs/axum/pull/1589 # 0.4.0 (25. November, 2022) - **added:** Add `RouterExt::route_with_tsr` for adding routes with an additional "trailing slash redirect" route ([#1119]) - **added:** Support chaining handlers with `HandlerCallWithExtractors::or` ([#1170]) - **added:** Add Protocol Buffer extractor and response ([#1239]) - **added:** Add `Either*` types for combining extractors and responses into a single type ([#1263]) - **added:** `WithRejection` extractor for customizing other extractors' rejections ([#1262]) - **added:** Add sync constructors to `CookieJar`, `PrivateCookieJar`, and `SignedCookieJar` so they're easier to use in custom middleware - **changed:** For methods that accept some `S: Service`, the bounds have been relaxed so the return type can be any type that implements `IntoResponse` rather than being a literal `Response` - **change:** axum-extra's MSRV is now 1.60 ([#1239]) - **breaking:** `Form` has a new rejection type ([#1496]) - **breaking:** `Query` has a new rejection type ([#1496]) - **breaking:** `Resource::nest` and `Resource::nest_collection` have been removed. You can instead convert the `Resource` into a `Router` and add additional routes as necessary ([#1086]) - **breaking:** `SignedCookieJar` and `PrivateCookieJar` now extracts the keys from the router's state, rather than extensions - **breaking:** `Resource` has a new `S` type param which represents the state ([#1155]) - **breaking:** `RouterExt::route_with_tsr` now only accepts `MethodRouter`s ([#1155]) - **added:** `RouterExt::route_service_with_tsr` for routing to any `Service` ([#1155]) [#1086]: https://github.com/tokio-rs/axum/pull/1086 [#1119]: https://github.com/tokio-rs/axum/pull/1119 [#1155]: https://github.com/tokio-rs/axum/pull/1155 [#1170]: https://github.com/tokio-rs/axum/pull/1170 [#1214]: https://github.com/tokio-rs/axum/pull/1214 [#1239]: https://github.com/tokio-rs/axum/pull/1239 [#1262]: https://github.com/tokio-rs/axum/pull/1262 [#1263]: https://github.com/tokio-rs/axum/pull/1263 [#1496]: https://github.com/tokio-rs/axum/pull/1496
0.4.0 Pre-Releases # 0.4.0-rc.3 (19. November, 2022) - **breaking:** Depend axum 0.6.0-rc.5 and axum-macros 0.3.0-rc.3 # 0.4.0-rc.2 (8. November, 2022) - **breaking:** `Form` has a new rejection type ([#1496]) - **breaking:** `Query` has a new rejection type ([#1496]) [#1496]: https://github.com/tokio-rs/axum/pull/1496 # 0.4.0-rc.1 (23. August, 2022) - **added:** Add `RouterExt::route_with_tsr` for adding routes with an additional "trailing slash redirect" route ([#1119]) - **breaking:** `Resource::nest` and `Resource::nest_collection` has been removed. You can instead convert the `Resource` into a `Router` and add additional routes as necessary ([#1086]) - **changed:** For methods that accept some `S: Service`, the bounds have been relaxed so the response type must implement `IntoResponse` rather than being a literal `Response` - **added:** Support chaining handlers with `HandlerCallWithExtractors::or` ([#1170]) - **change:** axum-extra's MSRV is now 1.60 ([#1239]) - **breaking:** `SignedCookieJar` and `PrivateCookieJar` now extracts the keys from the router's state, rather than extensions - **added:** Add Protocol Buffer extractor and response ([#1239]) - **added:** Add `Either*` types for combining extractors and responses into a single type ([#1263]) - **added:** `WithRejection` extractor for customizing other extractors' rejections ([#1262]) - **added:** Add sync constructors to `CookieJar`, `PrivateCookieJar`, and `SignedCookieJar` so they're easier to use in custom middleware - **breaking:** `Resource` has a new `S` type param which represents the state ([#1155]) - **breaking:** `RouterExt::route_with_tsr` now only accepts `MethodRouter`s ([#1155]) - **added:** `RouterExt::route_service_with_tsr` for routing to any `Service` ([#1155]) [#1086]: https://github.com/tokio-rs/axum/pull/1086 [#1119]: https://github.com/tokio-rs/axum/pull/1119 [#1155]: https://github.com/tokio-rs/axum/pull/1155 [#1170]: https://github.com/tokio-rs/axum/pull/1170 [#1214]: https://github.com/tokio-rs/axum/pull/1214 [#1239]: https://github.com/tokio-rs/axum/pull/1239 [#1262]: https://github.com/tokio-rs/axum/pull/1262 [#1263]: https://github.com/tokio-rs/axum/pull/1263
# 0.3.7 (09. August, 2022) - **fixed:** Depend on axum 0.5.15 which contains a fix for an accidental breaking change. # 0.3.6 (02. July, 2022) - **fixed:** Fix feature labels missing in generated docs ([#1137]) [#1137]: https://github.com/tokio-rs/axum/pull/1137 # 0.3.5 (27. June, 2022) - **added:** Add `JsonLines` for streaming newline delimited JSON ([#1093]) - **change:** axum-extra's MSRV is now 1.56 ([#1098]) [#1093]: https://github.com/tokio-rs/axum/pull/1093 [#1098]: https://github.com/tokio-rs/axum/pull/1098 # 0.3.4 (08. June, 2022) - **fixed:** Use `impl IntoResponse` less in docs ([#1049]) - **added:** Add `AsyncReadBody` for creating a body from a `tokio::io::AsyncRead` ([#1072]) [#1049]: https://github.com/tokio-rs/axum/pull/1049 [#1072]: https://github.com/tokio-rs/axum/pull/1072 # 0.3.3 (18. May, 2022) - **added:** Add `extract::Query` which supports multi-value items ([#1041]) - **added:** Support customizing rejections for `#[derive(TypedPath)]` ([#1012]) [#1041]: https://github.com/tokio-rs/axum/pull/1041 [#1012]: https://github.com/tokio-rs/axum/pull/1012 # 0.3.2 (15. May, 2022) - **added:** Add `extract::Form` which supports multi-value items ([#1031]) [#1031]: https://github.com/tokio-rs/axum/pull/1031 # 0.3.1 (10. May, 2022) - **fixed:** `Option` and `Result` are now supported in typed path route handler parameters ([#1001]) - **fixed:** Support wildcards in typed paths ([#1003]) - **added:** Support using a custom rejection type for `#[derive(TypedPath)]` instead of `PathRejection` ([#1012]) [#1001]: https://github.com/tokio-rs/axum/pull/1001 [#1003]: https://github.com/tokio-rs/axum/pull/1003 [#1012]: https://github.com/tokio-rs/axum/pull/1012 # 0.3.0 (27. April, 2022) - **fixed:** Don't depend on axum with default features enabled ([#913]) - **breaking:** Private and signed cookies now requires enabling the `cookie-private` and `cookie-signed` features respectively ([#949]) - **changed:** Update to tower-http 0.3 ([#965]) [#913]: https://github.com/tokio-rs/axum/pull/913 [#949]: https://github.com/tokio-rs/axum/pull/949 [#965]: https://github.com/tokio-rs/axum/pull/965 # 0.2.1 (03. April, 2022) - **added:** Re-export `SameSite` and `Expiration` from the `cookie` crate ([#898]) - **added:** Add `PrivateCookieJar` for managing private cookies ([#900]) - **added:** Add `SpaRouter` for routing setups commonly used for single page applications ([#904]) - **fixed:** Fix `SignedCookieJar` when using custom key types ([#899]) [#898]: https://github.com/tokio-rs/axum/pull/898 [#899]: https://github.com/tokio-rs/axum/pull/899 [#900]: https://github.com/tokio-rs/axum/pull/900 [#904]: https://github.com/tokio-rs/axum/pull/904 # 0.2.0 (31. March, 2022) - **added:** Add `TypedPath::to_uri` for converting the path into a `Uri` ([#790]) - **added:** Extractors and responses for dealing with cookies. See `extract::cookies` for more details ([#816]) - **breaking:** `CachedRejection` has been removed ([#699]) - **breaking:** ` as FromRequest>::Rejection` is now `T::Rejection`. ([#699]) - **breaking:** `middleware::from_fn` has been remove from axum-extra and moved into the main axum crate ([#719]) - **breaking:** `HasRoutes` has been removed. `Router::merge` now accepts `Into` ([#819]) - **breaking:** `RouterExt::with` method has been removed. Use `Router::merge` instead. It works identically ([#819]) [#699]: https://github.com/tokio-rs/axum/pull/699 [#719]: https://github.com/tokio-rs/axum/pull/719 [#790]: https://github.com/tokio-rs/axum/pull/790 [#816]: https://github.com/tokio-rs/axum/pull/816 [#819]: https://github.com/tokio-rs/axum/pull/819 # 0.1.5 (1. March, 2022) - **added:** Add `TypedPath::to_uri` for converting the path into a `Uri` ([#790]) [#790]: https://github.com/tokio-rs/axum/pull/790 # 0.1.4 (22. February, 2022) - **fix:** Depend on the right versions of axum and axum-macros ([#782]) [#782]: https://github.com/tokio-rs/axum/pull/782 # 0.1.3 (22. February, 2022) - **added:** Add type safe routing. See `axum_extra::routing::typed` for more details ([#756]) - **fix:** Depend on tower with `default_features = false` ([#666]) - **change:** `middleware::from_fn` has been deprecated and moved into the main axum crate ([#719]) [#666]: https://github.com/tokio-rs/axum/pull/666 [#719]: https://github.com/tokio-rs/axum/pull/719 [#756]: https://github.com/tokio-rs/axum/pull/756 # 0.1.2 (13. January, 2022) - **fix:** Depend on tower with `default_features = false` ([#666]) # 0.1.1 (27. December, 2021) - Add `middleware::from_fn` for creating middleware from async functions ([#656]) - Add support for returning pretty JSON response in `response::ErasedJson` ([#662]) [#656]: https://github.com/tokio-rs/axum/pull/656 [#662]: https://github.com/tokio-rs/axum/pull/662 # 0.1.0 (02. December, 2021) - Initial release. [Keep a Changelog]: https://keepachangelog.com/en/1.0.0/ [Semantic Versioning]: https://semver.org/spec/v2.0.0.html