In an AsyncAPI document, adding messages mainly means setting up channels and operations. This is key for explaining how data moves between your applications. However, sometimes you might just want to use the AsyncAPI document to describe the messages themselves, without anything else.
Add messages
In an AsyncAPI document, you define message definitions under channels. However, the best practice is to first define these messages under the 'components' section as reusable definitions. That way, you can reference them easily from a channel.
Here is a diagram showing some channel fields and the relation between channel messages and components messages:
Channels section
Define the channels section in your AsyncAPI document, including the messages your channel accepts. For example:
1channels:
2 allCommentsLiked:
3 address: comment/liked
4 messages:
5 commentLiked:
6 description: Message that is being sent when a comment has been liked by someone.
7 payload:
8 type: object
9 title: commentLikedPayload
10 additionalProperties: false
11 properties:
12 commentId:
13 type: string
14 description: Id of the comment that was liked
15 description: Notification channel for all the services that need to know comment is liked.The above example presents an application that communicates over the allCommentsLiked channel, which only accepts one message called commentLiked.
messages section
In your AsyncAPI document, create a components.messages section to define each message your application uses as a reusable message. When setting up multiple channels, you won't have to repeat the same message definitions. For example:
1components:
2 messages:
3 commentLiked:
4 description: Message that is being sent when a comment has been liked by someone.
5 payload:
6 type: object
7 title: commentLikedPayload
8 additionalProperties: false
9 properties:
10 commentId:
11 type: string
12 description: Id of the comment that was likedYou can reuse messages using the Reference Object. For example:
1 messages:
2 commentLiked:
3 $ref: '#/components/messages/commentLiked'Here's the complete AsyncAPI document with channels reusing the same message:
1asyncapi: 3.0.0
2info:
3 title: Example API
4 version: '1.0.0'
5channels:
6 allCommentsLiked:
7 address: comment/liked
8 messages:
9 commentLiked:
10 $ref: '#/components/messages/commentLikedUnliked'
11 description: Notification channel for all the services that need to know comment is liked.
12 allCommentUnliked:
13 address: comment/unliked
14 messages:
15 commentUnliked:
16 $ref: '#/components/messages/commentLikedUnliked'
17 description: Notification channel for all the services that need to know comment is liked.
18components:
19 messages:
20 commentLikedUnliked:
21 description: Message that is being sent when a comment has been liked or unliked by someone.
22 payload:
23 type: object
24 title: commentInfoPayload
25 additionalProperties: false
26 properties:
27 commentId:
28 type: string
29 description: Id of the comment that was liked or unlikedIdentifier of the message
The key name that represents a message in your AsyncAPI document must be interpreted as messageId. If your document defines channels, the message key defined in the channel is the messageId.
1channels:
2 allCommentsLiked:
3 address: comment/liked
4 messages:
5 commentLiked:
6 $ref: '#/components/messages/commentLikedUnliked'
7 description: Notification channel for all the services that need to know comment is liked.The above example shows a commentLiked message under the allCommentsLiked channel. It references a reusable message definition from the components section represented by the commentLikedUnliked key. In this setup, the commentLiked key is the messageId and not commentLikedUnliked.
Messages under operations
Operations specify which channels they interact with. If a channel has several messages, but your operation only involves one, indicate which specific message the operation uses.
1channels:
2 allComments:
3 address: comments
4 messages:
5 commentLiked:
6 $ref: '#/components/messages/commentLikedMsg'
7 commentUnliked:
8 $ref: '#/components/messages/commentUnlikedMsg'
9 description: Notification channel for all the services that need to know comment is liked.
10operations:
11 onCommentLiked:
12 action: receive
13 channel:
14 $ref: '#/channels/allComments'
15 messages:
16 - $ref: '#/channels/allComments/messages/commentLiked'The above example demonstrates how to specify the message for the onCommentsLiked operation received from the allCommentLiked channel. It's important to note that the message reference points to the channel, not the components section. That ensures accurate information about the messageId, which in this case is commentLiked, not commentLikedMsg.