- Ensure
actix-http
dependency uses sameserde_urlencoded
.
- Add
Either<A, B>
extractor helper. #1788
- Upgrade
serde_urlencoded
to0.7
. #1773
- Implement
exclude_regex
for Logger middleware. #1723 - Add request-local data extractor
web::ReqData
. #1748 - Add ability to register closure for request middleware logging. #1749
- Add
app_data
toServiceConfig
. [#1757] - Expose
on_connect
for access to the connection stream before request is handled. #1754
- Updated actix-web-codegen dependency for access to new
#[route(...)]
multi-method macro. - Print non-configured
Data<T>
type when attempting extraction. #1743 - Re-export bytes::Buf{Mut} in web module. #1750
- Upgrade
pin-project
to1.0
.
- Add
TrailingSlash::MergeOnly
behaviour toNormalizePath
, which allowsNormalizePath
to retain any trailing slashes. #1695 - Remove bound
std::marker::Sized
fromweb::Data
to support storingArc<dyn Trait>
viaweb::Data::from
#1710
ResourceMap
debug printing is no longer infinitely recursive. #1708
NormalizePath
when used withTrailingSlash::Trim
no longer trims the root path "/". #1678
middleware::normalize::TrailingSlash
enum is now accessible. #1673
- No significant changes from
3.0.0-beta.4
.
middleware::NormalizePath
now has configurable behaviour for either always having a trailing slash, or as the new addition, always trimming trailing slashes. #1639
- Update actix-codec and actix-utils dependencies. #1634
FormConfig
andJsonConfig
configurations are now also considered when set usingApp::data
. #1641HttpServer::maxconn
is renamed to the more expressiveHttpServer::max_connections
. #1655HttpServer::maxconnrate
is renamed to the more expressiveHttpServer::max_connection_rate
. #1655
- Update
rustls
to 0.18
PayloadConfig
is now also considered inBytes
andString
extractors when set usingApp::data
. #1610web::Path
now has a public representation:web::Path(pub T)
that enables destructuring. #1594ServiceRequest::app_data
allows retrieval of non-Data data without splitting into parts to accessHttpRequest
which already allows this. #1618- Re-export all error types from
awc
. #1621 - MSRV is now 1.42.0.
- Memory leak of app data in pooled requests. #1609
- Re-export
actix_rt::main
asactix_web::main
. HttpRequest::match_pattern
andServiceRequest::match_pattern
for extracting the matched resource pattern.HttpRequest::match_name
andServiceRequest::match_name
for extracting matched resource name.
- Fix actix_http::h1::dispatcher so it returns when HW_BUFFER_SIZE is reached. Should reduce peak memory consumption during large uploads. [#1550]
- Migrate cookie handling to
cookie
crate. Actix-web no longer requiresring
dependency. - MSRV is now 1.41.1
NormalizePath
improved consistency when path needs slashes added and removed.
- Add option to create
Data<T>
fromArc<T>
#1509
- Resources and Scopes can now access non-overridden data types set on App (or containing scopes) when setting their own data. #1486
- Fix audit issue logging by default peer address #1485
- Bump minimum supported Rust version to 1.40
- Replace deprecated
net2
crate withsocket2
{Resource,Scope}::default_service(f)
handlers now support app data extraction. #1452- Implement
std::error::Error
for our custom errors #1422 - NormalizePath middleware now appends trailing / so that routes of form /example/ respond to /example requests. #1433
- Remove the
failure
feature and support.
- Add helper function for creating routes with
TRACE
method guardweb::trace()
- Add convenience functions
test::read_body_json()
andtest::TestRequest::send_request()
for testing.
- Use
sha-1
crate instead of unmaintainedsha1
crate - Skip empty chunks when returning response from a
Stream
#1308 - Update the
time
dependency to 0.2.7 - Update
actix-tls
dependency to 2.0.0-alpha.1 - Update
rustls
dependency to 0.17
-
Rename
HttpServer::start()
toHttpServer::run()
-
Allow to gracefully stop test server via
TestServer::stop()
-
Allow to specify multi-patterns for resources
-
Move
BodyEncoding
todev
module #1220 -
Allow to set
peer_addr
for TestRequest #1074 -
Make web::Data deref to Arc #1214
-
Rename
App::register_data()
toApp::app_data()
-
HttpRequest::app_data<T>()
returnsOption<&T>
instead ofOption<&Data<T>>
- Fix
AppConfig::secure()
is always false. #1202
- Fixed compilation with default features off
- Add test server,
test::start()
andtest::start_with()
- Delete HttpServer::run(), it is not useful with async/await
- Migrate to tokio 0.2
-
Migrated to
std::future
-
Remove implementation of
Responder
for()
. (#1167)
- Add
Payload::into_inner
method and make storeddef::Payload
public. (#1110)
- Support
Host
guards when theHost
header is unset (e.g. HTTP/2 requests) (#1129)
-
Add
Scope::register_data
andResource::register_data
methods, parallel toApp::register_data
. -
Add
middleware::Condition
that conditionally enables another middleware -
Allow to re-construct
ServiceRequest
fromHttpRequest
andPayload
-
Add
HttpServer::listen_uds
for ability to listen on UDS FD rather than path, which is useful for example with systemd.
-
Make UrlEncodedError::Overflow more informative
-
Use actix-testing for testing utils
- Request Extensions leak #1062
-
Re-implement Host predicate (#989)
-
Form implements Responder, returning a
application/x-www-form-urlencoded
response -
Add
into_inner
toData
-
Add
test::TestRequest::set_form()
convenience method to automatically serialize data and set the header in test requests.
-
Query
payload madepub
. Allows user to pattern-match the payload. -
Enable
rust-tls
feature for client #1045 -
Update serde_urlencoded to 0.6.1
-
Update url to 2.1
-
Unix domain sockets (HttpServer::bind_uds) #92
-
Actix now logs errors resulting in "internal server error" responses always, with the
error
logging level
- Restored logging of errors through the
Logger
middleware
-
Add
Responder
impl for(T, StatusCode) where T: Responder
-
Allow to access app's resource map via
ServiceRequest::resource_map()
andHttpRequest::resource_map()
methods.
- Upgrade
rand
dependency version to 0.7
- Support asynchronous data factories #850
- Use
encoding_rs
crate instead of unmaintainedencoding
crate
-
Move cors middleware to
actix-cors
crate. -
Move identity middleware to
actix-identity
crate.
-
Add support for PathConfig #903
-
Add
middleware::identity::RequestIdentity
trait toget_identity
fromHttpMessage
.
-
Move cors middleware to
actix-cors
crate. -
Move identity middleware to
actix-identity
crate. -
Disable default feature
secure-cookies
. -
Allow to test an app that uses async actors #897
-
Re-apply patch from #637 #894
- HttpRequest::url_for is broken with nested scopes #915
-
Add
Scope::configure()
method. -
Add
ServiceRequest::set_payload()
method. -
Add
test::TestRequest::set_json()
convenience method to automatically serialize data and set header in test requests. -
Add macros for head, options, trace, connect and patch http methods
- Drop an unnecessary
Option<_>
indirection aroundServerBuilder
fromHttpServer
. #863
-
Fix Logger request time format, and use rfc3339. #867
-
Clear http requests pool on app service drop #860
- Add
Query<T>::from_query()
to extract parameters from a query string. #846 QueryConfig
, similar toJsonConfig
for customizing error handling of query extractors.
JsonConfig
is nowSend + Sync
, this implies thaterror_handler
must beSend + Sync
too.
- Codegen with parameters in the path only resolves the first registered endpoint #841
- Allow to set/override app data on scope level
App::configure
take anFnOnce
instead ofFn
- Upgrade actix-net crates
- Add helper function for executing futures
test::block_fn()
-
Extractor configuration could be registered with
App::data()
or withResource::data()
#775 -
Route data is unified with app data,
Route::data()
moved to resource level toResource::data()
-
CORS handling without headers #702
-
Allow to construct
Data
instances to avoid doubleArc
forSend + Sync
types.
- Fix
NormalizePath
middleware impl #806
App::data_factory()
is deleted.
-
Add raw services support via
web::service()
-
Add helper functions for reading response body
test::read_body()
-
Add support for
remainder match
(i.e "/path/{tail}*") -
Extend
Responder
trait, allow to override status code and headers. -
Store visit and login timestamp in the identity cookie #502
.to_async()
handler can returnResponder
type #792
- Fix async web::Data factory handling
-
Add helper functions for reading test response body,
test::read_response()
and test::read_response_json()` -
Add
.peer_addr()
#744 -
Add
NormalizePath
middleware
-
Rename
RouterConfig
toServiceConfig
-
Rename
test::call_success
totest::call_service
-
Removed
ServiceRequest::from_parts()
as it is unsafe to create from parts. -
CookieIdentityPolicy::max_age()
accepts value in seconds
- Fixed
TestRequest::app_data()
-
Allow to use any service as default service.
-
Remove generic type for request payload, always use default.
-
Removed
Decompress
middleware. Bytes, String, Json, Form extractors automatically decompress payload. -
Make extractor config type explicit. Add
FromRequest::Config
associated type.
- Added async io
TestBuffer
for testing.
- Removed native-tls support
-
App::configure()
allow to offload app configuration to different methods -
Added
URLPath
option for logger -
Added
ServiceRequest::app_data()
, returnsData<T>
-
Added
ServiceFromRequest::app_data()
, returnsData<T>
-
FromRequest
trait refactoring -
Move multipart support to actix-multipart crate
- Fix body propagation in Response::from_error. #760
-
Renamed
TestRequest::to_service()
toTestRequest::to_srv_request()
-
Renamed
TestRequest::to_response()
toTestRequest::to_srv_response()
-
Removed
Deref
impls
- Removed unused
actix_web::web::md()
- rustls support
-
use forked cookie
-
multipart::Field renamed to MultipartField
-
Complete architecture re-design.
-
Return 405 response if no matching route found within resource #538