From 1987e69a0e44f5e9526edc0e9f2df3ed19e8565f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Fran=20M=C3=A9ndez?= Date: Mon, 29 May 2023 08:52:03 +0200 Subject: [PATCH] feat: simplify parameter object (#935) --- spec/asyncapi.md | 80 ++++++++++++++++-------------------------------- 1 file changed, 27 insertions(+), 53 deletions(-) diff --git a/spec/asyncapi.md b/spec/asyncapi.md index d9c99717..c7d3dc84 100644 --- a/spec/asyncapi.md +++ b/spec/asyncapi.md @@ -1014,48 +1014,34 @@ location: $message.header#/replyTo #### Parameters Object -Describes a map of parameters included in a channel name. +Describes a map of parameters included in a channel address. -This map MUST contain all the parameters used in the parent channel name. +This map MUST contain all the parameters used in the parent channel address. ##### Patterned Fields Field Pattern | Type | Description ---|:---:|--- -`^[A-Za-z0-9_\-]+$` | [Parameter Object](#parameterObject) | [Reference Object](#referenceObject) | The key represents the name of the parameter. It MUST match the parameter name used in the parent channel name. +`^[A-Za-z0-9_\-]+$` | [Parameter Object](#parameterObject) | [Reference Object](#referenceObject) | The key represents the name of the parameter. It MUST match the parameter name used in the parent channel address. ##### Parameters Object Example ```json { - "user/{userId}/signup": { - "parameters": { - "userId": { - "description": "Id of the user.", - "schema": { - "type": "string" - } - } - }, - "subscribe": { - "message": { - "$ref": "#/components/messages/userSignedUp" - } + "address": "user/{userId}/signedup", + "parameters": { + "userId": { + "description": "Id of the user." } } } ``` ```yaml -user/{userId}/signup: - parameters: - userId: - description: Id of the user. - schema: - type: string - subscribe: - message: - $ref: "#/components/messages/userSignedUp" +address: user/{userId}/signedup +parameters: + userId: + description: Id of the user. ``` @@ -1064,15 +1050,17 @@ user/{userId}/signup: #### Parameter Object -Describes a parameter included in a channel name. +Describes a parameter included in a channel address. ##### Fixed Fields Field Name | Type | Description ---|:---:|--- -description | `string` | A verbose explanation of the parameter. [CommonMark syntax](https://spec.commonmark.org/) can be used for rich text representation. -schema | [Schema Object](#schemaObject) \| [Reference Object](#referenceObject) | Definition of the parameter. -location | `string` | A [runtime expression](#runtimeExpression) that specifies the location of the parameter value. Even when a definition for the target field exists, it MUST NOT be used to validate this parameter but, instead, the `schema` property MUST be used. +enum | [`string`] | An enumeration of string values to be used if the substitution options are from a limited set. +default | `string` | The default value to use for substitution, and to send, if an alternate value is _not_ supplied. +description | `string` | An optional description for the parameter. [CommonMark syntax](https://spec.commonmark.org/) MAY be used for rich text representation. +examples | [`string`] | An array of examples of the parameter value. +location | `string` | A [runtime expression](#runtimeExpression) that specifies the location of the parameter value. This object MAY be extended with [Specification Extensions](#specificationExtensions). @@ -1080,36 +1068,22 @@ This object MAY be extended with [Specification Extensions](#specificationExtens ```json { - "user/{userId}/signup": { - "parameters": { - "userId": { - "description": "Id of the user.", - "schema": { - "type": "string" - }, - "location": "$message.payload#/user/id" - } - }, - "subscribe": { - "message": { - "$ref": "#/components/messages/userSignedUp" - } + "address": "user/{userId}/signedup", + "parameters": { + "userId": { + "description": "Id of the user.", + "location": "$message.payload#/user/id" } } } ``` ```yaml -user/{userId}/signup: - parameters: - userId: - description: Id of the user. - schema: - type: string - location: $message.payload#/user/id - subscribe: - message: - $ref: "#/components/messages/userSignedUp" +address: user/{userId}/signedup +parameters: + userId: + description: Id of the user. + location: $message.payload#/user/id ```