EPS API Collection (1.0.0)

Download OpenAPI specification:Download

Group: EPS APIs

Definition: Interface for using a EPS system from a point of sale system (POS), device, or site system.

Description: Add Electronic Payment Server definition.

You can find out more about apis at the Open Retailing website.

Associated API Definitions in this Group:

  • (none)

Use Case Summary: The basic use case flows are:

  • Authorization
  • Completion/FinancialAdvice
  • Sale/Payment
  • Reversal
  • Refund/Return

Architecture: This API uses RESTFul Web Services, associating required functionality with resources and operations on those resources. For handling unsolicited events from the service provider to the client, it uses HTML5 constructs such as "Server Sent Events" and "Web Sockets".

Referenced Standards:

Scope: OpenRetailing

Part of: EPS API Group

Authentication

apikey

apikey security scheme as defined by Open Retailing API Implementation Guide - Security.

Security Scheme Type API Key
Header parameter name: X-Api-Key

basic

This API supports Basic Authentication.

Security Scheme Type HTTP
HTTP Authorization Scheme basic

oauth2

OAuth2 security scheme as defined by Open Retailing API Implementation Guide - Security.

Security Scheme Type OAuth2
authorizationCode OAuth Flow
Authorization URL: https://gitlab.openretailing.org
Token URL: https://gitlab.openretailing.org/oauth/token
Scopes:
  • read -

    Grants read access

  • write -

    Grants write access

  • admin -

    Grants access to admin operations

poi

Contains the list of functions related to POI (Point of Interaction) registration. A POI can include a Payment Terminal (PinPad), scanner, or printer.

/POIs

Retrieve the list of POIs with logical ID that have been registered with the EPS

Authorizations:
header Parameters
openretailing-connection-id
required
string (connectionIDType) [ 1 .. 1024 ] characters

The Site Reference ID returned in the "connect" call.

Responses

Response samples

Content type
application/json
{
  • "statusReturn": {
    },
  • "poiAddresses": [
    ]
}

/POIs/iccStart/{iccStartID}

Upon receiving the iccStartAvailableEvent, request information about the transaction needed to process an ICC card

Authorizations:
path Parameters
iccStartID
required
string (id40BaseType) [ 1 .. 40 ] characters

The icc start identifier created by the EPS.

header Parameters
openretailing-connection-id
required
string (connectionIDType) [ 1 .. 1024 ] characters

The Site Reference ID returned in the "connect" call.

Responses

Response samples

Content type
application/json
{
  • "statusReturn": {
    },
  • "iccStartID": "ab64d0b2-8b31-4c90-a3b3-ff83cb10f8f8",
  • "iccAmount": {
    },
  • "chipData": [
    ]
}

/POIs/iccStart/{iccStartID}

Provide information gathered during ICC processing.

Authorizations:
path Parameters
iccStartID
required
string (id40BaseType) [ 1 .. 40 ] characters

The icc start identifier created by the EPS.

Request Body schema: application/json
connectionID
required
string (connectionIDType) [ 1 .. 1024 ] characters

The site reference ID is created by the Host. It is used in subsequent requests. It avoids the need to send all vendor information on subsequent requests.

iccStartID
required
string (id40BaseType) [ 1 .. 40 ] characters

40 character ID

required
object (statusReturn)

'status' (defined in the API Data dictionary as "statusReturn.yaml") should be the first property returned at the beginning of reach response. 'timestamp' and 'result' are required properties inside this 'status' property. 'error' and 'message' give more information and may therefore unsuitable for production, and are therefore optional. 'uuid' is included specifically for FACTORY INTEGRATION, FACTORY PRE-CERTIFICATION, and FACTORY CERTIFICATION support, where returned errors may use 'uuid' to provide more information (like validation results) than should be returned in a production implementation.

required
Array of objects (chipDataObject) [ 0 .. 100 ] items [ items ]

The chip data information acquired at the POI.

Responses

Request samples

Content type
application/json
{
  • "connectionID": "40641ee8-8c1b-47cb-9609-70ff4318f7f5",
  • "iccStartID": "e68ee6a7-4ce9-4981-b8a0-fc16d9b9accd",
  • "statusNotification": {
    },
  • "chipData": [
    ]
}

Response samples

Content type
application/json
{
  • "statusReturn": {
    }
}

/POIs/iccCompletion/{iccCompletionID}

Upon receiving the iccCompletionAvailableEvent, request information needed to complete the ICC Transaction

Authorizations:
path Parameters
iccCompletionID
required
string (id40BaseType) [ 1 .. 40 ] characters

The icc completion identifier created by the EPS.

header Parameters
openretailing-connection-id
required
string (connectionIDType) [ 1 .. 1024 ] characters

The Site Reference ID returned in the "connect" call.

Responses

Response samples

Content type
application/json
{
  • "statusReturn": {
    },
  • "iccCompletionID": "ab64d0b2-8b31-4c90-a3b3-ff83cb10f8f8",
  • "iccAmount": {
    },
  • "chipData": [
    ]
}

/POIs/iccCompletion/{iccCompletionID}

Provide information gathered from completing the ICC processing

Authorizations:
path Parameters
iccCompletionID
required
string (id40BaseType) [ 1 .. 40 ] characters

The icc completion identifier created by the EPS.

Request Body schema: application/json
connectionID
required
string (connectionIDType) [ 1 .. 1024 ] characters

The site reference ID is created by the Host. It is used in subsequent requests. It avoids the need to send all vendor information on subsequent requests.

iccCompletionID
required
string (id40BaseType) [ 1 .. 40 ] characters

40 character ID

required
object (statusReturn)

'status' (defined in the API Data dictionary as "statusReturn.yaml") should be the first property returned at the beginning of reach response. 'timestamp' and 'result' are required properties inside this 'status' property. 'error' and 'message' give more information and may therefore unsuitable for production, and are therefore optional. 'uuid' is included specifically for FACTORY INTEGRATION, FACTORY PRE-CERTIFICATION, and FACTORY CERTIFICATION support, where returned errors may use 'uuid' to provide more information (like validation results) than should be returned in a production implementation.

required
Array of objects (chipDataObject) [ 0 .. 100 ] items [ items ]

The chip data information acquired at the POI.

Responses

Request samples

Content type
application/json
{
  • "connectionID": "40641ee8-8c1b-47cb-9609-70ff4318f7f5",
  • "iccCompletionID": "e68ee6a7-4ce9-4981-b8a0-fc16d9b9accd",
  • "statusNotification": {
    },
  • "chipData": [
    ]
}

Response samples

Content type
application/json
{
  • "statusReturn": {
    }
}

/POIs/iccCardRemoval/{iccCardRemovalID}

Upon receiving the iccRemoveCardEvent, Provide information confirming card removal

Authorizations:
path Parameters
iccCardRemovalID
required
string (id40BaseType) [ 1 .. 40 ] characters

The icc card removal identifier created by the EPS.

Request Body schema: application/json
connectionID
required
string (connectionIDType) [ 1 .. 1024 ] characters

The site reference ID is created by the Host. It is used in subsequent requests. It avoids the need to send all vendor information on subsequent requests.

iccCardRemovalID
required
string (id40BaseType) [ 1 .. 40 ] characters

40 character ID

required
object (statusReturn)

'status' (defined in the API Data dictionary as "statusReturn.yaml") should be the first property returned at the beginning of reach response. 'timestamp' and 'result' are required properties inside this 'status' property. 'error' and 'message' give more information and may therefore unsuitable for production, and are therefore optional. 'uuid' is included specifically for FACTORY INTEGRATION, FACTORY PRE-CERTIFICATION, and FACTORY CERTIFICATION support, where returned errors may use 'uuid' to provide more information (like validation results) than should be returned in a production implementation.

Responses

Request samples

Content type
application/json
{
  • "connectionID": "40641ee8-8c1b-47cb-9609-70ff4318f7f5",
  • "iccCardRemovalID": "e68ee6a7-4ce9-4981-b8a0-fc16d9b9accd",
  • "statusNotification": {
    }
}

Response samples

Content type
application/json
{
  • "statusReturn": {
    }
}

/POIs/aidCanidateListUpdate

This request will be performed by the POI when it needs an AID to be selected from a candidate list.

Authorizations:
Request Body schema: application/json
connectionID
required
string (connectionIDType) [ 1 .. 1024 ] characters

The site reference ID is created by the Host. It is used in subsequent requests. It avoids the need to send all vendor information on subsequent requests.

poiID
required
string (id80BaseType) [ 1 .. 80 ] characters

80 character ID

aidCandidateList
required
Array of strings (iccAIDType) <= 10 items [ items [ 10 .. 40 ] characters ([A-Fa-f0-9]{10,32}) ]

Responses

Request samples

Content type
application/json
{
  • "connectionID": "40641ee8-8c1b-47cb-9609-70ff4318f7f5",
  • "poiID": "703ef3b9-dc4b-4240-a81a-85e392ac9fb6",
  • "aidCandidateList": [
    ]
}

Response samples

Content type
application/json
{
  • "statusReturn": {
    },
  • "aidCandidateList": [
    ]
}

/POIs/registration

The POI registers with its unique identifier and capabilities.

Authorizations:
Request Body schema: application/json
poiID
required
string (id80BaseType) [ 1 .. 80 ] characters

80 character ID

logicalID
string (id4BaseType) [ 1 .. 4 ] characters

4 character ID

object (poiCapabilitiesObject)

POI address object.

Responses

Request samples

Content type
application/json
{
  • "poiID": "1231231231209382018302130",
  • "capabilities": {
    }
}

Response samples

Content type
application/json
{
  • "statusReturn": {
    }
}

/POIs/cardAcquisition/{cardAcquisitionID}

Upon receiving the cardAcquisitionEvent, request information about the transaction needed to acquire the card information

Authorizations:
path Parameters
cardAcquisitionID
required
string (id40BaseType) [ 1 .. 40 ] characters

The card acquistion identifier is a unique identifier created by the EPS when requesting a card acquisition from the POI.

Responses

Response samples

Content type
application/json
{
  • "statusReturn": {
    },
  • "timestamp": "2021-06-18T12:55:00",
  • "chipData": [
    ],
  • "prompt": {
    }
}

/POIs/cardAcquisition/{cardAcquisitionID}

Provide information acquired from the card

Authorizations:
path Parameters
cardAcquisitionID
required
string (id40BaseType) [ 1 .. 40 ] characters

The card acquistion identifier is a unique identifier created by the EPS when requesting a card acquisition from the POI.

Request Body schema: application/json
connectionID
required
string (connectionIDType) [ 1 .. 1024 ] characters

The site reference ID is created by the Host. It is used in subsequent requests. It avoids the need to send all vendor information on subsequent requests.

required
object (cardDataObject)

The entry method and the card instrument acquired by the POI.

poiID
required
string (id80BaseType) [ 1 .. 80 ] characters

80 character ID

Responses

Request samples

Content type
application/json
{
  • "connectionID": "40641ee8-8c1b-47cb-9609-70ff4318f7f5",
  • "poiID": "703ef3b9-dc4b-4240-a81a-85e392ac9fb6",
  • "cardInstrument": {
    }
}

Response samples

Content type
application/json
{
  • "statusReturn": {
    }
}

/prompt/{promptID}

Upon receiving the promptAvailableEvent, request information about the prompt desired

Authorizations:
header Parameters
openretailing-connection-id
required
string (connectionIDType) [ 1 .. 1024 ] characters

The Site Reference ID returned in the "connect" call.

Responses

Response samples

Content type
application/json
{
  • "statusReturn": {
    },
  • "promptID": "e68ee6a7-4ce9-4981-b8a0-fc16d9b9accd",
  • "lines": [
    ],
  • "input": {
    }
}

/prompt/{promptID}

Provide information about the prompt data acquired.

Authorizations:
Request Body schema: application/json
connectionID
required
string (connectionIDType) [ 1 .. 1024 ] characters

The site reference ID is created by the Host. It is used in subsequent requests. It avoids the need to send all vendor information on subsequent requests.

promptID
required
string (id40BaseType) [ 1 .. 40 ] characters

40 character ID

required
object (statusReturn)

'status' (defined in the API Data dictionary as "statusReturn.yaml") should be the first property returned at the beginning of reach response. 'timestamp' and 'result' are required properties inside this 'status' property. 'error' and 'message' give more information and may therefore unsuitable for production, and are therefore optional. 'uuid' is included specifically for FACTORY INTEGRATION, FACTORY PRE-CERTIFICATION, and FACTORY CERTIFICATION support, where returned errors may use 'uuid' to provide more information (like validation results) than should be returned in a production implementation.

value
string [ 0 .. 500 ] characters

Responses

Request samples

Content type
application/json
{
  • "connectionID": "40641ee8-8c1b-47cb-9609-70ff4318f7f5",
  • "promptID": "e68ee6a7-4ce9-4981-b8a0-fc16d9b9accd",
  • "statusNotification": {
    },
  • "value": "yes"
}

Response samples

Content type
application/json
{
  • "statusReturn": {
    }
}

/receipt/{receiptID}

Upon receiving the receiptAvailableEvent, request the receipt data

Authorizations:
header Parameters
openretailing-connection-id
required
string (connectionIDType) [ 1 .. 1024 ] characters

The Site Reference ID returned in the "connect" call.

Responses

Response samples

Content type
application/json
{
  • "statusReturn": {
    },
  • "receiptID": "0d1d9f51-6540-4cbd-ae0c-13bd224e8057",
  • "mandatory": "yes",
  • "numberOfCopies": 2,
  • "target": "customer",
  • "lines": [
    ]
}

/receipt/{receiptID}

Provide confirmation that the receipt has been printed. It is an optional message only required if the mandatory flag in the reponse to the GET /receipt request is set to yes.

Authorizations:
Request Body schema: application/json
connectionID
string (connectionIDType) [ 1 .. 1024 ] characters

The site reference ID is created by the Host. It is used in subsequent requests. It avoids the need to send all vendor information on subsequent requests.

receiptID
string (id40BaseType) [ 1 .. 40 ] characters

40 character ID

object (statusReturn)

'status' (defined in the API Data dictionary as "statusReturn.yaml") should be the first property returned at the beginning of reach response. 'timestamp' and 'result' are required properties inside this 'status' property. 'error' and 'message' give more information and may therefore unsuitable for production, and are therefore optional. 'uuid' is included specifically for FACTORY INTEGRATION, FACTORY PRE-CERTIFICATION, and FACTORY CERTIFICATION support, where returned errors may use 'uuid' to provide more information (like validation results) than should be returned in a production implementation.

Responses

Request samples

Content type
application/json
{
  • "connectionID": "40641ee8-8c1b-47cb-9609-70ff4318f7f5",
  • "receiptID": "e68ee6a7-4ce9-4981-b8a0-fc16d9b9accd",
  • "statusNotification": {
    }
}

Response samples

Content type
application/json
{
  • "statusReturn": {
    }
}

/POIs/{poiID}/aidsConfiguration

Upon receiving the iccUpdateAIDConfigurationEvent, request the AID configuration for the POI ID

Authorizations:
path Parameters
poiID
required
string (id80BaseType) [ 1 .. 80 ] characters

The Point of Interaction ID for the device performing the operation.

header Parameters
openretailing-connection-id
required
string (connectionIDType) [ 1 .. 1024 ] characters

The Site Reference ID returned in the "connect" call.

Responses

Response samples

Content type
application/json
{
  • "statusReturn": {
    },
  • "aidsConfiguration": [
    ]
}

/POIs/{poiID}/aidRules

Upon receiving the iccUpdateAIDRulesEvent, request the AID rules for the POI ID

Authorizations:
path Parameters
poiID
required
string (id80BaseType) [ 1 .. 80 ] characters

The Point of Interaction ID for the device performing the operation.

header Parameters
openretailing-connection-id
required
string (connectionIDType) [ 1 .. 1024 ] characters

The Site Reference ID returned in the "connect" call.

Responses

Response samples

Content type
application/json
{
  • "statusReturn": {
    },
  • "timestamp": "2009-11-20T17:30:50",
  • "aidRules": [
    ]
}

/POIs/{poiID}/iccCAPK

Upon receiving the iccUpdateICCCAPKEvent, request the ICC Keys for the POI ID

Authorizations:
path Parameters
poiID
required
string (id80BaseType) [ 1 .. 80 ] characters

The Point of Interaction ID for the device performing the operation.

header Parameters
openretailing-connection-id
required
string (connectionIDType) [ 1 .. 1024 ] characters

The Site Reference ID returned in the "connect" call.

Responses

Response samples

Content type
application/json
{
  • "statusReturn": {
    },
  • "keys": [
    ]
}

/POIs/{poiID}/iccTerminalConfiguration

Upon receiving the iccUpdateAIDICCConfigurationEvent, request the ICC configuration for the POI ID

Authorizations:
path Parameters
poiID
required
string (id80BaseType) [ 1 .. 80 ] characters

The Point of Interaction ID for the device performing the operation.

header Parameters
openretailing-connection-id
required
string (connectionIDType) [ 1 .. 1024 ] characters

The Site Reference ID returned in the "connect" call.

Responses

Response samples

Content type
application/json
{
  • "statusReturn": {
    },
  • "configuration": [
    ]
}