Terminal-2 icon

Assign terminals

Assign your terminals using our Management API.

To make terminals ready for boarding, you need to assign them to a store or, depending on your account setup, to a merchant account as in-store terminals. You can assign your terminals manually in your Customer Area, but Management API enables you to automate these processes.

We recommend using Management API to assign terminals. If you are still using the classic assign terminals call, refer to Classic POS Terminal Management.

Requirements

Before you begin, take into account the following requirements, limitations, and preparations.

Requirement Description
Integration type A point-of-sale integration with Adyen.
API credentials You must have an API credential with an API key and the following roles:
  • Management API—Stores read
  • Management API—Stores read and write
  • Management API—Terminal actions read
  • Management API—Assign Terminal

If you have a Terminal API integration with cloud-based communications, you can use the existing API key that you use for Terminal API requests.
Webhooks Subscribe to Terminal assignment complete webhooks.
Limitations Requests to live Management API endpoints related to assigning terminals are subject to rate limits.

Inventory and in-store terminals

When assigning terminals, you need to be aware that terminals have both:

  • A level in your account setup: company account, merchant account, or store. Depending on your account setup, the merchant account may represent a store.
  • A state: inventory or in store. A terminal in the inventory cannot process transactions. A terminal that is in store is either ready for boarding, or is already boarded.

Terminals at the company account level are always inventory terminals, and terminals at the store level are always in-store terminals. If the merchant account has stores underneath, the merchant account can only have inventory terminals. A merchant account that represents a store can have both inventory terminals and in-store terminals.

Therefore, you can assign terminals to:

  • A company account: terminals cannot process transactions.
  • A merchant account inventory: terminals cannot process transactions.
  • A merchant account directly: terminals can process transactions.
  • A store: terminals can process transactions.

Get a list of stores

You can make a GET /merchants/{merchantId}/stores request to retrieve the list of stores under your merchant account. You can then reassign your terminals to the specific storeId.

To make this request to Management API, you need to have an API credential with an API key and the following roles:

  • Management API—Stores read
  • Management API—Stores read and write

To retrieve the list of stores:

  1. Make a GET /merchants/{merchantId}/stores request, specifying:

    • As a path parameter:
    Parameters Required Description
    merchantId -white_check_mark- The unique identifier of the merchant account.
    • As query parameters:
    Parameters Description
    reference The reference of the store.
    pageSize The number of items to have on a page, maximum 100. The default is 10 items on a page.
    pageNumber The number of the page to fetch.
    GET /merchants/{merchantId}/stores request
    Expand view
    Copy link to code block
    Copy code
    Copy code
    curl https://management-test.adyen.com/v3/merchants/{merchantId}/stores \
    -H 'x-API-key: ADYEN_API_KEY' \
    -X GET
  2. The response returns a paginated list of stores for the specified merchant account. The data object contains the following details for every store:

    GET /merchants/{merchantId}/stores response
    Expand view
    Copy link to code block
    Copy code
    Copy code
    {
    "_links":{
    "first":{
    "href":"https://management-test.adyen.com/v3/merchants/ADYEN_MERCHANT_ACCOUNT_ID/stores?pageNumber=1&pageSize=1"
    },
    "last":{
    "href":"https://management-test.adyen.com/v3/merchants/ADYEN_MERCHANT_ACCOUNT_ID/stores?pageNumber=2&pageSize=1"
    },
    "next":{
    "href":"https://management-test.adyen.com/v3/merchants/ADYEN_MERCHANT_ACCOUNT_ID/stores?pageNumber=2&pageSize=1"
    },
    "self":{
    "href":"https://management-test.adyen.com/v3/merchants/ADYEN_MERCHANT_ACCOUNT_ID/stores?pageNumber=1&pageSize=1"
    }
    },
    "itemsTotal":2,
    "pagesTotal":1,
    "data":[
    {
    "storeId":"ST322LJ223223K5F4SQNR9XL5",
    "address":{
    "city":"Springfield",
    "country":"US",
    "line1":"200 Main Street",
    "line2":"Building 5A",
    "line3":"Suite 3",
    "postalCode":"20250",
    "stateOrProvince":"NY"
    },
    "description":"City centre store",
    "merchantId":"ADYEN_MERCHANT_ACCOUNT_ID",
    "phoneNumber":"+1813702551707653",
    "reference":"Springfield Shop",
    "status":"active",
    "_links":{
    "self":{
    "href":"https://management-test.adyen.com/v3/stores/ST322LJ223223K5F4SQNR9XL5"
    }
    }
    },
    {
    "storeId":"ST322LJ223223K5F4SQNR9XL6",
    "address":{
    "city":"North Madison",
    "country":"US",
    "line1":"1492 Townline Road",
    "line2":"Rowland Business Park",
    "postalCode":"20577",
    "stateOrProvince":"NY"
    },
    "description":"West location",
    "merchantId":"ADYEN_MERCHANT_ACCOUNT_ID",
    "phoneNumber":"+1211992213193020",
    "reference":"Second Madison store",
    "status":"active",
    "_links":{
    "self":{
    "href":"https://management-test.adyen.com/v3/stores/ST322LJ223223K5F4SQNR9XL6"
    }
    }
    }
    ]
    }
  3. From the response, save the storeId and make a assign terminals request to reassign the terminal to that store.

Get terminal details

To get the list of terminals for your API credential, you can use the GET /terminals request. The response also returns the details of each terminal, like the id, the account level to which it is assigned, the IP address, and the software version of the terminal.
You can then use these details to reassign a specific terminal to another level in your account structure.

To make this request to Management API, you need to have an API credential with an API key and the following roles:

  • Management API — Terminal actions read

To retrieve the list of terminals and their details:

  1. Make a GET /terminals request.

    GET /terminals request
    Expand view
    Copy link to code block
    Copy code
    Copy code
    curl https://management-test.adyen.com/v3/terminals \
    -H 'x-API-key: ADYEN_API_KEY' \
    -X GET
  2. The response returns a paginated list of terminals for the specified API credential. The data object contains the following details for every terminal:

    Parameters Description
    assignment An object with:
    • companyId: the unique identifier of the company account to which terminal is assigned.
    • merchantId: the unique identifier of the merchant account to which terminal is assigned.
    • reassignmentTarget: indicates where the terminal is in the process of being reassigned to.
    • status: the status of the reassignment.
    • storeId: the unique identifier of the store to which terminal is assigned.
    connectivity Information about bluetooth, cellular, ethernet, and Wi-Fi connectivity for the terminal.
    firmwareVersion The software release currently in use on the terminal.
    id The unique identifier of the terminal.
    lastActivityAt Date and time of the last activity on the terminal. Not included when the last activity was more than 14 days ago.
    lastTransactionAt Date and time of the last transaction on the terminal. Not included when the last transaction was more than 14 days ago.
    model The model name of the terminal.
    serialNumber The serial number of the terminal.
    GET /terminals response
    Expand view
    Copy link to code block
    Copy code
    Copy code
    {
    "_links": {
    "first": {
    "href": "https://management-test.adyen.com/v3/terminals?pageNumber=1&pageSize=20"
    },
    "last": {
    "href": "https://management-test.adyen.com/v3/terminals?pageNumber=1&pageSize=20"
    },
    "next": {
    "href": "https://management-test.adyen.com/v3/terminals?pageNumber=1&pageSize=20"
    },
    "self": {
    "href": "https://management-test.adyen.com/v3/terminals?pageNumber=0&pageSize=20"
    }
    },
    "itemsTotal": 3,
    "pagesTotal": 1,
    "data": [
    {
    "id": "AMS1-000150183300032",
    "model": "AMS1",
    "serialNumber": "000150183300032",
    "firmwareVersion": "Castles_Android 1.89.4",
    "assignment": {
    "companyId": "ADYEN_COMPANY_ACCOUNT",
    "merchantId": "ADYEN_MERCHANT_ACCOUNT",
    "storeId": "YOUR_STORE_ID",
    "status": "reassignmentInProgress",
    "reassignmentTarget": {
    "inventory": true
    }
    },
    "connectivity": {
    "cellular": {
    "iccid": "6006491286999921374"
    },
    "wifi": {
    "ipAddress": "198.51.100.1",
    "macAddress": "C4:6E:33:26:36:E4"
    }
    }
    },
    {
    "id": "S1EL-000158204503066",
    "model": "S1EL",
    "serialNumber": "000158204503066",
    "firmwareVersion": "Castles_Android 1.94.5",
    "assignment": {
    "companyId": "ADYEN_COMPANY_ACCOUNT",
    "merchantId": "ADYEN_MERCHANT_ACCOUNT",
    "storeId": "YOUR_STORE_ID",
    "status": "boarded"
    },
    "connectivity": {
    "cellular": {
    "iccid": "6006491286999921374"
    },
    "wifi": {
    "ipAddress": "198.51.100.2",
    "macAddress": "C4:41:37:33:E5:0F"
    }
    }
    },
    {
    "id": "V400m-347353332",
    "model": "V400m",
    "serialNumber": "347-353-332",
    "firmwareVersion": "Verifone_VOS 1.94.4",
    "assignment": {
    "companyId": "ADYEN_COMPANY_ACCOUNT",
    "merchantId": "ADYEN_MERCHANT_ACCOUNT",
    "storeId": "YOUR_STORE_ID",
    "status": "boarded"
    },
    "connectivity": {
    "bluetooth": {
    "macAddress": "a4:60:11:af:79:76"
    },
    "cellular": {
    "iccid": "6006491286999921374"
    },
    "ethernet": {
    "macAddress": "a4:60:11:61:e4:c9"
    },
    "wifi": {
    "ipAddress": "198.51.100.3",
    "macAddress": "d0:17:69:7c:02:4d",
    "ssid": "YOUR_WIFI"
    }
    }
    }
    ]
    }
  3. From the response, save the terminalId and make a assign terminals request to reassign the terminal to a different account level.

Assign terminals

To make a terminal ready to accept payments, you need to assign it to a store or a merchant account representing a store, and then board the terminal.

To make the POST /terminals/{terminalId}/reassign request, you need to have an API credential with an API key and the following roles:

  • Management API—Assign Terminal
  1. Prepare for assigning terminals:

    • Make sure that you have terminalId of the terminal that you want to reassign. To get the ID, make a GET /terminals request.
    • Optionally, make a GET /merchants/{merchantId}/stores request to retrieve an overview of your stores and their details.
  2. Make a POST /terminals/{terminalId}/reassign request, specifying:

    • As a path parameter:
    Parameter Required Description
    terminalId -white_check_mark- The unique identifier of the payment terminal in the format [Device model]-[Serial number].
    • As request parameters:
    Parameter Description
    companyId The unique identifier of the company account to which the terminal is reassigned.
    merchantId The unique identifier of the merchant account to which the terminal is reassigned. When reassigning terminals to a merchant account, you must specify the inventory field.
    inventory Indicates if the terminal is reassigned to the inventory of the merchant account.
    • If true, the terminal is in the inventory of the merchant account and cannot process transactions.
    • If false, the terminal is reassigned directly to the merchant account and can process transactions.
    storeId The unique identifier of the store to which the terminal is reassigned.
    Reassign a terminal to your store
    Expand view
    Copy link to code block
    Copy code
    Copy code
    curl https://management-test.adyen.com/v3/terminals/AMS1-000150183300032/reassign \
    -H 'x-API-key: ADYEN_API_KEY' \
    -H 'content-type: application/json' \
    -X POST \
    -d '{
    "storeId": "YOUR_STORE_ID"
    }'
    Reassign a terminal to your merchant account
    Expand view
    Copy link to code block
    Copy code
    Copy code
    curl https://management-test.adyen.com/v3/terminals/AMS1-000150183300032/reassign \
    -H 'x-API-key: ADYEN_API_KEY' \
    -H 'content-type: application/json' \
    -X POST \
    -d '{
    "merchantId": "YOUR_MERCHANT_ID",
    "inventory": "false"
    }'
  3. Because the request is processed asynchronously, the response returns HTTP status code 200/OK.

    When the terminal is online, it downloads and applies the new configuration. The terminal is then ready for boarding.

Terminal assignment complete webhooks

In some cases, it is not possible to assign a terminal synchronously and we schedule the assignment for later. To let you know when the assignment is completed, we send you a Terminal assignment complete webhook. This is sent as an HTTP callback to your server.

To set up receiving Terminal assignment complete webhooks, follow the general instructions to set up webhooks:

  1. Expose an endpoint on your server where you want to receive the webhooks.
  2. Set up the webhooks in your Customer Area as described, but select Terminal assignment complete (not Standard webhook) as the webhook type you want to add.
  3. Make sure that you accept webhooks correctly.
  4. Test and go live.

After you set up the webhook type, you will receive Terminal assignment complete webhook with:

  • The account (assignedToAccount) or store (assignedToStore) that the terminal is assigned to.
  • The date and time when the assignment was carried out.
  • The ID of the terminal involved.
Copy code
{
"assignedToAccount": "ADYEN_MERCHANT_ACCOUNT",
"assignedToStore": "YOUR_STORE",
"eventDate": "2020-06-03 22:42:13.840 CEST",
"pspReference": "NO_PSP_REF_1591216933840470",
"uniqueTerminalId": "V400m-324689776"
}

See also