Skip to content

Commit 4bb62f8

Browse files
committed
Request bodies moved out of parameters
1 parent 28d39ae commit 4bb62f8

File tree

1 file changed

+97
-67
lines changed

1 file changed

+97
-67
lines changed

versions/3.0.md

Lines changed: 97 additions & 67 deletions
Original file line numberDiff line numberDiff line change
@@ -346,7 +346,8 @@ Field Name | Type | Description
346346
<a name="pathItemHost"></a>host | `string` | The host (name or ip) serving the path. This optional value will override the top-level [host](#oasHost) if present. This MUST be the host only and does not include the scheme nor sub-paths. It MAY include a port. If the `host` is not included, the host serving the documentation is to be used (including the port). The `host` does not support [path templating](#pathTemplating).
347347
<a name="pathItemBasePath"></a>basePath | `string` | The base path on which the API is served, which is relative to the [`host`](#pathItemHost). This optional value will override the top-level [basePath](#oasBasePath) if present. If it is not included, the API is served directly under the `host`. The value MUST start with a leading slash (`/`). The `basePath` does not support [path templating](#pathTemplating).
348348
<a name="pathItemSchemes"></a>schemes | [`string`] | The transfer protocol of the API. Values MUST be from the list: `"http"`, `"https"`, `"ws"`, `"wss"`. This optional value will override the top-level [schemes](#oasSchemes) if present. If the `schemes` is not included, the default scheme to be used is the one used to access the OpenAPI definition itself.
349-
<a name="pathItemParameters"></a>parameters | [[Parameter Object](#parameterObject) <span>&#124;</span> [Reference Object](#referenceObject)] | A list of parameters that are applicable for all the operations described under this path. These parameters can be overridden at the operation level, but cannot be removed there. The list MUST NOT include duplicated parameters. A unique parameter is defined by a combination of a [name](#parameterName) and [___location](#parameterIn). The list can use the [Reference Object](#referenceObject) to link to parameters that are defined at the [OpenAPI Object's parameters](#oasParameters). There can be one "body" parameter at most.
349+
<a name="pathItemParameters"></a>parameters | [[Parameter Object](#parameterObject) <span>&#124;</span> [Reference Object](#referenceObject)] | A list of parameters that are applicable for all the operations described under this path. These parameters can be overridden at the operation level, but cannot be removed there. The list MUST NOT include duplicated parameters. A unique parameter is defined by a combination of a [name](#parameterName) and [___location](#parameterIn). The list can use the [Reference Object](#referenceObject) to link to parameters that are defined at the [OpenAPI Object's parameters](#oasParameters).
350+
<a name="pathItemRequestBody"></a>requestBody | [[Request Body Object](#requestBodyObject) <span>&#124;</span> [Reference Object](#referenceObject)] | The request body applicable for all the operations described under this path. This request body can be overriden at the operation level, but cannot be removed there.
350351

351352
##### Patterned Fields
352353

@@ -445,7 +446,8 @@ Field Name | Type | Description
445446
<a name="operationId"></a>operationId | `string` | Unique string used to identify the operation. The id MUST be unique among all operations described in the API. Tools and libraries MAY use the operationId to uniquely identify an operation, therefore, it is recommended to follow common programming naming conventions.
446447
<a name="operationConsumes"></a>consumes | [`string`] | A list of MIME types the operation can consume. This overrides the [`consumes`](#oasConsumes) definition at the OpenAPI Object. An empty value MAY be used to clear the global definition. Value MUST be as described under [Mime Types](#mimeTypes).
447448
<a name="operationProduces"></a>produces | [`string`] | A list of MIME types the operation can produce. This overrides the [`produces`](#oasProduces) definition at the OpenAPI Object. An empty value MAY be used to clear the global definition. Value MUST be as described under [Mime Types](#mimeTypes).
448-
<a name="operationParameters"></a>parameters | [[Parameter Object](#parameterObject) <span>&#124;</span> [Reference Object](#referenceObject)] | A list of parameters that are applicable for this operation. If a parameter is already defined at the [Path Item](#pathItemParameters), the new definition will override it, but can never remove it. The list MUST NOT include duplicated parameters. A unique parameter is defined by a combination of a [name](#parameterName) and [___location](#parameterIn). The list can use the [Reference Object](#referenceObject) to link to parameters that are defined at the [OpenAPI Object's parameters](#oasParameters). There can be one "body" parameter at most.
449+
<a name="operationParameters"></a>parameters | [[Parameter Object](#parameterObject) <span>&#124;</span> [Reference Object](#referenceObject)] | A list of parameters that are applicable for this operation. If a parameter is already defined at the [Path Item](#pathItemParameters), the new definition will override it, but can never remove it. The list MUST NOT include duplicated parameters. A unique parameter is defined by a combination of a [name](#parameterName) and [___location](#parameterIn). The list can use the [Reference Object](#referenceObject) to link to parameters that are defined at the [OpenAPI Object's parameters](#oasParameters).
450+
<a name="operationRequestBody"></a>body | [[Request Body Object](#requestBodyObject) <span>&#124;</span> [Reference Object](#referenceObject)] | The request body applicable for this operation. If a request body is already defined at the [Path Item](#pathItemParameters), the new definition will override it, but can never remove it.
449451
<a name="operationResponses"></a>responses | [Responses Object](#responsesObject) | **Required.** The list of possible responses as they are returned from executing this operation.
450452
<a name="operationSchemes"></a>schemes | [`string`] | The transfer protocol for the operation. Values MUST be from the list: `"http"`, `"https"`, `"ws"`, `"wss"`. The value overrides the OpenAPI Object [`schemes`](#oasSchemes) definition.
451453
<a name="operationDeprecated"></a>deprecated | `boolean` | Declares this operation to be deprecated. Usage of the declared operation should be refrained. Default value is `false`.
@@ -595,25 +597,24 @@ Describes a single operation parameter.
595597

596598
A unique parameter is defined by a combination of a [name](#parameterName) and [___location](#parameterIn).
597599

598-
There are six possible parameter types.
600+
There are five possible parameter types.
599601
* Path - Used together with [Path Templating](#pathTemplating), where the parameter value is actually part of the operation's URL. This does not include the host or base path of the API. For example, in `/items/{itemId}`, the path parameter is `itemId`.
600602
* Query - Parameters that are appended to the URL. For example, in `/items?id=###`, the query parameter is `id`.
601603
* Header - Custom headers that are expected as part of the request.
602-
* Body - The payload that's appended to the HTTP request. Since there can only be one payload, there can only be *one* body parameter. The name of the body parameter has no effect on the parameter itself and is used for documentation purposes only. Since Form parameters are also in the payload, body and form parameters cannot exist together for the same operation.
603604
* Form - Used to describe the payload of an HTTP request when either `application/x-www-form-urlencoded`, `multipart/form-data` or both are used as the content type of the request (in the OpenAPI Specification's definition, the [`consumes`](#operationConsumes) property of an operation). This is the only parameter type that can be used to send files, thus supporting the `file` type. Since form parameters are sent in the payload, they cannot be declared together with a body parameter for the same operation. Form parameters have a different format based on the content-type used (for further details, consult http://www.w3.org/TR/html401/interact/forms.html#h-17.13.4):
604605
* `application/x-www-form-urlencoded` - Similar to the format of Query parameters but as a payload. For example, `foo=1&bar=swagger` - both `foo` and `bar` are form parameters. This is normally used for simple parameters that are being transferred.
605606
* `multipart/form-data` - each parameter takes a section in the payload with an internal header. For example, for the header `Content-Disposition: form-data; name="submit-name"` the name of the parameter is `submit-name`. This type of form parameters is more commonly used for file transfers.
606607

607608
* Cookie - Used to pass a specific cookie value to the API.
608609

609610

610-
For complex parameter schemas, a serialization strategy is required. For parameter of type `in: body`, the serialization will be handled by the `consumes` attribute. For all other types, a serialization strategy must be declared.
611+
For complex parameter schemas, a serialization strategy is required. For all types, a serialization strategy must be declared.
611612

612613
##### Fixed Fields
613614
Field Name | Type | Description
614615
---|:---:|---
615616
<a name="parameterName"></a>name | `string` | **Required.** The name of the parameter. Parameter names are *case sensitive*. <ul><li>If [`in`](#parameterIn) is `"path"`, the `name` field MUST correspond to the associated path segment from the [path](#pathsPath) field in the [Paths Object](#pathsObject). See [Path Templating](#pathTemplating) for further information.<li>For all other cases, the `name` corresponds to the parameter name used based on the [`in`](#parameterIn) property.</ul>
616-
<a name="parameterIn"></a>in | `string` | **Required.** The ___location of the parameter. Possible values are "query", "header", "path", "formData", "body", or "cookie".
617+
<a name="parameterIn"></a>in | `string` | **Required.** The ___location of the parameter. Possible values are "query", "header", "path", "formData" or "cookie".
617618
<a name="parameterDescription"></a>description | `string` | A brief description of the parameter. This could contain examples of use. [GFM syntax](https://help.github.com/articles/github-flavored-markdown) can be used for rich text representation.
618619
<a name="parameterRequired"></a>required | `boolean` | Determines whether this parameter is mandatory. If the parameter is [`in`](#parameterIn) "path", this property is **required** and its value MUST be `true`. Otherwise, the property MAY be included and its default value is `false`.
619620
<a name="parameterDeprecated"></a> deprecated | `boolean` | Specifies that a parameter is deprecated and should be transitioned out of usage.
@@ -628,59 +629,6 @@ Field Pattern | Type | Description
628629

629630
##### Parameter Object Examples
630631

631-
###### Body Parameters
632-
633-
A body parameter with a referenced schema definition (normally for a model definition):
634-
```js
635-
{
636-
"name": "user",
637-
"in": "body",
638-
"description": "user to add to the system",
639-
"required": true,
640-
"schema": {
641-
"$ref": "#/definitions/User"
642-
}
643-
}
644-
```
645-
646-
```yaml
647-
name: user
648-
in: body
649-
description: user to add to the system
650-
required: true
651-
schema:
652-
$ref: '#/definitions/User'
653-
```
654-
655-
A body parameter that is an array of string values:
656-
```js
657-
{
658-
"name": "user",
659-
"in": "body",
660-
"description": "user to add to the system",
661-
"required": true,
662-
"schema": {
663-
"type": "array",
664-
"items": {
665-
"type": "string"
666-
}
667-
}
668-
}
669-
```
670-
671-
```yaml
672-
name: user
673-
in: body
674-
description: user to add to the system
675-
required: true
676-
schema:
677-
type: array
678-
items:
679-
type: string
680-
```
681-
682-
###### Other Parameters
683-
684632
A header parameter with an array of 64 bit integer numbers:
685633

686634
```js
@@ -786,9 +734,89 @@ schema:
786734
type: file
787735
```
788736

737+
#### <a name="requestBodyObject"></a>Request Body Object
738+
739+
Describes a single request body.
740+
741+
If the `requestBody` attribute is not present, or `schema` is not defined, the request body is not required.
742+
743+
The serialization of the request body should be specified by the `consumes` attribute.
744+
745+
##### Fixed Fields
746+
Field Name | Type | Description
747+
---|:---:|---
748+
<a name="requestBodyDescription"></a>description | `string` | A brief description of the request body. This could contain examples of use. [GFM syntax](https://help.github.com/articles/github-flavored-markdown) can be used for rich text representation.
749+
<a name="requestBodySchema"></a>schema | [Schema Object](#schemaObject) | The schema defining the type used for the request body.
750+
<a name="requestBodyExamples"></a>examples | [Examples Object](#examplesObject) | Examples of the request body, referenced by mime type.
751+
752+
753+
##### Patterned Fields
754+
Field Pattern | Type | Description
755+
---|:---:|---
756+
<a name="parameterExtensions"></a>^x- | Any | Allows extensions to the OpenAPI Schema. The field name MUST begin with `x-`, for example, `x-internal-id`. The value can be `null`, a primitive, an array or an object. See [Vendor Extensions](#vendorExtensions) for further details.
757+
758+
759+
##### Request Body Examples
760+
761+
A request body with a referenced model definition.
762+
```js
763+
{
764+
"description": "user to add to the system",
765+
"schema": {
766+
"$ref": "#/definitions/User"
767+
},
768+
"examples": {
769+
"application/json": {
770+
"$ref": 'http://foo.bar#/examples/address-example.json'
771+
'application/xml':
772+
$ref: 'http://foo.bar#/examples/address-example.xml'
773+
'text/plain':
774+
$ref: 'http://foo.bar#/examples/address-example.txt'
775+
default:
776+
$ref: 'http://foo.bar#/examples/address-example.whatever'
777+
}
778+
```
779+
780+
```yaml
781+
description: user to add to the system
782+
schema:
783+
$ref: '#/definitions/User'
784+
examples:
785+
'application/json':
786+
$ref: 'http://foo.bar/examples/user-example.json'
787+
'application/xml':
788+
$ref: 'http://foo.bar/examples/user-example.xml'
789+
'text/plain':
790+
$ref: 'http://foo.bar/examples/user-example.txt'
791+
default:
792+
$ref: 'http://foo.bar/examples/user-example.whatever'
793+
```
794+
795+
A body parameter that is an array of string values:
796+
```js
797+
{
798+
"description": "user to add to the system",
799+
"schema": {
800+
"type": "array",
801+
"items": {
802+
"type": "string"
803+
}
804+
}
805+
}
806+
```
807+
808+
```yaml
809+
description: user to add to the system
810+
required: true
811+
schema:
812+
type: array
813+
items:
814+
type: string
815+
```
816+
789817
#### <a name="itemsObject"></a>Items Object
790818

791-
A limited subset of JSON-Schema's items object. It is used by parameter definitions that are not located [`in`](#parameterIn) `"body"`.
819+
A limited subset of JSON-Schema's items object. It is used by parameter definitions.
792820

793821
##### Fixed Fields
794822
Field Name | Type | Description
@@ -1060,7 +1088,7 @@ X-Rate-Limit-Reset:
10601088

10611089
#### <a name="exampleObject"></a>Example Object
10621090

1063-
Allows sharing examples for operation responses.
1091+
Allows sharing examples for operation requests and responses.
10641092

10651093
##### Patterned Fields
10661094
Field Pattern | Type | Description
@@ -1069,7 +1097,7 @@ Field Pattern | Type | Description
10691097

10701098
##### Example Object Example
10711099

1072-
Example response for application/json mimetype of a Pet data type:
1100+
Example request or response for application/json mimetype of a Pet data type:
10731101

10741102
```js
10751103
{
@@ -1173,7 +1201,7 @@ Anywhere an `example` may be given, allow a $ref object. This does mean that `e
11731201

11741202
In locations where the field being provided an `example` is a scalar value _or_ has it's content-type definition determined by a higher-level construct (a response payload, for example, uses the `produces` attribute to select the correct message format), the plural `examples` shall be used, and the payload format be specified as a key to the example.
11751203

1176-
In all cases, the payload is expected to be compatible with the type schema for the value that it is accompanying. Tooling vendors may choose to valide compatibility automatically, and reject the example value(s) if they are not compatible.
1204+
In all cases, the payload is expected to be compatible with the type schema for the value that it is accompanying. Tooling vendors may choose to validate compatibility automatically, and reject the example value(s) if they are not compatible.
11771205

11781206
```yaml
11791207
# in a model
@@ -1184,10 +1212,8 @@ definitions:
11841212
example:
11851213
$ref: http://foo.bar#/examples/name-example
11861214
1187-
# in a parameter, note the plural `examples` as the content-type is set by `consumes`:
1188-
parameters:
1189-
- name: address
1190-
in: body
1215+
# in a request body, note the plural `examples` as the content-type is set by `consumes`:
1216+
requestBody:
11911217
schema:
11921218
$ref: '#/definitions/Address'
11931219
examples:
@@ -1199,6 +1225,10 @@ definitions:
11991225
$ref: 'http://foo.bar#/examples/address-example.txt'
12001226
default:
12011227
$ref: 'http://foo.bar#/examples/address-example.whatever'
1228+
1229+
# in a parameter
1230+
1231+
parameters:
12021232
- name: 'zip'
12031233
in: 'query'
12041234
type: 'string'

0 commit comments

Comments
 (0)