You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
This splits the Encoding Object's fixed fields table
to make the usage more clear, and closer to how it is presented
for the Parameter and Header Objects
Copy file name to clipboardExpand all lines: versions/3.0.4.md
+25-19
Original file line number
Diff line number
Diff line change
@@ -1621,14 +1621,14 @@ A single encoding definition applied to a single schema property; encodings are
1621
1621
Properties are correlated with `multipart` parts using the `name` parameter to `Content-Disposition: form-data`, and with `application/x-www-form-urlencoded` using the query string paramter names.
1622
1622
In both cases, their order is implementation-defined.
1623
1623
1624
-
##### Fixed Fields
1624
+
###### Common Fixed Fields
1625
+
1626
+
These fields MAY be used either with or without the RFC6570-style serialization fields defined in the next section below.
1627
+
1625
1628
Field Name | Type | Description
1626
1629
---|:---:|---
1627
1630
<a name="encodingContentType"></a>contentType | `string` | The `Content-Type` for encoding a specific property. The value is a comma-separated list, each element of which is either a specific media type (e.g. `image/png`) or a wildcard media type (e.g. `image/*`). Default value depends on the property type as shown in the table below.
1628
1631
<a name="encodingHeaders"></a>headers | Map[`string`, [Header Object](#headerObject) \| [Reference Object](#referenceObject)] | A map allowing additional information to be provided as headers. `Content-Type` is described separately and SHALL be ignored in this section. This property SHALL be ignored if the request body media type is not a `multipart`.
1629
-
<a name="encodingStyle"></a>style | `string` | Describes how a specific property value will be serialized depending on its type. See [Parameter Object](#parameterObject) for details on the [`style`](#parameterStyle) property. The behavior follows the same values as `query` parameters, including default values. This property SHALL be ignored if the request body media type is not `application/x-www-form-urlencoded`.
1630
-
<a name="encodingExplode"></a>explode | `boolean` | When this is true, property values of type `array` or `object` generate separate parameters for each value of the array, or key-value-pair of the map. For other types of properties this property has no effect. When [`style`](#encodingStyle) is `form`, the default value is `true`. For all other styles, the default value is `false`. This property SHALL be ignored if the request body media type is not `application/x-www-form-urlencoded`.
1631
-
<a name="encodingAllowReserved"></a>allowReserved | `boolean` | When this is true, parameter values are serialized using reserved expansion, as defined by [RFC6570](https://datatracker.ietf.org/doc/html/rfc6570#autoid-20), which allows [RFC3986's reserved character set](https://datatracker.ietf.org/doc/html/rfc3986#autoid-13), as well as percent-encoded triples, to pass through unchanged, while still percent-encoding all other disallowed characters (including `%` outside of percent-encoded triples). Applications are still responsible for percent-encoding reserved characters that are [not allowed in the query string](https://datatracker.ietf.org/doc/html/rfc3986#autoid-24) (`[`, `]`, `#`), or have a special meaning in `application/x-www-form-urlencoded` (`-`, `&`, `+`); see Appendices [C](#usingRFC6570Implementations) and [E](#percentEncodingAndFormMediaTypes) for details. This property only applies to parameters with an `in` value of `query`. The default value is `false`.
1632
1632
1633
1633
This object MAY be extended with [Specification Extensions](#specificationExtensions).
1634
1634
@@ -1641,8 +1641,29 @@ Property Type | Property Format | Default `contentType`
1641
1641
`object`| _n/a_ | `application/json`
1642
1642
`array`| _n/a_ | according to the `type` and `format` of the `items` schema
1643
1643
1644
+
##### Fixed Fields for RFC6570-style Serialization
1645
+
1646
+
Field Name | Type | Description
1647
+
---|:---:|---
1648
+
<a name="encodingStyle"></a>style | `string` | Describes how a specific property value will be serialized depending on its type. See [Parameter Object](#parameterObject) for details on the [`style`](#parameterStyle) property. The behavior follows the same values as `query` parameters, including default values. This property SHALL be ignored if the request body media type is not `application/x-www-form-urlencoded`.
1649
+
<a name="encodingExplode"></a>explode | `boolean` | When this is true, property values of type `array` or `object` generate separate parameters for each value of the array, or key-value-pair of the map. For other types of properties this property has no effect. When [`style`](#encodingStyle) is `form`, the default value is `true`. For all other styles, the default value is `false`. This property SHALL be ignored if the request body media type is not `application/x-www-form-urlencoded`.
1650
+
<a name="encodingAllowReserved"></a>allowReserved | `boolean` | When this is true, parameter values are serialized using reserved expansion, as defined by [RFC6570](https://datatracker.ietf.org/doc/html/rfc6570#autoid-20), which allows [RFC3986's reserved character set](https://datatracker.ietf.org/doc/html/rfc3986#autoid-13), as well as percent-encoded triples, to pass through unchanged, while still percent-encoding all other disallowed characters (including `%` outside of percent-encoded triples). Applications are still responsible for percent-encoding reserved characters that are [not allowed in the query string](https://datatracker.ietf.org/doc/html/rfc3986#autoid-24) (`[`, `]`, `#`), or have a special meaning in `application/x-www-form-urlencoded` (`-`, `&`, `+`); see Appendices [C](#usingRFC6570Implementations) and [E](#percentEncodingAndFormMediaTypes) for details. This property only applies to parameters with an `in` value of `query`. The default value is `false`.
1651
+
1644
1652
See also [Appendix C: Using RFC6570 Implementations](#usingRFC6570Implementations) for additional guidance.
1645
1653
1654
+
The role of `contentType` with `application/x-www-form-urlencoded` request bodies was not described in detail in version 3.0.3 and earlier of this specification.
1655
+
To match the intent of these fields and be compatible with version 3.1 of this specification, it is RECOMMENDED that whenever any of `style`, `explode`, or `allowReserved` are present with an explicit value:
1656
+
1657
+
* The value of `contentType`, whether it is explicitly defined or has the default value, is to be ignored
1658
+
* If any of `style`, `explode`, or `allowReserved` are _not_ present with explicit values, then they are to be treated as if they were present with their default values
1659
+
1660
+
However, if all three of `style`, `explode`, and `allowReserved` fields are absent, it is RECOMMENDED that:
1661
+
1662
+
* All three keywords are to be entirely ignored, rather than treated as having their default values
1663
+
* Encoding is to be based on `contentType` alone, whether it is present with an explicit value or absent and treated as having its default value
1664
+
1665
+
This makes the presence of at least one of `style`, `explode`, or `allowReserved` with an explicit value equivalent to using `schema` with `in: query` Parameter Objects, and their absence the equivalent of using `content`, but with the media type specified in `contentType` rather than through a Media Type Object.
1666
+
1646
1667
###### Encoding `multipart` Media Types
1647
1668
1648
1669
Properties are correlated with `multipart` parts using the `name` parameter to `Content-Disposition: form-data`, and their order is implementation-defined.
@@ -1660,21 +1681,6 @@ Note also that `Content-Transfer-Encoding` is deprecated for `multipart/form-dat
1660
1681
Using `format: byte` for a multipart field is equivalent to setting `Content-Transfer-Encoding: base64`.
1661
1682
If `format: byte` is used along with setting a different `Content-Transfer-Encoding` value with the `headers` field, the result is undefined.
1662
1683
1663
-
###### Encoding the `application/x-www-form-urlencoded` Media Type
1664
-
1665
-
The role of `contentType` with `application/x-www-form-urlencoded` request bodies was not described in detail in version 3.0.3 and earlier of this specification.
1666
-
To match the intent of these fields and be compatible with version 3.1 of this specification, it is RECOMMENDED that whenever any of `style`, `explode`, or `allowReserved` are present with an explicit value:
1667
-
1668
-
* The value of `contentType`, whether it is explicitly defined or has the default value, is to be ignored
1669
-
* If any of `style`, `explode`, or `allowReserved` are _not_ present with explicit values, then they are to be treated as if they were present with their default values
1670
-
1671
-
However, if all three of `style`, `explode`, and `allowReserved` fields are absent, it is RECOMMENDED that:
1672
-
1673
-
* All three keywords are to be entirely ignored, rather than treated as having their default values
1674
-
* Encoding is to be based on `contentType` alone, whether it is present with an explicit value or absent and treated as having its default value
1675
-
1676
-
This makes the presence of at least one of `style`, `explode`, or `allowReserved` with an explicit value equivalent to using `schema` with `in: query` Parameter Objects, and their absence the equivalent of using `content`, but with the media type specified in `contentType` rather than through a Media Type Object.
0 commit comments