Terminal-2 icon

Barcode scanning

Scan barcodes with a payment terminal.

On payment terminals with a barcode scanner, you can press the dedicated button to activate the scanner. If it scans a barcode, the terminals pastes the barcode content into an Android app installed on the terminal that has an input text box. This works on the following Android payment terminals: S1E Barcode, S1E2L, S1F2L, and S1U2.

You can also enable the software keyboard feature where the terminal simulates typing the barcode content as individual characters. For this to work, your app needs to listen for software keyboard events.

Enable barcode scanner

You can enable barcode scanning per company, merchant accounts, store or terminal level:

  1. Log into your Customer Area.
  2. Go to Terminal Settings > Hardware > Barcode scanner.
  3. Under Enable barcode scanner button, select Enabled.
  4. To play a sound after a successful scan, under Play a beep select Enabled.
  5. To place a separator after each scan, under Separator choose one of the following options:
    • New line: passes the content of each scanned barcode in a new line. This option is set by default.
    • Custom: in the Custom character field, specify the character that you want to use as a separator.
  6. Select Save.

Additionally, you can contact our to enable:

  • Adding a prefix to scanned barcodes. You need to provide the characters you want added in front of every scanned barcode content.
  • Software keyboard feature, where the barcode content is typed into your Android app as individual keyboard events. With this integration, your app needs to listen for software keyboard events.

For advanced barcode-scanning use cases, see how you can activate the barcode scanner with a Terminal API request.

Use barcode scanner with Terminal API

If you want more control over how the barcode scanner is activated, cancelled, or the duration of the scan you can send Terminal API requests.
When you receive the barcode content in the response, you need to implement a way to process it in your app depending on your use case.

Before you begin, make sure that you have built a local or cloud Terminal API integration:

Activate barcode scanner

To scan a barcode you only need to send a request to activate the barcode scanner. On a successful scan, there is no need to end the session.

  1. Create a JSON object with the following data elements:

    Parameter Required Description
    Session -white_check_mark- An object with:
    • Id: your unique reference of the scanning session.
    • Type: Once activates the barcode scanner.
    Operation -white_check_mark- An object with:
    • Type: ScanBarcode.
    • TimeoutMs: how long the barcode scanner stays on, in milliseconds (from 0 to 30000).
    Activate barcode scanner
    Expand view
    Copy link to code block
    Copy code
    Copy code
    {
    "Session": {
    "Id": 12345,
    "Type": "Once"
    },
    "Operation": [
    {
    "Type": "ScanBarcode",
    "TimeoutMs": 5000
    }
    ]
    }
  2. Encode the JSON object to Base64.

    Base64 encoded message
    Expand view
    Copy link to code block
    Copy code
    Copy code
    ewogICAgIlNlc3Npb24iOnsKICAgICAgICAiSWQiOjEyMzQ1LAogICAgICAgICJUeXBlIjoiT25jZSIKICAgIH0sCiAgICAiT3BlcmF0aW9uIjpbCiAgICAgICAgewogICAgICAgICAgICAiVHlwZSI6IlNjYW5CYXJjb2RlIiwKICAgICAgICAgICAgIlRpbWVvdXRNcyI6NTAwMAogICAgICAgIH0KICAgIF0KfQ==
  3. Make a POST request to a Terminal API endpoint, specifying:

    • MessageHeader: the standard SaleToPOIRequest.MessageHeader object. Specify:

      Parameter Required Description
      ProtocolVersion -white_check_mark- 3.0
      MessageClass -white_check_mark- Service
      MessageCategory -white_check_mark- Admin
      MessageType -white_check_mark- Request
      ServiceID -white_check_mark- 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 -white_check_mark- Your unique ID for the POS system component to send this request from.
      POIID -white_check_mark- 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.
    Activate barcode scanner request
    Expand view
    Copy link to code block
    Copy code
    Copy code
    {
    "SaleToPOIRequest": {
    "MessageHeader": {
    "ProtocolVersion": "3.0",
    "MessageClass": "Service",
    "MessageCategory": "Admin",
    "MessageType": "Request",
    "ServiceID": "POSSystemID12345",
    "SaleID": "S00101",
    "POIID": "S1EL-324688179"
    },
    "AdminRequest": {
    "ServiceIdentification": "ewogICAgIlNlc3Npb24iOnsKICAgICAgICAiSWQiOjEyMzQ1LAogICAgICAgICJUeXBlIjoiT25jZSIKICAgIH0sCiAgICAiT3BlcmF0aW9uIjpbCiAgICAgICAgewogICAgICAgICAgICAiVHlwZSI6IlNjYW5CYXJjb2RlIiwKICAgICAgICAgICAgIlRpbWVvdXRNcyI6NTAwMAogICAgICAgIH0KICAgIF0KfQ=="
    }
    }
    }
  4. In the response, note:

    • If successful, the following fields are returned:
      • Response.Result: Success
      • AdditionalResponse: contains the Base64-encoded barcode content.
    • If unsuccessful, the following fields are returned:
      • Response.Result: Failure
      • ErrorCondition: Cancel, Aborted, UnavailableService, or NotFound
      • AdditionalResponse: contains the reason for failure as a Base64-encoded string. Decoding the string results in a message of the following format: { "message": "Admin ScanBarcode request canceled due to Timeout" }.

    The format of the AdditionalResponse can be a Base64-encoded or URL-encoded. To always receive the AdditionalResponse in one of those formats, contact our Support Team.

    Copy code
    {
    "SaleToPOIResponse": {
    "AdminResponse": {
    "Response": {
    "Result": "Success",
    "AdditionalResponse": "eyAiQmFyY29kZSI6IHsgIkRhdGEiOiAiODYwMDE5NzQxNjgyNCIsICJTeW1ib2xvZ3kiOiAiUVJfQ09ERSIgfSB9"
    }
    },
    "MessageHeader": {
    "MessageCategory": "Admin",
    "MessageClass": "Service",
    "MessageType": "Response",
    "POIID": "S1EL-324688179",
    "ProtocolVersion": "3.0",
    "SaleID": "POSSystemID12345",
    "ServiceID": "S00101"
    }
    }
    }
  5. If Response.Result is Success, decode the Base64-encoded string in the AdditionalResponse.
    Note that this contains:

    • Barcode.Data: the content of the scanned barcode.
    • Barcode.Symbology: the format of the scanned barcode. If the symbology is not recognized, the response returns UNKNOWN.
    Decoded Base64 AdditionalResponse
    Expand view
    Copy link to code block
    Copy code
    Copy code
    {
    "Barcode":{
    "Data":"8600197416824",
    "Symbology":"QR_CODE"
    }
    }

    For more information on the Terminal API request structure, see the Terminal API fundamentals.

If you want to turn off the barcode scanner before the timeout, you need to send a request to cancel the scanning session.

Cancel scanning session

If you want to cancel the activation of the terminal's barcode scanner before the specified timeout, you need to send an AdminRequest with the Session.Type End.

  1. Create a JSON object with the following data elements:

    Parameter Required Description
    ServiceIdentification.Session -white_check_mark- An object with:
    • Id: the unique reference of the session.
    • Type: End cancels the scanning session.
    Data elements in JSON format
    Expand view
    Copy link to code block
    Copy code
    Copy code
    {
    "Session": {
    "Id": 12345,
    "Type": "End"
    }
    }
  2. Encode the JSON object to Base64.

    Base64 encoded message
    Expand view
    Copy link to code block
    Copy code
    Copy code
    	ewogICAiU2Vzc2lvbiI6ewogICAgICAiSWQiOjEyMzQ1LAogICAgICAiVHlwZSI6IkVuZCIKICAgfQp9
  3. Make a POST request to a Terminal API endpoint, specifying:

    • MessageHeader: the standard SaleToPOIRequest.MessageHeader object. Specify:

      Parameter Required Description
      ProtocolVersion -white_check_mark- 3.0
      MessageClass -white_check_mark- Service
      MessageCategory -white_check_mark- Admin
      MessageType -white_check_mark- Request
      ServiceID -white_check_mark- 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 -white_check_mark- Your unique ID for the POS system component to send this request from.
      POIID -white_check_mark- 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.
    End scanning session
    Expand view
    Copy link to code block
    Copy code
    Copy code
    {
    "SaleToPOIRequest":{
    "MessageHeader":{
    "ProtocolVersion":"3.0",
    "MessageClass":"Service",
    "MessageCategory":"Admin",
    "MessageType":"Request",
    "ServiceID":"S00101",
    "SaleID":"POSSystemID12345",
    "POIID":"S1EL-324688179"
    },
    "AdminRequest":{
    "ServiceIdentification": "ewogICAiU2Vzc2lvbiI6ewogICAgICAiSWQiOjEyMzQ1LAogICAgICAiVHlwZSI6IkVuZCIKICAgfQp9"
    }
    }
    }
  4. If the cancel request succeeds, in the AdminResponse note:

    • Response.Result: Success
    • AdditionalResponse: contains the Base64-encoded message. Decoding the string results in a message of the following format: { "message": "Admin ScanBarcode request was successfully canceled" }

    The format of the AdditionalResponse can be a Base64-encoded or URL-encoded. To always receive the AdditionalResponse in one of those formats, contact our Support Team.

    End scanning session response - success
    Expand view
    Copy link to code block
    Copy code
    Copy code
    {
    "SaleToPOIResponse": {
    "MessageHeader": {
    "ProtocolVersion": "3.0",
    "MessageClass": "Service",
    "MessageCategory": "Admin",
    "MessageType": "Request",
    "ServiceID": "POSSystemID12345",
    "SaleID": "S00101",
    "POIID": "V400m-324688179"
    },
    "AdminResponse": {
    "Response": {
    "Result": "Success",
    "AdditionalResponse": "eyAibWVzc2FnZSI6ICJBZG1pbiBTY2FuQmFyY29kZSByZXF1ZXN0IHdhcyBzdWNjZXNzZnVsbHkgY2FuY2VsZWQiIH0="
    }
    }
    }
    }

Barcode symbologies

Symbologies are barcode formats that a payment terminal can recognize, and they depend on the decoder of the barcode scanner. If the barcode is scanned successfully but the symbology is not recognized, the response still returns the content inside Barcode.Data, but the Barcode.Symbology is UNKNOWN.

Our payment terminals recognize the following barcode symbologies:

S1E Barcode S1E2L S1F2L S1U2
CODABAR -white_check_mark- -white_check_mark- -white_check_mark- -white_check_mark-
CODE 128 -white_check_mark- -white_check_mark- -white_check_mark- -x-
CODE 39 -white_check_mark- -white_check_mark- -white_check_mark- -white_check_mark-
Data Matrix -white_check_mark- -white_check_mark- -white_check_mark- -white_check_mark-
EAN-8 -white_check_mark- -white_check_mark- -white_check_mark- -white_check_mark-
EAN-13 -white_check_mark- -white_check_mark- -white_check_mark- -white_check_mark-
GS1 -white_check_mark- -white_check_mark- -white_check_mark- -white_check_mark-
Matrix 2 of 5 -white_check_mark- -white_check_mark- -white_check_mark- -white_check_mark-
MaxiCode -white_check_mark- -white_check_mark- -white_check_mark- -x-
PDF417 -white_check_mark- -white_check_mark- -white_check_mark- -x-
QR Code -white_check_mark- -white_check_mark- -white_check_mark- -white_check_mark-
UPC-A -white_check_mark- -white_check_mark- -white_check_mark- -white_check_mark-
UPC-E -white_check_mark- -white_check_mark- -white_check_mark- -white_check_mark-

See also