Waiting for a response synchronously
When sending an asynchronous call, a caller application can specify an amount of time it is willing to wait for a response.
- If the call can be processed within the specified time, Cloud API returns the results as if the call had been executed synchronously.
- If the call cannot be processed within the specified time, Cloud API returns a "202
Accepted" response and a
GW-Async-Location
header. As is the case with regular asynchronous calls, the caller application must retrieve the results with a second call
You can specify the wait time in seconds or milliseconds.
Specifying wait time in seconds
To specify a wait time in seconds, specify the asynchronous header as:
- KEY:
Prefer
- VALUE:
respond-async, wait=T
where T is the number of seconds the caller application is willing to wait.
Specifying wait time in milliseconds
To specify a wait time in milliseconds, specify the asynchronous header as:
- KEY:
Prefer
- VALUE:
respond-async, wait-ms=T
where T is the number of milliseconds the caller application is willing to wait.
Specifying a 0 wait time
You can force a call to always execute asynchronously and without any initial
validation. To do this, specify wait=0
or
wait-ms=0
.
Tutorial: Send a request asynchronously with a wait time
This tutorial assumes you have set up your environment with Postman and the correct sample data set. For more information, see Tutorial: Set up your Postman environment.
In this tutorial, you will submit two requests asynchronously to create a new user. Both will specify a wait time.
Tutorial steps
- In Postman, start a new request by:
- Clicking the + to the right of the Launchpad tab
- Specifying Basic Auth authorization using user
su
and passwordgw
.
- Enter the following call, but do not click Send yet:
- POST
http://localhost:8580/bc/rest/admin/v1/users
- POST
- Specify the request payload.
- In the first row of tabs (the one that starts with Params), click Body.
- In the row of radio buttons, select raw.
- At the end of the row of radio buttons, change the drop-down list value from Text to JSON.
- Paste the following into the text field underneath the radio buttons.
{ "data": { "attributes": { "username": "asyncUserNoWait" } } }
- Add the asynchronous request to the header.
- In the first row of tabs, click Headers.
- Scroll to the bottom of the existing key/value list.
- In the blank row at the bottom of the key/value list, enter the
following:
- KEY: Prefer
- VALUE: respond-async, wait=1
- Create a second tab by duplicating the first tab. To do this, right-click the tab and select Duplicate Tab.
- Modify the second tab so that it executes with a wait time.
- In the request body, change the
username
value toasyncUserWithWait
. - Change the Prefer header so its wait time is
"
wait-ms=1
" instead of "wait=1
":- KEY: Prefer
- VALUE: respond-async, wait-ms=1
- In the request body, change the
- On both tabs, click Send.
Results
The first tab executes an asynchronous call with a wait time of 1 second. The application is able to complete the call within this time, so the response is provided. (The status is "201 Created" and the response to the original call is provided.)
The second tab executes an asynchronous call with a wait time of 1 millisecond. The application is not able to complete the call within this time, so the call is merely accepted. (The status is "202 Accepted" and the response body is blank.)