Terminal-2 icon

Display notifications

Receive terminal-generated display notifications in your POS app.

During a transaction or tender, the payment terminal generates display notifications. You can show these in your POS app to keep your staff up-to-date on the progress of the tender. For example, whether the customer has selected Dynamic Currency Conversion, or finished entering their PIN.

Here we describe how to set up display notifications. You can do this in your Customer Area or by using API calls. You then receive webhooks that include a Terminal API DisplayRequest from the terminal. This has an event indicating the progress of the transaction, or the result of the transaction. You can use this information to show a message in your POS app.

We also provide an overview of display notification types, and examples of each.

Set up display notifications in the Customer Area

To get display notifications, you need to make sure you can receive HTTP callbacks (webhooks) on a specific endpoint. Then you need to provide the URL to that endpoint in your Customer Area.

  1. Prepare your system. It needs to have:

    • An endpoint that can receive JSON messages.
    • For the test environment: an open TCP port for HTTP traffic (80, 8080, or 8888) or HTTPS traffic (443, 8443, or 8843) with TLSv1.2.
    • For the live environment: an open TCP port for HTTPS traffic (443, 8443, or 8843) with TLSv1.2.

  2. Log in to your Customer Area.

  3. Switch to the merchant account, store, or terminal that you want to set up notifications for.

  4. Go to In-person payments > Terminal settings > Integrations.

  5. In the Terminal API section, select Decrypted.

  6. Under Display URLs, select Add new.

  7. Select the pencil icon next to the field that appears.
    The Add URL dialog opens.

  8. Enter the details:

    • URL: the URL of the endpoint where you want to receive display notifications.
    • Username and Password (optional): the basic authentication credentials you set up on your server. We include these details in the header of the notification to authenticate with your server.
    • Public: select this option if the specified URL is on a public network.
    • Local: select this option if the specified URL is on a Local Area Network.
    • Enable encryption: select this if you want the message sent to this URL to be encrypted.

  9. Select Add URL.

  10. Select Save.

Display notifications will now be sent to the endpoint you specified.

Set up display notifications using API calls

Instead of using your Customer Area, you can use our Management API to automate setting up display notifications. To get display notifications, make sure you can receive HTTP callbacks (webhooks) on a specific endpoint. You then need to provide the URL to that endpoint in the PATCH request.

To set up display notifications, you need to have the following role:

  • Management API - Terminal settings Advanced read and write

Proceed as follows:

  1. Prepare your system. It needs to have:

    • An endpoint that can receive JSON messages.
    • For the test environment: an open TCP port for HTTP traffic (80, 8080, or 8888) or HTTPS traffic (443, 8443, or 8843) with TLSv1.2.
    • For the live environment: an open TCP port for HTTPS traffic (443, 8443, or 8843) with TLSv1.2.
  2. Optional. To see what display notification settings have already been configured, make a GET request to the /terminalSettings endpoint for the company account, merchant account, store or terminal, and check the nexo.displayUrls object.

    When removing settings, you need to know the settings that will be inherited from the next higher level.

  3. Make a PATCH request to the /terminalSettings endpoint on the company account, merchant account, store or terminal level.
    In the request body, inside the nexo object, specify:

    • localUrls: an array with one or more local URLs. Use this if the specified URL is on a Local Area Network. This includes:
    Parameter Data type Description
    encrypted Boolean Indicates if the message sent to this URL should be encrypted.
    password String The password for authentication of the notifications.
    url String The URL of the endpoint where they want to receive notifications, in the format: http(s)://domain.com.
    username String The username for authentication of the notifications.
    • publicUrls: an array with one or more public URLs. Use this if the specified URL is on a public network. This includes:
    Parameter Data type Description
    encrypted Boolean Indicates if the message sent to this URL should be encrypted.
    password String The password for authentication of the notifications.
    url String The URL of the endpoint where they want to receive notifications, in the format: http(s)://domain.com.
    username String The username for authentication of the notifications.
    Set up a local URL on a terminal level
    Expand view
    Copy link to code block
    Copy code
    Copy code
    curl https://management-test.adyen.com/v3/terminals/{terminalId}/terminalSettings \
    -H 'x-API-key: ADYEN_API_KEY' \
    -X PATCH \
    -d '{
    "nexo": {
    "displayUrls":{
    "localUrls":[
    {
    "encrypted":"true",
    "password":"BASIC_AUTH_PASSWORD",
    "url":"https://your-display-notifications-endpoint.com",
    "username":"BASIC_AUTH_USERNAME"
    }
    ]
    }
    }
    }'
  4. When you receive the response, note that this returns the entire configuration at the level where you made the request.

    Response with the entire configuration on a terminal level
    Expand view
    Copy link to code block
    Copy code
    Copy code
    {
    "cardholderReceipt":{
    "headerForAuthorizedReceipt":"header1,header2,filler"
    },
    "gratuities":[
    {
    "currency":"EUR",
    "usePredefinedTipEntries":true,
    "predefinedTipEntries":[
    "100",
    "1%",
    "5%"
    ],
    "allowCustomAmount":true
    }
    ],
    "nexo":{
    "displayUrls":{
    "localUrls":[
    {
    "password":"BASIC_AUTH_PASSWORD",
    "url":"https://your-display-notifications-endpoint.com",
    "username":"BASIC_AUTH_USERNAME"
    }
    ]
    },
    "encryptionKey":{
    "identifier":"KEY_IDENTIFIER",
    "passphrase":"KEY_PASSPHRASE",
    "version":1
    },
    "eventUrls":{
    "eventPublicUrls":[
    {
    "password":"BASIC_AUTH_PASSWORD",
    "url":"https://your-event-notifications-endpoint.com",
    "username":"BASIC_AUTH_USERNAME"
    }
    ]
    }
    },
    "opi":{
    "enablePayAtTable":true,
    "payAtTableStoreNumber":"1",
    "payAtTableURL":"https:/your-pay-at-table-endpoint.com"
    },
    "offlineProcessing":{
    "chipFloorLimit":0
    },
    "receiptOptions":{
    "qrCodeData":"http://www.example.com/order/${pspreference}/${merchantreference}"
    },
    "receiptPrinting":{
    "shopperApproved":true,
    "shopperRefused":true,
    "shopperCancelled":true,
    "shopperRefundApproved":true,
    "shopperRefundRefused":true,
    "shopperVoid":true
    },
    "signature":{
    "askSignatureOnScreen":true,
    "skipSignature":false,
    "deviceName":"Amsterdam-236203386"
    },
    "wifiProfiles":{
    "profiles":[
    {
    "authType":"wpa-psk",
    "autoWifi":false,
    "bssType":"infra",
    "channel":0,
    "defaultProfile":true,
    "hiddenSsid":false,
    "name":"Guest Wi-Fi",
    "psk":"4R8R2R3V456X",
    "ssid":"G470P37660D4G",
    "wsec":"ccmp"
    }
    ],
    "settings":{
    "band":"All",
    "roaming":true
    }
    },
    "timeouts":{
    "fromActiveToSleep":30
    },
    "hardware":{
    "displayMaximumBackLight":75
    },
    "connectivity":{
    "simcardStatus":"INVENTORY"
    }
    }

Display notification types

A display notification is a DisplayRequest sent from the terminal. It includes a ReferenceID field with either:

  • event: the interaction between the terminal and the customer.
  • Result: the outcome of the transaction.

Use the ReferenceID to show a message to your staff, informing them of the progress of the transaction.

The main display notification types are:

Event Description

TENDER_CREATED

The tender has started.The ReferenceID includes: the event TENDER_CREATED, and the TimeStamp and TransactionID of the transaction.

CARD_INSERTED

The shopper has inserted their card into the terminal.

CARD_PRESENTED

The shopper has presented the card to the terminal's contactless reader.

CARD_SWIPED

The shopper has swiped their card.

WAIT_FOR APP_SELECTION

The terminal is waiting for the shopper to select a payment application.

APPLICATION_SELECTED

The shopper has selected their preferred payment application.

ASK_SIGNATURE

The terminal has prompted the shopper to provide their signature.

CHECK_SIGNATURE

The signature is ready to be checked by store staff.

SIGNATURE_CHECKED

The signature has been checked by store staff.

WAIT_FOR_PIN

The terminal is waiting for the shopper to enter their PIN.

PIN_ENTERED

The shopper has finished entering their PIN.

PRINT_RECEIPT

The terminal is printing the receipt.

RECEIPT_PRINTED

The terminal has finished printing the receipt.

CARD_REMOVED

The shopper has removed their card from the terminal.

TENDER_FINAL

The tender was finished; the shopper either completed or abandoned the transaction.

The ReferenceID includes: the event TENDER_FINAL, and the Result, TimeStamp, and TransactionID of the transaction.

ASK_DCC

The terminal is asking if the shopper requires dynamic currency conversion.

DCC_ACCEPTED

The shopper accepted the dynamic currency conversion request.

DCC_REJECTED

The shopper rejected the dynamic currency conversion request.

ASK_GRATUITY

The terminal is waiting for a possible tip.

GRATUITY_ENTERED

The shopper has entered a gratuity on the terminal.

BALANCE_QUERY_STARTED

Balance check started on the terminal.

BALANCE_QUERY_COMPLETED

Balance check completed on the terminal.

LOAD_STARTED

Gift card load has been initiated.

LOAD_COMPLETED

Gift card load has been completed.

PROVIDE_CARD_DETAILS

The terminal is waiting for card details to be entered manually.

CARD_DETAILS_PROVIDED

The card details have been entered.

Examples of display notifications are provided below.

Examples

TENDER_CREATED

Expand view
Copy link to code block
Copy code
Copy code
{
"SaleToPOIRequest":{
"DisplayRequest":{
"DisplayOutput":[
{
"Device": "CashierDisplay",
"InfoQualify": "Status",
"OutputContent": {
"OutputFormat": "MessageRef",
"PredefinedContent": {
"ReferenceID": "TransactionID=oLkO001517998574000&TimeStamp=2018-02-07T10%3a16%3a14.000Z&event=TENDER_CREATED"
}
},
"ResponseRequiredFlag": false
}
]
},
"MessageHeader":{
"SaleID":"POSSystemID12345",
"ProtocolVersion":"3.0",
"MessageType":"Request",
"POIID":"V400m-324688179",
"ServiceID":"0207111617",
"MessageClass":"Device",
"MessageCategory":"Display",
"DeviceID":"1517998562"
}
}
}

CARD_INSERTED

Expand view
Copy link to code block
Copy code
Copy code
{
"SaleToPOIRequest":{
"DisplayRequest":{
"DisplayOutput":[
{
"Device":"CashierDisplay",
"InfoQualify":"Status",
"OutputContent":{
"OutputFormat":"MessageRef",
"PredefinedContent":{
"ReferenceID":"event=CARD_INSERTED"
}
},
"ResponseRequiredFlag":false
}
]
},
"MessageHeader":{
"SaleID":"POSSystemID12345",
"ProtocolVersion":"3.0",
"MessageType":"Request",
"POIID":"V400m-324688179",
"ServiceID":"0207111617",
"MessageClass":"Device",
"MessageCategory":"Display",
"DeviceID":"1517998563"
}
}
}

CARD_SWIPED

Expand view
Copy link to code block
Copy code
Copy code
{
"SaleToPOIRequest":{
"DisplayRequest":{
"DisplayOutput":[
{
"Device":"CashierDisplay",
"InfoQualify":"Status",
"OutputContent":{
"OutputFormat":"MessageRef",
"PredefinedContent":{
"ReferenceID":"event=CARD_SWIPED"
}
},
"ResponseRequiredFlag":false
}
]
},
"MessageHeader":{
"SaleID":"POSSystemID12345",
"ProtocolVersion":"3.0",
"MessageType":"Request",
"POIID":"V400m-324688179",
"ServiceID":"0207111617",
"MessageClass":"Device",
"MessageCategory":"Display",
"DeviceID":"1517998573"
}
}
}

WAIT_FOR_APP_SELECTION

Expand view
Copy link to code block
Copy code
Copy code
{
"SaleToPOIRequest":{
"DisplayRequest":{
"DisplayOutput":[
{
"Device":"CashierDisplay",
"InfoQualify":"Status",
"OutputContent":{
"OutputFormat":"MessageRef",
"PredefinedContent":{
"ReferenceID":"event=WAIT_FOR_APP_SELECTION"
}
},
"ResponseRequiredFlag":false
}
]
},
"MessageHeader":{
"SaleID":"POSSystemID12345",
"ProtocolVersion":"3.0",
"MessageType":"Request",
"POIID":"V400m-324688179",
"ServiceID":"0207111617",
"MessageClass":"Device",
"MessageCategory":"Display",
"DeviceID":"1517998564"
}
}
}

APPLICATION_SELECTED

Expand view
Copy link to code block
Copy code
Copy code
{
"SaleToPOIRequest":{
"DisplayRequest":{
"DisplayOutput":[
{
"Device":"CashierDisplay",
"InfoQualify":"Status",
"OutputContent":{
"OutputFormat":"MessageRef",
"PredefinedContent":{
"ReferenceID":"event=APPLICATION_SELECTED"
}
},
"ResponseRequiredFlag":false
}
]
},
"MessageHeader":{
"SaleID":"POSSystemID12345",
"ProtocolVersion":"3.0",
"MessageType":"Request",
"POIID":"V400m-324688179",
"ServiceID":"0207111617",
"MessageClass":"Device",
"MessageCategory":"Display",
"DeviceID":"1517998565"
}
}
}

WAIT_FOR_PIN

Expand view
Copy link to code block
Copy code
Copy code
{
"SaleToPOIRequest":{
"DisplayRequest":{
"DisplayOutput":[
{
"Device":"CashierDisplay",
"InfoQualify":"Status",
"OutputContent":{
"OutputFormat":"MessageRef",
"PredefinedContent":{
"ReferenceID":"event=WAIT_FOR_PIN"
}
},
"ResponseRequiredFlag":false
}
]
},
"MessageHeader":{
"SaleID":"POSSystemID12345",
"ProtocolVersion":"3.0",
"MessageType":"Request",
"POIID":"V400m-324688179",
"ServiceID":"0207111617",
"MessageClass":"Device",
"MessageCategory":"Display",
"DeviceID":"1517998566"
}
}
}

PIN_ENTERED

Expand view
Copy link to code block
Copy code
Copy code
{
"SaleToPOIRequest":{
"DisplayRequest":{
"DisplayOutput":[
{
"Device":"CashierDisplay",
"InfoQualify":"Status",
"OutputContent":{
"OutputFormat":"MessageRef",
"PredefinedContent":{
"ReferenceID":"event=PIN_ENTERED"
}
},
"ResponseRequiredFlag":false
}
]
},
"MessageHeader":{
"SaleID":"POSSystemID12345",
"ProtocolVersion":"3.0",
"MessageType":"Request",
"POIID":"V400m-324688179",
"ServiceID":"0207111617",
"MessageClass":"Device",
"MessageCategory":"Display",
"DeviceID":"1517998571"
}
}
}
Expand view
Copy link to code block
Copy code
Copy code
{
"SaleToPOIRequest":{
"DisplayRequest":{
"DisplayOutput":[
{
"Device":"CashierDisplay",
"InfoQualify":"Status",
"OutputContent":{
"OutputFormat":"MessageRef",
"PredefinedContent":{
"ReferenceID":"event=PRINT_RECEIPT"
}
},
"ResponseRequiredFlag":false
}
]
},
"MessageHeader":{
"SaleID":"POSSystemID12345",
"ProtocolVersion":"3.0",
"MessageType":"Request",
"POIID":"V400m-324688179",
"ServiceID":"0207111617",
"MessageClass":"Device",
"MessageCategory":"Display",
"DeviceID":"1517998572"
}
}
}

CARD_REMOVED

Expand view
Copy link to code block
Copy code
Copy code
{
"SaleToPOIRequest":{
"DisplayRequest":{
"DisplayOutput":[
{
"Device":"CashierDisplay",
"InfoQualify":"Status",
"OutputContent":{
"OutputFormat":"MessageRef",
"PredefinedContent":{
"ReferenceID":"event=CARD_REMOVED"
}
},
"ResponseRequiredFlag":false
}
]
},
"MessageHeader":{
"SaleID":"POSSystemID12345",
"ProtocolVersion":"3.0",
"MessageType":"Request",
"POIID":"V400m-324688179",
"ServiceID":"0207111617",
"MessageClass":"Device",
"MessageCategory":"Display",
"DeviceID":"1517998573"
}
}
}

TENDER_FINAL

Expand view
Copy link to code block
Copy code
Copy code
{
"SaleToPOIRequest":{
"DisplayRequest":{
"DisplayOutput":[
{
"Device":"CashierDisplay",
"InfoQualify":"Status",
"OutputContent":{
"OutputFormat":"MessageRef",
"PredefinedContent":{
"ReferenceID":"Result=Success&TimeStamp=2018-09-27T14:40:18.000Z&TransactionID=faQm001538059218000.NC6HT9CRT65ZGN82&event=TENDER_FINAL"
}
},
"ResponseRequiredFlag":false
}
]
},
"MessageHeader":{
"SaleID":"POSSystemID12345",
"ProtocolVersion":"3.0",
"MessageType":"Request",
"POIID":"V400m-324688179",
"ServiceID":"0207111617",
"MessageClass":"Device",
"MessageCategory":"Display",
"DeviceID":"1517998573"
}
}
}

BALANCE_QUERY_STARTED

Expand view
Copy link to code block
Copy code
Copy code
{
"SaleToPOIRequest":{
"DisplayRequest":{
"DisplayOutput":[
{
"Device":"CashierDisplay",
"InfoQualify":"Status",
"OutputContent":{
"OutputFormat":"MessageRef",
"PredefinedContent":{
"ReferenceID":"event=BALANCE_QUERY_STARTED"
}
},
"ResponseRequiredFlag":false
}
]
},
"MessageHeader":{
"SaleID":"Ray",
"MessageClass":"Device",
"MessageCategory":"Display",
"ServiceID":"S34",
"POIID":"V400m-324688179",
"MessageType":"Request",
"DeviceID":"39288033"
}
}
}

GRATUITY_ENTERED

Expand view
Copy link to code block
Copy code
Copy code
{
"SaleToPOIRequest":{
"DisplayRequest":{
"DisplayOutput":[
{
"Device":"CashierDisplay",
"InfoQualify":"Status",
"OutputContent":{
"OutputFormat":"MessageRef",
"PredefinedContent":{
"ReferenceID":"event=GRATUITY_ENTERED"
}
},
"ResponseRequiredFlag":false
}
]
},
"MessageHeader":{
"SaleID":"POSSystemID12345",
"ProtocolVersion":"3.0",
"MessageType":"Request",
"POIID":"V400m-324688179",
"ServiceID":"0207111617",
"MessageClass":"Device",
"MessageCategory":"Display",
"DeviceID":"1517998573"
}
}
}

LOAD_STARTED

Expand view
Copy link to code block
Copy code
Copy code
{
"SaleToPOIRequest":{
"DisplayRequest":{
"DisplayOutput":[
{
"Device":"CashierDisplay",
"InfoQualify":"Status",
"OutputContent":{
"OutputFormat":"MessageRef",
"PredefinedContent":{
"ReferenceID":"event=LOAD_STARTED"
}
},
"ResponseRequiredFlag":false
}
]
},
"MessageHeader":{
"SaleID":"POSSystemID12345",
"ProtocolVersion":"3.0",
"MessageType":"Request",
"POIID":"V400m-324688179",
"ServiceID":"0207111617",
"MessageClass":"Device",
"MessageCategory":"Display",
"DeviceID":"1517998573"
}
}
}

PROVIDE_CARD_DETAILS

Expand view
Copy link to code block
Copy code
Copy code
{
"SaleToPOIRequest":{
"DisplayRequest":{
"DisplayOutput":[
{
"Device":"CashierDisplay",
"InfoQualify":"Status",
"OutputContent":{
"OutputFormat":"MessageRef",
"PredefinedContent":{
"ReferenceID":"event=PROVIDE_CARD_DETAILS"
}
},
"ResponseRequiredFlag":false
}
]
},
"MessageHeader":{
"SaleID":"POSSystemID12345",
"ProtocolVersion":"3.0",
"MessageType":"Request",
"POIID":"V400m-324688179",
"ServiceID":"0207111617",
"MessageClass":"Device",
"MessageCategory":"Display",
"DeviceID":"1517998573"
}
}
}

Next steps