mirror of
https://github.com/actix/actix-web.git
synced 2024-11-22 09:31:10 +00:00
fix: content type required flag (#3168)
* fix: content type required flag * clarify comments for invalid json mime type * remove pr reference --------- Co-authored-by: Rob Ede <robjtede@icloud.com>
This commit is contained in:
parent
e50bceb914
commit
9d1f75d349
2 changed files with 36 additions and 8 deletions
|
@ -6,6 +6,10 @@
|
||||||
|
|
||||||
- Updated `zstd` dependency to `0.13`.
|
- Updated `zstd` dependency to `0.13`.
|
||||||
|
|
||||||
|
### Fixed
|
||||||
|
|
||||||
|
- Fix validation of `Json` extractor when `JsonConfig::validate_content_type()` is set to false.
|
||||||
|
|
||||||
## 4.4.0
|
## 4.4.0
|
||||||
|
|
||||||
### Added
|
### Added
|
||||||
|
|
|
@ -328,14 +328,19 @@ impl<T: DeserializeOwned> JsonBody<T> {
|
||||||
ctype_required: bool,
|
ctype_required: bool,
|
||||||
) -> Self {
|
) -> Self {
|
||||||
// check content-type
|
// check content-type
|
||||||
let can_parse_json = if let Ok(Some(mime)) = req.mime_type() {
|
let can_parse_json = match (ctype_required, req.mime_type()) {
|
||||||
mime.subtype() == mime::JSON
|
(true, Ok(Some(mime))) => {
|
||||||
|| mime.suffix() == Some(mime::JSON)
|
mime.subtype() == mime::JSON
|
||||||
|| ctype_fn.map_or(false, |predicate| predicate(mime))
|
|| mime.suffix() == Some(mime::JSON)
|
||||||
} else {
|
|| ctype_fn.map_or(false, |predicate| predicate(mime))
|
||||||
// if `ctype_required` is false, assume payload is
|
}
|
||||||
// json even when content-type header is missing
|
|
||||||
!ctype_required
|
// if content-type is expected but not parsable as mime type, bail
|
||||||
|
(true, _) => false,
|
||||||
|
|
||||||
|
// if content-type validation is disabled, assume payload is JSON
|
||||||
|
// even when content-type header is missing or invalid mime type
|
||||||
|
(false, _) => true,
|
||||||
};
|
};
|
||||||
|
|
||||||
if !can_parse_json {
|
if !can_parse_json {
|
||||||
|
@ -725,6 +730,25 @@ mod tests {
|
||||||
assert!(s.is_ok())
|
assert!(s.is_ok())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[actix_rt::test]
|
||||||
|
async fn test_json_ignoring_content_type() {
|
||||||
|
let (req, mut pl) = TestRequest::default()
|
||||||
|
.insert_header((
|
||||||
|
header::CONTENT_LENGTH,
|
||||||
|
header::HeaderValue::from_static("16"),
|
||||||
|
))
|
||||||
|
.insert_header((
|
||||||
|
header::CONTENT_TYPE,
|
||||||
|
header::HeaderValue::from_static("invalid/value"),
|
||||||
|
))
|
||||||
|
.set_payload(Bytes::from_static(b"{\"name\": \"test\"}"))
|
||||||
|
.app_data(JsonConfig::default().content_type_required(false))
|
||||||
|
.to_http_parts();
|
||||||
|
|
||||||
|
let s = Json::<MyObject>::from_request(&req, &mut pl).await;
|
||||||
|
assert!(s.is_ok());
|
||||||
|
}
|
||||||
|
|
||||||
#[actix_rt::test]
|
#[actix_rt::test]
|
||||||
async fn test_with_config_in_data_wrapper() {
|
async fn test_with_config_in_data_wrapper() {
|
||||||
let (req, mut pl) = TestRequest::default()
|
let (req, mut pl) = TestRequest::default()
|
||||||
|
|
Loading…
Reference in a new issue