You can create a flow that spans multiple requests, including input, display, and payment requests. To do so, you send an admin request to start a session. The terminal shows the waiting screen after every input, display, and payment request until you end the session. This solves the issue that customers may think something is wrong if they provide input and then do not see anything happening on the terminal. The waiting screen is shown for a set amount of time, or until the next request is sent to the terminal.
This is useful for payment flows where someone needs to interact with a terminal, like Pay at Table. It shows that the POS system is not unresponsive, it is just busy doing something that takes a bit of time.
How it works
You need to send two separate admin requests to mark the start and the end of a session. All requests in between belong to a single session.
To include multiple requests in one session:
-
Before you send the first request, send an admin request to start the session.
-
Send multiple requests, including input, display, and payment requests.
When you send an input request, after the user provides input on the terminal, the waiting screen shows for the set amount of time. With display and payment requests, after showing your data on the screen, the waiting screen shows. If you send another request before the waiting screen expires, the waiting screen disappears. -
After the last request, send an admin request to end the session.
Step 1: Start the session
-
Create a JSON object with the following data elements:
Parameter Required Description Session
An object with: ID
: the unique reference of the session.Type
: set the value to Begin to start the session.
Operation
An object with: Type
: the type of request after which the waiting screen shows: InputRequest, DisplayRequest, and Payment .Variant
: WaitingScreen.UserInterfaceData.WaitingScreenTimeoutMs
: how long the waiting screen is shown on the terminal display, in milliseconds.
Data elements in JSON formatExpand viewCopy link to code blockCopy code{ "Session": { "Id": 12345, "Type": "Begin" }, "Operation": [ { "Type": "InputRequest", "Variant": "WaitingScreen", "UserInterfaceData": { "WaitingScreenTimeoutMs": 15000 } }, { "Type": "DisplayRequest", "Variant": "WaitingScreen", "UserInterfaceData": { "WaitingScreenTimeoutMs": 10000 } } ] } For now, the
Operation.Variant
can only have WaitingScreen as value. This shows the waiting screen animation on the terminal after every request until you end the session. -
Encode the JSON object to Base64.
Base64 encoded messageExpand viewCopy link to code blockCopy codeewogICAgIlNlc3Npb24iOiB7CiAgICAgICAgIklkIjogMTIzNDUsCiAgICAgICAgIlR5cGUiOiAiQmVnaW4iLAogICAgfSwKICAgICJPcGVyYXRpb24iOiBbCiAgICAgICAgewogICAgICAgICAgICAiVHlwZSI6ICJJbnB1dFJlcXVlc3QiLAogICAgICAgICAgICAiVmFyaWFudCI6ICJXYWl0aW5nU2NyZWVuIiwKICAgICAgICAgICAgIlVzZXJJbnRlcmZhY2VEYXRhIjogewogICAgICAgICAgICAgICAgIldhaXRpbmdTY3JlZW5UaW1lb3V0TXMiOiAxNTAwMAogICAgICAgICAgICB9CiAgICAgICAgfSwKICAgICAgICB7CiAgICAgICAgICAgICJUeXBlIjogIkRpc3BsYXlSZXF1ZXN0IiwKICAgICAgICAgICAgIlZhcmlhbnQiOiAiV2FpdGluZ1NjcmVlbiIsCiAgICAgICAgICAgICJVc2VySW50ZXJmYWNlRGF0YSI6IHsKICAgICAgICAgICAgICAgICJXYWl0aW5nU2NyZWVuVGltZW91dE1zIjogMTAwMDAKICAgICAgICAgICAgfQogICAgICAgIH0KICAgIF0KfQ==
-
Make a POST request to a Terminal API endpoint, specifying:
-
MessageHeader
: the standardSaleToPOIRequest.MessageHeader
object. Specify:Parameter Required Description ProtocolVersion
3.0 MessageClass
Service MessageCategory
Admin MessageType
Request ServiceID
Your unique ID for this request, consisting of 1-10 alphanumeric characters. Must be unique within the last 48 hours for the terminal ( POIID
) being used.SaleID
Your unique ID for the POS system component to send this request from. POIID
The unique ID of the terminal to send this request to. Format: [device model]-[serial number].
AdminRequest
: the request body. This must include:ServiceIdentification
: the Base64-encoded JSON object.
Admin request - start sessionExpand viewCopy link to code blockCopy code{ "SaleToPOIRequest": { "MessageHeader": { "ProtocolVersion": "3.0", "MessageClass": "Service", "MessageCategory": "Admin", "MessageType": "Request", "ServiceID": "POSSystemID12345", "SaleID": "S00101", "POIID": "V400m-324688179" }, "AdminRequest": { "ServiceIdentification": "ewogICAiU2Vzc2lvbiI6ewogICAgICAiSWQiOjEyMzQ1LAogICAgICAiVHlwZSI6IkJlZ2luIgogICB9LAogICAiT3BlcmF0aW9uIjpbCiAgICAgIHsKICAgICAgICAgIlR5cGUiOiJJbnB1dFJlcXVlc3QiLAogICAgICAgICAiVmFyaWFudCI6IldhaXRpbmdTY3JlZW4iLAogICAgICAgICAiVXNlckludGVyZmFjZURhdGEiOnsKICAgICAgICAgICAgIldhaXRpbmdTY3JlZW5UaW1lb3V0TXMiOjE1MDAwCiAgICAgICAgIH0KICAgICAgfQogICBdCn0=" } } } -
-
The
AdminResponse
showsResponse.Result
Success.
Admin request - responseExpand viewCopy link to code blockCopy code{ "SaleToPOIResponse": { "AdminResponse": { "Response": { "Result": "Success" } }, "MessageHeader": { "MessageCategory": "Admin", "MessageClass": "Service", "MessageType": "Response", "POIID": "V400m-324688179", "ProtocolVersion": "3.0", "SaleID": "POSSystemID12345", "ServiceID": "S00101" } } } For more information on the Terminal API request structure, see the Terminal API fundamentals.
Step 2: Send requests
- Start sending the requests that you specified in the
operation.type
, including input, display, and payment requests. - After every request sent, the screen shows the waiting screen for the amount of time specified in milliseconds in
UserInterfaceData.WaitingScreenTimeoutMs
. - Every new request interrupts the waiting screen.
Step 3: End the session
-
Create a JSON object with the following data elements:
Parameter Required Description ServiceIdentification.Session
An object with: Id
: the unique reference of the session. This must be the sameId
as in the start sessionAdminRequest
).Type
: set the value to End.
Data elements in JSON formatExpand viewCopy link to code blockCopy code{ "Session": { "Id": 12345, "Type": "End" } } -
Encode the JSON object to Base64.
Base64 encoded messageExpand viewCopy link to code blockCopy codeewogICAiU2Vzc2lvbiI6ewogICAgICAiSWQiOjEyMzQ1LAogICAgICAiVHlwZSI6IkVuZCIKICAgfQp9
-
Make a POST request to a Terminal API endpoint, specifying:
-
MessageHeader
: the standardSaleToPOIRequest.MessageHeader
object. Specify:Parameter Required Description ProtocolVersion
3.0 MessageClass
Service MessageCategory
Admin MessageType
Request ServiceID
Your unique ID for this request, consisting of 1-10 alphanumeric characters. Must be unique within the last 48 hours for the terminal ( POIID
) being used.SaleID
Your unique ID for the POS system component to send this request from. POIID
The unique ID of the terminal to send this request to. Format: [device model]-[serial number].
AdminRequest
: the request body. This must include:ServiceIdentification
: the Base64-encoded JSON object.
Admin request - end sessionExpand viewCopy link to code blockCopy code{ "SaleToPOIRequest":{ "MessageHeader":{ "ProtocolVersion":"3.0", "MessageClass":"Service", "MessageCategory":"Admin", "MessageType":"Request", "ServiceID":"S00101", "SaleID":"POSSystemID12345", "POIID":"V400m-324688179" }, "AdminRequest":{ "ServiceIdentification": "ewogICAiU2Vzc2lvbiI6ewogICAgICAiSWQiOjEyMzQ1LAogICAgICAiVHlwZSI6IkVuZCIKICAgfQp9" } } } -
-
The
AdminResponse
showsResponse.Result
Success, same as in Step 1.
You can send an admin request to end the session while the waiting screen is still on the display. This does not interrupt the waiting screen like other requests.
After the session ends, the waiting screen no longer shows after sent input, display, or payment requests.