Receive Messages with Postman
You learned how to send messages to Axon Synapse in the previous section. In this one, you’ll listen to messages from Axon Synapse. Again the three message types you can listen for are commands, queries, and events.
Prerequisites
To accomplish the steps in this guide, you need to download and install Axon Synapse, Axon Server, and the Giftcard demo application. Before you continue, please complete the steps detailed on the Installation page.
Additionally, you need to download and install Postman. Go to Postman’s download page for detailed instructions.
Postman mock servers
When you send messages to Axon Synapse, you send HTTP requests. To receive messages, Axon Synapse sends HTTP requests to your application. You may create such an application in any language. From Axon Synapse’s perspective, all that matters is that it can receive an HTTP request and process the message in the payload.
For the purposes of this example, you’ll simulate your application by using Postman’s mock server feature.
Handle a command message
A command message is a request to perform a specific operation. Axon Synapse sends such messages via regular HTTP requests.
Create a dedicated mock server
Select Mock Servers
in Postman’s sidebar, then select +.
Next, give it a name. You can leave default values in other options.
The new mock server is ready and waiting for incoming messages.
Configure Axon Synapse to send commands to the mock server
You must inform Axon Synapse what commands it should send to the application (the mock server in this case). One way to do it’s to send a registration request to Axon Synapse, as demonstrated below.
(1) (2) (3)
POST http://localhost:8080/v1/contexts/default/handlers/commands
Content-Type: application/json
{
"names": [
"io.axoniq.demo.giftcard.api.IssueCardCommand" (4)
],
"endpoint": "https://cb5b8a7d-d2d1-4583-a6bc-31c70e9d0593.mock.pstmn.io/gift-cards", (5)
"endpointType": "http-raw", (6)
"clientId": "Postman", (7)
"componentName": "Giftcard" (8)
}
1 | POST - indicates a POST request |
2 | http://localhost:8080 - the instance of Axon Synapse |
3 | v1/contexts/default/handlers/commands - registering a command handler |
4 | io.axoniq.demo.giftcard.api.IssueCardCommand - the command name |
5 | the command handler endpoint, in this example the Postman mock |
6 | the command handler endpoint type (http-raw means the payload is in the request’s body) |
7 | the unique identifier of the command handling application instance |
8 | the application of the application component |
Alternatively, you can use Axon Synapse’s UI to register the handler.
Confirm it works
If you configured the mock server correctly, there are now two command handlers in the system for the IssueCardCommand
message. There is one in the Giftcard demo app and the Postman mock server you created. As new command messages of type IssueCardCommand
arrive, they’re load-balanced between the two handlers.
Go to the admin page for the Giftcard demo app and issue several new gift cards. Doing so creates and sends several IssueCardCommand
command messages. At least some of them should go to Postman mock server. Once it receives such a command, you should see the content of the command and its meta-data, as on the screen below.
Handle a query message
A query message is a request for information and so the handler must provide a response. Responding to a query message received from Axon Synapse is nothing more than replying to the HTTP request. You’ll use Postman mock server again to simulate the behavior of an HTTP application.
Create a dedicated mock server
Select Mock Servers
in Postman’s sidebar, then select +.
For the Response Body
, you can use the template sown below.
<list> (1)
<io.axoniq.demo.giftcard.api.CardSummary> (2)
<id>http-based-gift-card</id> (3)
<initialValue>155</initialValue> (4)
<remainingValue>155</remainingValue> (5)
</io.axoniq.demo.giftcard.api.CardSummary>
</list>
1 | The response with list of gift cards |
2 | The first gift card |
3 | The id property |
4 | The initialValue property |
5 | The remainingValue property |
Proceed to the next step and give the mock a name.
Finally, you can listen to requests:
Go to the Collections tab and add headers to the response:
AxonIQ-PayloadType: java.util.ArrayList
Configure Axon Synapse to send queries to the mock server
You need to register the query handler with Axon Synapse as you did with the command handlers. The code below shows an example of doing so via the HTTP API.
(1) (2) (3)
POST http://localhost:8080/v1/contexts/default/handlers/queries
Content-Type: application/json
{
"names": [
"io.axoniq.demo.giftcard.api.FetchCardSummariesQuery" (4)
],
"endpoint": "https://ac365f15-964b-4083-af93-1536f297fd7e.mock.pstmn.io/list-gift-cards/", (5)
"endpointType": "http-raw", (6)
"clientId": "Postman", (7)
"componentName": "Giftcard" (8)
}
1 | POST - indicates a POST request |
2 | http://localhost:8080 - the instance of Axon Synapse |
3 | v1/contexts/default/handlers/queries - creating a query handler |
4 | io.axoniq.demo.giftcard.api.FetchCardSummariesQuery - the query name |
5 | the query handler endpoint, in this example the Postman mock |
6 | the query handler endpoint type (http-raw means the payload is in the request’s body) |
7 | the unique identifier of the command handling application instance |
8 | the application of the application component |
Alternatively, you can use Axon Synapse’s UI to register the handler.
Confirm it works
Again, if you configured everything correctly, there are two query handlers for the FetchCardSummariesQuery
- the one from the Giftcard demo app and the one from Postman’s mock server. Therefore, routing a query to the mock server may take several tries.
You can test the query handler using the Giftcard demo app or Synapse HTTP query.
Handle an event message
Axon Synapse can send events to your application through HTTP requests, one by one, ordered by the sequence index.
Create a dedicated mock server
Create a new Mock Server
in the Postman.
Configure Axon Synapse to send events to the mock server
As with the other message types, you must register the event handler in Axon Synapse. Below is an example of the HTTP API approach.
(1) (2) (3)
POST http://localhost:8080/v1/contexts/default/handlers/events
Content-Type: application/json
{
"names": [
"io.axoniq.demo.giftcard.api.CardIssuedEvent" (4)
],
"endpoint": "https://1d5cae3d-b328-4565-a36b-2d4a49de79de.mock.pstmn.io/card-issued", (5)
"endpointType": "http-raw", (6)
"clientId": "Postman", (7)
"componentName": "Giftcard" (8)
}
1 | POST - indicates a POST request |
2 | http://localhost:8080 - the instance of Axon Synapse |
3 | v1/contexts/default/handlers/events - creating an event handler |
4 | io.axoniq.demo.giftcard.api.CardIssuedEvent - the event type |
5 | the event handler endpoint, in this example the Postman mock |
6 | the event handler endpoint type (http-raw means the payload is in the request’s body) |
7 | the unique identifier of the event handling application instance |
8 | the application of the application component |
Similarly to the earlier examples, you can use Synapse UI.