Retrieving the response to the original request
There are multiple ways to retrieve the response to the initial request.
Response information in the /requests
response
The response to the initial call includes a GW-Async-Location
header.
This header uses the following syntax:
/async/v1/requests/<asyncRequestId>
You can execute a GET on this endpoint to retrieve information about the original request.
The response status
The response includes a status
field, which has one of the following
values:
- Accepted - The request is still waiting to be processed.
- In Progress - The request is being processed, but processing is not yet complete.
- Complete - The request has been processed.
The response also includes a responseBodyJson
attribute. If the
original request has been processed and if the original request's response type is
application/json
, then the responseBodyJson
attribute contains the response payload for the initial request.
Response information using the /response
endpoint
There is also a /requests/{asyncRequestId}/response
endpoint. Calls to
this endpoint use the following syntax:
/async/v1/requests/<asyncRequestId>/response
If the original request is complete, this endpoint returns the response to the original request as if the call had been executed synchronously. This endpoint is useful when:
- The response type is something other than application/json, and therefore is not
included in the
/requests
response. - The caller application wants to work with the response as it would normally appear,
as opposed to having to extract it from within the
responseBodyJson
attribute of a larger data envelope.
Note that there are two situations in which this endpoint could return a 400 error:
- The original request does not yet have a status of Complete. Its status is either still Accepted or In Progress.
- The original request has a status of Complete, and the response to the original request is a 400 error.
Tutorial: Retrieve information about an asynchronous request
This tutorial assumes you have submitted an asynchronous request to create a user and you
have the GW-Async-Location
value from the response. For more
information, see Tutorial: Send a request asynchronously.
In this tutorial, you will retrieve information about the asynchronous request using both
the /requests
and /response
endpoints.
Tutorial steps
- In Postman, start a new request by clicking the + to the right of the
Launchpad tab
- On the Authorization tab, select Basic
Auth using user
su
and passwordgw
.
- On the Authorization tab, select Basic
Auth using user
- Enter the following call, but do not click Send
yet:
- GET
http://localhost:8580/bc/rest/<Async-Location>
, where<Async-Location>
is the value of theGW-Async-Location
response header from the initial asynchronous request.
- GET
- Ensure that, for this request, you do not have
Prefer/respond-async
header specified in your request. (Although you can submit the/requests
call asynchronously, you typically would not want to.) - Click Send.
- Send a second request that uses the
/response
endpoint to retrieve only the response.- Right-click the current tab and choose Duplicate Tab.
- In the new tab, add "
/response
" to the end of the existing URL.
- Click Send.
Results
On the first tab, the response object contains information about the response to the original request. Typically, user creation occurs very rapidly, and the original request should already be processed. If so:
- The
completionTime
is specified. - The
responseBodyJson
attribute contains the response to the original request. In this case, it is information about the newly created user. - The
responseStatus
is 201. - The
status
has acode
ofComplete
.
On the second tab, the response object contains the same information that would have been returned if the initial request were submitted synchronously.