Download OpenAPI specification:Download
UniTerm securely handles sensitive cardholder data independent of the merchant's application software. In addition, UniTerm provides a simple, consistent interface to multiple payment acceptance devices, such as card readers, pinpads, and terminals.
UniTerm is dependant on and intended to be used in conjunction with the Payment Server. UniTerm handles the customer-facing portion of the payment, while the Payment Server handles authorization requests using the customer's account information that UniTerm has securely read.
Communication between UniTerm and the Payment Server uses a TLS-encrypted connection. Account information is never transmitted in the clear between UniTerm and the Payment Server.
At the heart of the protocol is a simple key/value pair message structure, very similar to the Payment Server Specification. In fact, many of these key/value pairs sent to UniTerm are simply passed-through to the Payment Server for processing.
The API utilizes robust key/value pairs for flexibility. To make transport easier, all pairs are comprised of strings.
All authentication is managed by the Payment Server.
To ensure that the integrated POS is removed from PCI PA-DSS scope, UniTerm requires that sensitive data is never returned from the Payment Server. To enact this, UniTerm only allows merchant sub-users to authenticate. Sub-users are unique usernames that are tied to a merchant user with their own individual password, but they possess only a subset of the allowed permissions. These unique usernames, when passed to UniTerm, are prefixed with the username of the merchant user and delimited with a colon (:). (e.g. merchuser:subuser). UniTerm requires the sub-user to have the "obscure sensitive information" flag set, or it will generate a failure.
UniTerm also requires these permissions to operate:
More permissions may be required based on the POS operations supported. Please consult with your integration and development team for the features used.
UniTerm supports prompting the cardholder for a tip amount at the time of
payment. To do this, the Payment Server merchant account must have the
merch_tippercent
setting configured. Sending the u_flags parameter NOTIP
will disable this prompting.
When a customer has chosen to add a tip amount to a transaction, the amount
provided by the POS to UniTerm will be incremented to reflect the tip amount,
and examount
will be populated with the tip amount when the transaction is
sent to the Payment Server.
In the response returned by UniTerm, the tip amount will be provided to the POS
in the u_tip
response parameter.
Note: Special care should be taken to validate whether or not the authamount
response parameter is returned, indicating a partial authorization occurred,
that split tender operations can occur. When prompting for a second payment
method, an integrator should use the NOTIP u_flags in order to avoid tip
prompting on the second method of payment, and respect the returned u_tip
response for the chosen tip amount from the original response.
UniTerm supports prompting a cardholder for cashback when a Debit or EBT Cash
Benefits card is used for payment. UniTerm will automatically perform such
prompting when the Payment Server account is configured to support cashback. The
NOCASHBACK
u_flags parameter will disable this behavior.
When a customer has chosen to request cashback with a transaction, the amount
provided by the POS to UniTerm will be incremented to reflect the cashback
amount and the cashbackamount
parameter will be populated with the cashback
amount when the transaction is sent to the Payment Server.
In the response returned by UniTerm, the cashback amount will be provided to
the POS in the u_cashback
response parameter.
Note: Special care should be taken to validate if the authamount
response
parameter is returned, indicating a partial authorization occurred. If the
returned amount is less than the requested amount plus u_cashback
then the POS
must decide on the proper course of action. For instance if the authamount
is
greater than requested, but less than the amount plus u_cashback
then partial
cashback would be provided to the cardholder. Otherwise if the authamount
is
less than the requested amount, then the u_cashback
returned should be
completely ignored and the POS would need to prompt the cardholder for another
method of payment.
UniTerm supports EBT prompting when an EBT card is used for payment. If the
u_foodamount
parameter is populated with a non-zero dollar amount to indicate
the amount of the transaction that applies to qualified food purchases (or for
Transaction Start with a value of maybe), then the customer will also be
prompted if they would like to use Food Stamps (SNAP) or Cash Benefits to
complete the transaction. When the cardholder makes the selection, UniTerm
will internally rewrite the action=sale
request parameter to
action=ebtfssale
or action=ebtcbsale
as appropriate.
For Transaction Start transactions where u_foodamount=maybe
, the integrator
must send a valid u_foodamount
value with Transaction Finish, or else the
transaction will be aborted.
If Food Stamps (SNAP) was selected, u_wasfood
will be returned as yes/true to
indicate this. If the requested amount is greater than u_foodamount
, then a
partial authorization will be returned (as indicated by the authamount
response parameter), indicating the amount of the authorization was less than
the requested. The returned authamount
may be less than the u_foodamount
if
there are insufficient funds. Otherwise, it will be equal to the u_foodamount
requested.
If a partial authorization is performed, the merchant should perform a
split-tender operation and prompt for another method of payment for the
remainder, which may also be EBT. The requested amount and u_foodamount
need to
be adjusted accordingly on the next request based on the amounts previously
authorized.
EMV transactions, by nature, are much more complex than traditional magnetic stripe transactions. UniTerm hides this complexity from the application software. For instance, in the case of magnetic stripe and EMV transactions, the application software will send the request to UniTerm. UniTerm will use the device capabilities (like EMV contact and RFID) and the merchant account configuration to handle the appropriate prompting and flow aspects related to the determined capabilities. The application software simply needs to send a Transaction Request and let UniTerm handle the rest.
Integrators unfamiliar with EMV may notice some specific flow cases that seem counterintuitive at first. This section is meant to address these EMV-specific cases.
If a chip-enabled card is swiped on an EMV-capable terminal, it is mandated that the user be prompted to insert the card. This is an EMV certification requirement that cannot be lifted. It is meant to prevent fraud and to train consumers to insert their cards.
There are certain thresholds negotiated between the card and terminal which may request a chip-enabled card that is presented as a tap transaction to be inserted instead. When this occurs, it can be due to a number of factors, like fraud mitigation, or because the card has determined that it needs to be updated (for insert transactions, an issuer can choose to return issuer scripts to remotely reprogram cards).
If a chip-enabled card is prompted to be swiped, this is usually an indication that there was a chip malfunction and the cardholder should have their card replaced, which is called a technical fallback. It is expected that, at some point in the future, a technical fallback will be disallowed due to fraud concerns. The other possibility is that the terminal does not support the card's application ID.
The cardholder verification method is negotiated between the card and the terminal. If both the card and terminal support PIN entry, it may be chosen as the desired verification method. Consumers in the US may not expect to enter a PIN on their credit cards, but it is common among foreign cards.
The cardholder verification method is negotiated between the card and the terminal. They may negotiate Signature, PIN, or what is called NoCVM, which means no cardholder verification is required for the transaction. The decision is strictly made based on the terminal capabilities and card capabilities.
It is a requirement by the card brands that a card cannot be prompted for insertion if it is presented as a tap and read as MSD. This can happen due to a terminal not being configured for contactless EMV support, or if a chip is malfunctioning.
EMV cards have the ability to make decisions about the transaction before it is even processed. From time to time, a merchant may see a chip-capable card presented that results in an immediate decline before requesting cardholder verification or connecting to a processing institution. This could happen because the card has exceeded some internal threshold, or the card has received a remote script on a previous transaction to explicitly block transactions, such as a card block or application block.
Pre-formatted receipt processing has been added to simplify generation of receipts that are in compliance with the rules dictated by the card brands. Data is output in a series of sections so that merchants may insert their own custom data in-between sections of brand-required data as they see fit.
The u_rcpt
key/value pair is sent in the request to UniTerm to indicate
whether or not to output a series of pre-formatted receipt blocks. This can
also specify format requirements. If set to yes
, it will simply use the
receipt formatting for plain text, suitable for printing on a standard receipt
printer. Other output formats are supported and discussed in the transaction
operations that can generate receipts.
The parameters listed are only the subset that apply to UniTerm. A small subset of interchange or other required parameters is also documented. Additional request parameters specific to the Payment Server may need to be specified and passed through. The Payment Server may pass back additional response data.
Internally, all keys are a flat list and are not hierarchical. Throughout the documentation, parameters may be grouped together under a named object. The object name is not evaluated when processing the request. All key/value pairs are moved to the top level.
Parameter grouping is present simply to make it easier to understand the relationship between parameters. The parameters themselves do not need to be part of the documented object they may be under.
Standin will take place when UniTerm cannot connect to the payment server or when the following codes are returned. The code and msoft codes indicate a connectivity failure to the processor.
The phard codes indicate the processor returned a connectivity failure either within their systems, or the brand network, or to the issuer. Not all processors return connectivity failure information. Most will return a generic decline without an indication if it was declined by the issuer or not.
code
:
TIMEOUT
msoft_code
:
CONN_MAXATTEMPTS
CONN_MAXSENDS
phard_code
:
NOREPLY
RETRY
SYSTEM_ERROR
In order for standin to happen it must be enabled in the UniTerm configuration. All parameters related to standin must also be configured in order for it to be setup.
Not all card types can be approved standin. Merchant configuration can place restrictions on what types of cards and under what circumstances transactions can be standin approved. Please see the merchant account configuration on the payment server for more details in regard to these limits.
Finally, some processing insinuations place restrictions on standin approvals which can influence if a transaction can standin approve.
A value denoting a time can take on one of two different types:
Formatted times can either be a fixed time or based on an offset. The time zone for the date is the merchant's timezone.
Fixed formats are very similar to written date and times.
Formats:
Offsets take this format:
+ or -
magnitude
space
modifier
Modifiers:
+1 day
-5 years
now
- current date/timeepoch
- Unix timestamp of 0 = Jan 1, 1970 00:00:00 UTCAny keys that end with _ts
, such as last_modified_ts
, are a Unix timestamp.
A Unix timestamp is the number of seconds since Jan 1, 1970 00:00:00 UTC.
That date and time is called the "epoch", and its value is 0.
Unix timestamps are always in UTC time and do not have a time zone.
API Keys and HTTP Basic authentication are currently supported.
An API key ID and secret need to be generated to use API keys.
The UniTerm username and password for the account setup to run transactions is used with the Basic authentication method.
API keys are composed of two parts. A public key id and a private key secret. The key secret must be protected by the integrator. Keys can represent a user or profile. It is recommended to create a profile key for unattended POS systems so the keys are not invalided if a user leaves.
These allow users to disassociate their username and password from authentication. They will be able to manage and revoke keys in case an application (POS) is compromised. Also, integrated applications will be able to use a key instead of storing the user's username and password.
API Key information is passed in the following headers when using ReST:
X-API-KEY-ID: <key id>
X-API-KEY: <key secret>
If using the libmonetra key value pair protocol, api keys use these fields:
auth_apikey_id
auth_apikey_secret
import urllib.request
import urllib.parse
URL = 'https://uniterm.test.transafe.com:8123/api/v1/transaction/quick'
KEY_ID = '@TEST_API_KEY_ID@'
KEY_SECRET = '@TEST_API_KEY_SECRET@'
headers = {
'X-API-KEY-ID': KEY_ID,
'X-API-KEY': KEY_SECRET,
}
data = urllib.parse.urlencode([
('u_device', 'IPCLIENT:78909876'),
('u_devicetype', 'ingenico_upp'),
('u_foodamount', '92.44'),
('u_id', '0IDS425S'),
('action', 'sale'),
('amount', '92.44'),
('nsf', 'yes'),
('ordernum', '6893'),
('u_rcpt', 'yes')
])
req = urllib.request.Request(URL, data=data.encode(), headers=headers, method='POST')
with urllib.request.urlopen(req) as o:
print(o.read().decode('utf-8'))
using System;
using System.IO;
using System.Net;
using System.Text;
class AuthExample
{
static void Main(string[] args)
{
var url = "https://uniterm.test.transafe.com:8123/api/v1/transaction/quick";
var key_id = "@TEST_API_KEY_ID@";
var key_secret = "@TEST_API_KEY_SECRET@";
var json = "{\"u_device\":\"IPCLIENT:78909876\",\"u_devicetype\":\"ingenico_upp\",\"u_foodamount\":\"92.44\",\"u_id\":\"0IDS425S\",\"action\":\"sale\",\"amount\":\"92.44\",\"nsf\":\"yes\",\"ordernum\":\"6893\",\"u_rcpt\":\"yes\"}";
ServicePointManager.Expect100Continue = false;
ServicePointManager.UseNagleAlgorithm = true;
ServicePointManager.SecurityProtocol = SecurityProtocolType.Tls12;
var request = WebRequest.Create(url);
request.Method = "POST";
request.Headers.Add("X-API-KEY-ID", key_id);
request.Headers.Add("X-API-KEY", key_secret);
request.ContentType = "application/json";
request.ContentLength = json.Length;
Stream requestStream = request.GetRequestStream();
requestStream.Write(Encoding.ASCII.GetBytes(json), 0, json.Length);
requestStream.Close();
using (var response = (HttpWebResponse)request.GetResponse()) {
Console.WriteLine(response.StatusDescription);
using (var dataStream = response.GetResponseStream()) {
using (var reader = new StreamReader(dataStream)) {
Console.WriteLine(reader.ReadToEnd());
}
}
}
}
}
<?php
$url = "https://uniterm.test.transafe.com:8123/api/v1/transaction/quick";
$key_id = "@TEST_API_KEY_ID@";
$key_secret = "@TEST_API_KEY_SECRET@";
$opts = array(
"http"=>array(
"method"=>"POST",
"header" => "X-API-KEY-ID:" . $key_id . "\r\n" . "X-API-KEY: " . $key_secret . "\r\n"
"content"=>array(
"u_device"=>"IPCLIENT:78909876",
"u_devicetype"=>"ingenico_upp",
"u_foodamount"=>"92.44",
"u_id"=>"0IDS425S",
"action"=>"sale",
"amount"=>"92.44",
"nsf"=>"yes",
"ordernum"=>"6893",
"u_rcpt"=>"yes"
),
),
);
$context = stream_context_create($opts);
$file = file_get_contents($url, false, $context);
echo $file;
?>
HTTP Basic Authentication involves sending the Authorization
HTTP header with the
type Basic
and the base64 encoded username:password
.
E.g.
Authorization: Basic dXNlcm5hbWU6cGFzc3dvcmQ=
If the authorization data is not present the response code 401 and
WWW-Authenticate
header is returned in the response indicating the
authentication that must be used.
WWW-Authenticate: Basic realm="Payment Server Resource"
Basic auth does not allow colons (':') to be present in usernames. However, most usernames for the system will include a colon. To deal with this, all colons must be replaced with a pipe ('|').
If a username contains a pipe, please contact support.
user:sub -> user|sub
For example, take the username test_retail:public
and a password of
publ1ct3st
. Therefore, the username must be transformed to
test_retail|public
, resulting in basic authentication data to be encoded of
test_retail|public:publ1ct3st
. The resulting Authentication header data
would be Authorization: Basic dGVzdF9yZXRhaWx8cHVibGljOnB1YmwxY3Qzc3Q=
We do not recommend using most programming language's build in credential
management APIs. Such as .Net's HTTPPasswordMgrWithDefaultRealm
with
a HTTPBasicAuthHandler
object. Or Python's NetworkCredential
with the
CredentialCache
. Instead we recommend sending the authorization data
directly/explicitly in the request header.
Using the language API credential management can increase the transaction processing time. Many language APIs will first send the request without authorization data. The server will respond with a 401 authorization data required response. The request will be sent a second time with the authorization data. The extra request that is known to fail adds additional and unnecessary, messaging which increases request processing time.
import urllib.request
import urllib.parse
import base64
URL = 'https://uniterm.test.transafe.com:8123/api/v1/transaction/quick'
USER = 'test_retail|public'
PASS = 'publ1ct3st'
auth_data = '%s:%s' % (USER, PASS)
auth_data = base64.b64encode(auth_data.encode()).decode('utf-8')
headers = {
'Authorization': 'Basic %s' % auth_data
}
data = urllib.parse.urlencode([
('u_device', 'IPCLIENT:78909876'),
('u_devicetype', 'ingenico_upp'),
('u_foodamount', '92.44'),
('u_id', '0IDS425S'),
('action', 'sale'),
('amount', '92.44'),
('nsf', 'yes'),
('ordernum', '6893'),
('u_rcpt', 'yes')
])
req = urllib.request.Request(URL, data=data.encode(), headers=headers, method='POST')
with urllib.request.urlopen(req) as o:
print(o.read().decode('utf-8'))
using System;
using System.IO;
using System.Net;
using System.Text;
class AuthExample
{
static void Main(string[] args)
{
var url = "https://uniterm.test.transafe.com:8123/api/v1/transaction/quick";
var username = "test_retail|public";
var password = "publ1ct3st";
var authData = System.Convert.ToBase64String(System.Text.Encoding.UTF8.GetBytes(username + ":" + password));
var json = "{\"u_device\":\"IPCLIENT:78909876\",\"u_devicetype\":\"ingenico_upp\",\"u_foodamount\":\"92.44\",\"u_id\":\"0IDS425S\",\"action\":\"sale\",\"amount\":\"92.44\",\"nsf\":\"yes\",\"ordernum\":\"6893\",\"u_rcpt\":\"yes\"}";
ServicePointManager.Expect100Continue = false;
ServicePointManager.UseNagleAlgorithm = true;
ServicePointManager.SecurityProtocol = SecurityProtocolType.Tls12;
var request = WebRequest.Create(url);
request.Method = "POST";
request.Headers.Add("Authorization", "Basic " + authData);
request.ContentType = "application/json";
request.ContentLength = json.Length;
Stream requestStream = request.GetRequestStream();
requestStream.Write(Encoding.ASCII.GetBytes(json), 0, json.Length);
requestStream.Close();
using (var response = (HttpWebResponse)request.GetResponse()) {
Console.WriteLine(response.StatusDescription);
using (var dataStream = response.GetResponseStream()) {
using (var reader = new StreamReader(dataStream)) {
Console.WriteLine(reader.ReadToEnd());
}
}
}
}
}
Using the language API credential management increase the transaction processing time. Using the language API will first send the request without authorization data. The server will respond with a 401 authorization data required response. The request will be sent a second time with the authorization data. The extra request that is known to fail adds additional and unnecessary, messaging which increases request processing time.
<?php
$url = "https://uniterm.test.transafe.com:8123/api/v1/transaction/quick";
$username = "test_retail|public";
$password = "publ1ct3st";
$opts = array(
"http"=>array(
"method"=>"POST",
"header" => "Authorization: Basic " . base64_encode("$username:$password")
"content"=>array(
"u_device"=>"IPCLIENT:78909876",
"u_devicetype"=>"ingenico_upp",
"u_foodamount"=>"92.44",
"u_id"=>"0IDS425S",
"action"=>"sale",
"amount"=>"92.44",
"nsf"=>"yes",
"ordernum"=>"6893",
"u_rcpt"=>"yes"
),
),
);
$context = stream_context_create($opts);
$file = file_get_contents($url, false, $context);
echo $file;
?>
When UniTerm is configured to listen on a public network connection it unauthenticated commands are restricted and must authenticate using an HMAC. Please see the UniTerm Guide for configuration information and HMAC generation.
To prevent the HMAC values from being sent as query arguments, the data should be sent as header fields. Following is the mapping from the UniTerm Guide fields to HTTP headers.
Protocol key | HTTP Header equivalent |
---|---|
u_req_sequence |
X-auth-sequence |
u_req_timestamp |
X-auth-timestamp |
u_req_hmacsha256 |
X-auth-hmacsha256 |
When a profile configuration used by a given user/device is updated on the payment server, UniTerm needs to be informed of this change in order to update the settings in the device.
The u_action=deviceload
can be issued immediately to by the user
account that will be using the updated profile. This will force UniTerm to
pull the updated configuration from payment server and load it into the device.
It is recommended integrators directly support this operation and provide a way for clerks to trigger this action. This way they can use configuration changes from the payment server immediately.
UniTerm will check for configuration changes on an account every 2-3 hours. The exact time is within this range to help stagger load on the payment server. If a change is detected the device will automatically be reloaded.
While the interval is every 2-3 hours the check does not take place until a transaction is performed with the account and using the device. Upon starting the transaction the check takes place and if configuration changes are detected the device will automatically reload the configuration. For most devices this will take less than 1 second and thus will not cause a customer disruption.
The check happens after 2-3 hours since the last check but only on the start of a transaction for several reasons.
UniTerm is designed to simply the device integration process including supporting both EMV and contactless payments. It provides a standardized API that work with multiple devices across several device vendors.
UniTerm can be used with a local installation, bundled into an mobile application as a library, or as a cloud service.
uniterm_example.ini
from the installation directory into the following directory
depending on your platform. The file should be named uniterm.ini
when placing in the
configuration directory. As indicated in the following full file paths.
a. Windows: %APPDATA%/UniTerm/uniterm.ini
b. macOS: ~/Library/Application Support/UniTerm/uniterm.ini
c. Linux/Unix: ~/.config/UniTerm/uniterm.ini
ini
file. The file is documented and explains
every section and setting. However, the only setting that needs to be verified and possibly changed
is the gateway host setting. The configuration is designed to be secure by default and no chagnes
should be necessary to have the UniTerm working out of the box.USB<>SERIAL
device will be assigned a COM
port. Such as COM3
.txnquick
documentation for a complete example of running a transaction.The library package provides a header file with a function that allows sending the key value pairs from the API to UniTerm. Please see the library package documentation for additional information.
If you're using a cloud service offering of UniTerm no setup of UniTerm is required. The device needs to support cloud connections. The device also needs to be configured to connect to the cloud system. Typically, this is done by loading a configuration package to the device. Ingencio devices will have a 'tgz' package with all necessary configuration contained within.
A configured device will automatically connect to the cloud system. At which point the device can be used with the web based POS or virtual terminal being offered. Additionally, some devices can function as stand alone devices that do not require additional web based systems to initiate transactions. Please speak with your UniTerm representative on how to convert a cloud device into a stand alone cloud device.
Attempts to cancel an outstanding transaction request
Requires username
, password
and u_id
, which must match the pending
request.
This will return u_errorcode=PENDING_TRAN
if the transaction cannot be
canceled. This could happen, for instance, while waiting on a response from the
Payment Server, or if the device doesn't support canceling the outstanding
request.
libmonetra KVS equivalent for endpoint
u_action
= cancel
u_id required | string Example: 1234 A unique ID (generated by the calling application) that identifies the transaction. This is used for checking the status or canceling the transaction. Without this ID, the transaction state cannot be queried. |
curl -X POST 'https://uniterm.test.transafe.com:8123/api/v1/transaction/U656789324/cancel' --basic -u 'test_retail|public:publ1ct3st' -d ''
{- "code": "AUTH",
- "u_errorcode": "SUCCESS",
- "verbiage": "Transaction approved"
}
Attempts to cancel an outstanding transaction request
Requires username
, password
and u_id
, which must match the pending
request.
This will return u_errorcode=PENDING_TRAN
if the transaction cannot be
canceled. This could happen, for instance, while waiting on a response from the
Payment Server, or if the device doesn't support canceling the outstanding
request.
libmonetra KVS equivalent for endpoint
u_action
= cancel
u_id required | string Example: 1234 A unique ID (generated by the calling application) that identifies the transaction. This is used for checking the status or canceling the transaction. Without this ID, the transaction state cannot be queried. |
curl -X DELETE 'https://uniterm.test.transafe.com:8123/api/v1/transaction/U656789324' --basic -u 'test_retail|public:publ1ct3st'
{- "code": "AUTH",
- "u_errorcode": "SUCCESS",
- "verbiage": "Transaction approved"
}
Prompts for card entry and returns non-financial card data
This is only valid on non-financial cards, like manager cards or private-label gift cards, that are not processed through the Payment Server.
The card must be swiped, and the reader must be configured to return the card in unencrypted form.
libmonetra KVS equivalent for endpoint
u_action
= cardrequest
u_device | string(?i)(HID|USB|SDK)(:?|:.*)|(SER||MFI|BT|BLE|BL... This specifies the path of the card entry device. Required parameter unless
performing a GUI-based action (such as manual keyed entry, or swiping via a
keyboard emulation card reader). Required if
Note: Requires:
|
u_devicetype | string Enum: "ingenico_rba" "ingenico_upp" "ingenico_tcpx" "idtech_spectrum_pro" "idtech_augusta" "bbpos_cros" "equinox_epe" "idtech_neo" "epson_esc" "star_line" "seiko" "generic_barcode" The unique device type supported as found via a device types request. Requires:
Values:
|
{- "u_device": "SER:COM3",
- "u_devicetype": "ingenico_upp"
}
{- "code": "AUTH",
- "u_errorcode": "SUCCESS",
- "verbiage": "Transaction approved",
- "trackdata": "string"
}
Requests the current status of a pending transaction
Requires username
, password
and u_id
fields, which must match the pending
request. This will provide a textual verbiage response suitable for clerk
display.
This will normally return a u_errorcode
of SUCCESS
when either the
transaction is still in-progress or UniTerm is in a cleanup phase after a
transaction. Will return a value of UID_NOT_FOUND
if the request is no longer
being processed.
libmonetra KVS equivalent for endpoint
u_action
= status
u_id required | string Example: 1234 A unique ID (generated by the calling application) that identifies the transaction. This is used for checking the status or canceling the transaction. Without this ID, the transaction state cannot be queried. |
curl -X GET 'https://uniterm.test.transafe.com:8123/api/v1/transaction/U656789324/status' --basic -u 'test_retail|public:publ1ct3st'
{- "code": "AUTH",
- "u_errorcode": "SUCCESS",
- "verbiage": "Transaction approved",
- "u_cancelable": "yes",
- "u_status": "WORKING",
- "u_external_select_rec": "string",
- "u_external_select": "string"
}
Requests to finish a QuickChip transaction
Requires the integrator send the same u_id
as was sent with the initial
txnstart request. The integrator can choose to send additional parameters to
pass through to the Payment Server with this request based on information
returned from txnstart (e.g. card type). Will return the same response
parameters as txnrequest.
libmonetra KVS equivalent for endpoint
u_action
= txnfinish
u_id required | string Example: 1234 A unique ID (generated by the calling application) that identifies the transaction. This is used for checking the status or canceling the transaction. Without this ID, the transaction state cannot be queried. |
nsf | string Enum: "yes" "no" Approve transactions even if there are non-sufficient funds (NSF). This will
result in a partial approval if there are not enough funds to cover the full
requested amount, in which case an Gift cards default to If a partial approval is received, it will automatically be reversed internally
and the returned decline will have Values:
|
laneid | string\d+ Identifier for the register/lane running the transaction Mastercard requires that each register or lane at a merchant's location be uniquely identified. This should be a numeric value no more than 8 digits in length. However, some processors cannot support more than 2 or 4 digits. It should be sent on all transactions, as it is not possible to know the card type prior to starting a transaction. |
ordernum | string <= 128 characters Order number An order number is required for all Card Not Present (e.g. Mail Order / Telephone Order and E-commerce) transactions, all transactions for the Restaurant industry, and all Level 2 cards such as Purchase or Corporate cards. Since it is not possible to know the card type prior to a request to UniTerm, an order number should be sent on all transactions. An order number is alphanumeric. However, for the restaurant industry, it should be numeric only. Processors are limited in the number of characters that can be sent as part of a transaction. Non restaurant industry will only have 25 characters sent and restaurant will only have 6. |
amount required | string\d*(\.\d{0,2})? Amount of money, including decimal. E.g This is the total amount and is an aggregate of all supplementary amounts. |
tax | string(?i)NT|\d*(\.\d{0,2})? Amount of tax that applies to the order The value 'NT' without the quotes indicates a non-taxable (tax exempt) transaction. Requires:
|
examount | string\d+(\.\d{0,2})? Extra amount. Typically used for Retail and Restaurant tipping Requires:
|
surchargeamount | string\d+(\.\d{0,2})? Amount of funds being received as a surcharge Surcharging rules are governed by the card brands. Compliance with brand rules need to be handled by the integrator because they can be highly industry and business type specific. Also, some times when people talk about surcharging, they are really talking about service fees, convenience fees, or cash discounts, which all have different rules even though they are closely related. Surcharges are the ONLY type that requires registration with the card brands and requires you pass the data along to the processing institution and therefore onto the card issuer. This is what this field does, is just pass that data along for transactions matching the surcharge classification (but not service fees, convenience fees, or cash discounts). Requires:
|
u_foodamount | string(?i)maybe|\d+(\.\d{0,2})? Food-qualified amount (E.g. 1.00), or 'maybe' to indicate possible EBT-qualified full or partial order If qualified amount is known, this is the amount of qualified food purchases for EBT Food Stamps (SNAP). It must be provided in order to allow customer prompting for EBT Food Stamp payments when an EBT card is presented. Otherwise, only EBT Cash Benefits will be available for payment. This is a subset of the transaction During a If the amount passed in |
u_tipeligibleamount | string\d+(\.\d{0,2})? Amount of the order that can be used for tip calculation Used when part of the order is not tip eligible or with a split payment method that's not capable of adding a tip. An example of when part of the order is not tip eligible A beauty salon wants to prompt for tip, but the order also has products that shouldn't be included in the tip-percent calculation. The customer would only tip on the service, not any products they're purchasing. If the customer is prompted for a tip, the order total will still show on the screen, so the clerk will need to let the customer know that the tip is only going to be applied to the eligible part of the order. The screen doesn't show only the tip-eligible amount, because the customer could be confused if part of the order is missing, or if the order suddenly jumps to a much larger amount after entering their tip. An example of split payment A customer wants to pay part of the order with a gift card. They want to use the total amount on the gift card and pay the remainder with their credit card. The total tip should be applied to the credit card part of the transaction. The gift card balance being exhausted does not leave room for the tip. Further, the customer could be confused by having to leave a tip on each part of the split order. In this situation only one payment should prompt for tip. The rest should use
the If the customer is prompted for a tip, the payment total not the order total will still show on the screen, so the clerk will need to let the customer know that the tip is going to be applied to an amount greater than what is shown on screen. The screen only shows the payment amount not the order amount, because the customer could be confused if they keep seeing the order total when they are only paying part of the total with that payment method. Notes If not sent, the entire Clerk requirements When using |
property name* additional property | string |
{- "nsf": "yes",
- "laneid": "4",
- "ordernum": "A13DDES345",
- "amount": "19.92",
- "tax": "1.29",
- "examount": "0.33",
- "surchargeamount": "1.25",
- "u_foodamount": "maybe",
- "u_tipeligibleamount": "string",
- "property1": "string",
- "property2": "string"
}
{- "code": "AUTH",
- "u_errorcode": "SUCCESS",
- "verbiage": "Transaction approved",
- "msoft_code": "INT_SUCCESS",
- "phard_code": "SUCCESS",
- "authamount": "6.50",
- "account": "XXXXXXXXXXXX1234",
- "ttid": "96748596765467",
- "u_emv_chip_malfunction": "yes",
- "u_need_signature": "yes",
- "u_tip": "string",
- "cardtype": "VISA",
- "u_cardclass": "UNKNOWN",
- "u_cashback": "string",
- "u_flowflags": "SIGCAPTURED",
- "u_standin": "yes",
- "u_wasfood": "yes",
- "property1": "string",
- "property2": "string"
}
Performs a full Transaction Request with cardholder's data
This will request that a transaction be performed. All normal Payment Server transaction parameters that may be required for processing or to comply with interchange requirements (e.g. action, amount, nsf, ordernum, etc) should be included in the request. Sensitive data, explicitly, should not be sent (e.g. trackdata, account, CVV2, PIN), as that data will be retrieved by UniTerm via a card-entry device and then forwarded to the Payment Server as part of the transaction request.
This operation is functionally similar to txnrequest. However, internally, it follows a QuickChip flow (like txnstart + txnfinish), which allows the cardholder to remove their card earlier. This may make a transaction appear to be faster to an end user.
libmonetra KVS equivalent for endpoint
u_action
= txnquick
action | string Action the Payment Server should perform on the captured data |
u_device | string(?i)(HID|USB|SDK)(:?|:.*)|(SER||MFI|BT|BLE|BL... This specifies the path of the card entry device. Required parameter unless
performing a GUI-based action (such as manual keyed entry, or swiping via a
keyboard emulation card reader). Required if
Note: Requires:
|
u_devicetype | string Enum: "ingenico_rba" "ingenico_upp" "ingenico_tcpx" "idtech_spectrum_pro" "idtech_augusta" "bbpos_cros" "equinox_epe" "idtech_neo" "epson_esc" "star_line" "seiko" "generic_barcode" The unique device type supported as found via a device types request. Requires:
Values:
|
nsf | string Enum: "yes" "no" Approve transactions even if there are non-sufficient funds (NSF). This will
result in a partial approval if there are not enough funds to cover the full
requested amount, in which case an Gift cards default to If a partial approval is received, it will automatically be reversed internally
and the returned decline will have Values:
|
laneid | string\d+ Identifier for the register/lane running the transaction Mastercard requires that each register or lane at a merchant's location be uniquely identified. This should be a numeric value no more than 8 digits in length. However, some processors cannot support more than 2 or 4 digits. It should be sent on all transactions, as it is not possible to know the card type prior to starting a transaction. |
ordernum | string <= 128 characters Order number An order number is required for all Card Not Present (e.g. Mail Order / Telephone Order and E-commerce) transactions, all transactions for the Restaurant industry, and all Level 2 cards such as Purchase or Corporate cards. Since it is not possible to know the card type prior to a request to UniTerm, an order number should be sent on all transactions. An order number is alphanumeric. However, for the restaurant industry, it should be numeric only. Processors are limited in the number of characters that can be sent as part of a transaction. Non restaurant industry will only have 25 characters sent and restaurant will only have 6. |
u_flags | string Enum: "DEVICEONLY" "GUIONLY" "KEY" "AVS" "CVV" "GIFTPIN" "NOEXPDATE" "NOTIP" "NOCASHBACK" "NOCONFIRM" "NOSIGNATURE" "DELAYRESPONSE" "CARDMETA" "NOSTANDIN" "PERSISTDEVICE" "EXTERNALSELECT" "DENYLISTQUEUE" Multiple flags may be sent per data ticket request. All flags are separated by a pipe (|) symbol. Flag values (pipe separated):
|
u_language | string Enum: "en" "fr" "es" "de" "it" Used to override terminal defaults for display of text prompts. Not all devices support all languages. Values:
|
u_id | string A unique ID (generated by the calling application) that identifies the transaction. This is used for checking the status or canceling the transaction. Without this ID, the transaction state cannot be queried. |
u_rcpt | string The A value of A value of All other values are key/value pairs indicating formatting configurations, separated by semicolons, as in this example:
Receipt configuration options:
|
amount | string\d*(\.\d{0,2})? Amount of money, including decimal. E.g This is the total amount and is an aggregate of all supplementary amounts. |
tax | string(?i)NT|\d*(\.\d{0,2})? Amount of tax that applies to the order The value 'NT' without the quotes indicates a non-taxable (tax exempt) transaction. Requires:
|
examount | string\d+(\.\d{0,2})? Extra amount. Typically used for Retail and Restaurant tipping Requires:
|
surchargeamount | string\d+(\.\d{0,2})? Amount of funds being received as a surcharge Surcharging rules are governed by the card brands. Compliance with brand rules need to be handled by the integrator because they can be highly industry and business type specific. Also, some times when people talk about surcharging, they are really talking about service fees, convenience fees, or cash discounts, which all have different rules even though they are closely related. Surcharges are the ONLY type that requires registration with the card brands and requires you pass the data along to the processing institution and therefore onto the card issuer. This is what this field does, is just pass that data along for transactions matching the surcharge classification (but not service fees, convenience fees, or cash discounts). Requires:
|
u_foodamount | string(?i)maybe|\d+(\.\d{0,2})? Food-qualified amount (E.g. 1.00), or 'maybe' to indicate possible EBT-qualified full or partial order If qualified amount is known, this is the amount of qualified food purchases for EBT Food Stamps (SNAP). It must be provided in order to allow customer prompting for EBT Food Stamp payments when an EBT card is presented. Otherwise, only EBT Cash Benefits will be available for payment. This is a subset of the transaction During a If the amount passed in |
u_tipeligibleamount | string\d+(\.\d{0,2})? Amount of the order that can be used for tip calculation Used when part of the order is not tip eligible or with a split payment method that's not capable of adding a tip. An example of when part of the order is not tip eligible A beauty salon wants to prompt for tip, but the order also has products that shouldn't be included in the tip-percent calculation. The customer would only tip on the service, not any products they're purchasing. If the customer is prompted for a tip, the order total will still show on the screen, so the clerk will need to let the customer know that the tip is only going to be applied to the eligible part of the order. The screen doesn't show only the tip-eligible amount, because the customer could be confused if part of the order is missing, or if the order suddenly jumps to a much larger amount after entering their tip. An example of split payment A customer wants to pay part of the order with a gift card. They want to use the total amount on the gift card and pay the remainder with their credit card. The total tip should be applied to the credit card part of the transaction. The gift card balance being exhausted does not leave room for the tip. Further, the customer could be confused by having to leave a tip on each part of the split order. In this situation only one payment should prompt for tip. The rest should use
the If the customer is prompted for a tip, the payment total not the order total will still show on the screen, so the clerk will need to let the customer know that the tip is going to be applied to an amount greater than what is shown on screen. The screen only shows the payment amount not the order amount, because the customer could be confused if they keep seeing the order total when they are only paying part of the total with that payment method. Notes If not sent, the entire Clerk requirements When using |
property name* additional property | string |
{- "action": "sale",
- "u_device": "SER:COM3",
- "u_devicetype": "ingenico_upp",
- "nsf": "yes",
- "laneid": "4",
- "ordernum": "A13DDES345",
- "u_flags": "NOSIGNATURE|CARDMETA|DELAYRESPONSE",
- "u_language": "en",
- "u_id": "1234",
- "u_rcpt": "yes",
- "amount": "19.92",
- "tax": "1.29",
- "examount": "0.33",
- "surchargeamount": "1.25",
- "u_foodamount": "maybe",
- "u_tipeligibleamount": "string",
- "property1": "string",
- "property2": "string"
}
{- "code": "AUTH",
- "u_errorcode": "SUCCESS",
- "verbiage": "Transaction approved",
- "msoft_code": "INT_SUCCESS",
- "phard_code": "SUCCESS",
- "authamount": "6.50",
- "account": "XXXXXXXXXXXX1234",
- "ttid": "96748596765467",
- "u_emv_chip_malfunction": "yes",
- "u_need_signature": "yes",
- "u_tip": "string",
- "cardtype": "VISA",
- "u_cardclass": "UNKNOWN",
- "u_cashback": "string",
- "u_flowflags": "SIGCAPTURED",
- "u_standin": "yes",
- "u_wasfood": "yes",
- "property1": "string",
- "property2": "string"
}
Performs a full Transaction Request with cardholder's data
This will request that a transaction be performed. All normal Payment Server transaction parameters that may be required for processing or to comply with interchange requirements (e.g. action, amount, nsf, ordernum, etc) should be included in the request. Sensitive data, explicitly, should not be sent (e.g. trackdata, account, CVV2, PIN), as that data will be retrieved by UniTerm via either the GUI or a card-entry device and then forwarded to the Payment Server as part of the transaction request.
UniTerm will fully control the transaction flow and user prompting. This request should only be used when card data entry is required as part of the transaction. For other operations, passthrough may be a more appropriate action.
libmonetra KVS equivalent for endpoint
u_action
= txnrequest
action | string Action the Payment Server should perform on the captured data |
u_device | string(?i)(HID|USB|SDK)(:?|:.*)|(SER||MFI|BT|BLE|BL... This specifies the path of the card entry device. Required parameter unless
performing a GUI-based action (such as manual keyed entry, or swiping via a
keyboard emulation card reader). Required if
Note: Requires:
|
u_devicetype | string Enum: "ingenico_rba" "ingenico_upp" "ingenico_tcpx" "idtech_spectrum_pro" "idtech_augusta" "bbpos_cros" "equinox_epe" "idtech_neo" "epson_esc" "star_line" "seiko" "generic_barcode" The unique device type supported as found via a device types request. Requires:
Values:
|
nsf | string Enum: "yes" "no" Approve transactions even if there are non-sufficient funds (NSF). This will
result in a partial approval if there are not enough funds to cover the full
requested amount, in which case an Gift cards default to If a partial approval is received, it will automatically be reversed internally
and the returned decline will have Values:
|
laneid | string\d+ Identifier for the register/lane running the transaction Mastercard requires that each register or lane at a merchant's location be uniquely identified. This should be a numeric value no more than 8 digits in length. However, some processors cannot support more than 2 or 4 digits. It should be sent on all transactions, as it is not possible to know the card type prior to starting a transaction. |
ordernum | string <= 128 characters Order number An order number is required for all Card Not Present (e.g. Mail Order / Telephone Order and E-commerce) transactions, all transactions for the Restaurant industry, and all Level 2 cards such as Purchase or Corporate cards. Since it is not possible to know the card type prior to a request to UniTerm, an order number should be sent on all transactions. An order number is alphanumeric. However, for the restaurant industry, it should be numeric only. Processors are limited in the number of characters that can be sent as part of a transaction. Non restaurant industry will only have 25 characters sent and restaurant will only have 6. |
u_flags | string Enum: "DEVICEONLY" "GUIONLY" "KEY" "AVS" "CVV" "GIFTPIN" "NOEXPDATE" "NOTIP" "NOCASHBACK" "NOCONFIRM" "NOSIGNATURE" "DELAYRESPONSE" "CARDMETA" "NOSTANDIN" "PERSISTDEVICE" "EXTERNALSELECT" "DENYLISTQUEUE" Multiple flags may be sent per data ticket request. All flags are separated by a pipe (|) symbol. Flag values (pipe separated):
|
u_language | string Enum: "en" "fr" "es" "de" "it" Used to override terminal defaults for display of text prompts. Not all devices support all languages. Values:
|
u_id | string A unique ID (generated by the calling application) that identifies the transaction. This is used for checking the status or canceling the transaction. Without this ID, the transaction state cannot be queried. |
u_rcpt | string The A value of A value of All other values are key/value pairs indicating formatting configurations, separated by semicolons, as in this example:
Receipt configuration options:
|
amount | string\d*(\.\d{0,2})? Amount of money, including decimal. E.g This is the total amount and is an aggregate of all supplementary amounts. |
tax | string(?i)NT|\d*(\.\d{0,2})? Amount of tax that applies to the order The value 'NT' without the quotes indicates a non-taxable (tax exempt) transaction. Requires:
|
examount | string\d+(\.\d{0,2})? Extra amount. Typically used for Retail and Restaurant tipping Requires:
|
surchargeamount | string\d+(\.\d{0,2})? Amount of funds being received as a surcharge Surcharging rules are governed by the card brands. Compliance with brand rules need to be handled by the integrator because they can be highly industry and business type specific. Also, some times when people talk about surcharging, they are really talking about service fees, convenience fees, or cash discounts, which all have different rules even though they are closely related. Surcharges are the ONLY type that requires registration with the card brands and requires you pass the data along to the processing institution and therefore onto the card issuer. This is what this field does, is just pass that data along for transactions matching the surcharge classification (but not service fees, convenience fees, or cash discounts). Requires:
|
u_foodamount | string(?i)maybe|\d+(\.\d{0,2})? Food-qualified amount (E.g. 1.00), or 'maybe' to indicate possible EBT-qualified full or partial order If qualified amount is known, this is the amount of qualified food purchases for EBT Food Stamps (SNAP). It must be provided in order to allow customer prompting for EBT Food Stamp payments when an EBT card is presented. Otherwise, only EBT Cash Benefits will be available for payment. This is a subset of the transaction During a If the amount passed in |
u_tipeligibleamount | string\d+(\.\d{0,2})? Amount of the order that can be used for tip calculation Used when part of the order is not tip eligible or with a split payment method that's not capable of adding a tip. An example of when part of the order is not tip eligible A beauty salon wants to prompt for tip, but the order also has products that shouldn't be included in the tip-percent calculation. The customer would only tip on the service, not any products they're purchasing. If the customer is prompted for a tip, the order total will still show on the screen, so the clerk will need to let the customer know that the tip is only going to be applied to the eligible part of the order. The screen doesn't show only the tip-eligible amount, because the customer could be confused if part of the order is missing, or if the order suddenly jumps to a much larger amount after entering their tip. An example of split payment A customer wants to pay part of the order with a gift card. They want to use the total amount on the gift card and pay the remainder with their credit card. The total tip should be applied to the credit card part of the transaction. The gift card balance being exhausted does not leave room for the tip. Further, the customer could be confused by having to leave a tip on each part of the split order. In this situation only one payment should prompt for tip. The rest should use
the If the customer is prompted for a tip, the payment total not the order total will still show on the screen, so the clerk will need to let the customer know that the tip is going to be applied to an amount greater than what is shown on screen. The screen only shows the payment amount not the order amount, because the customer could be confused if they keep seeing the order total when they are only paying part of the total with that payment method. Notes If not sent, the entire Clerk requirements When using |
property name* additional property | string |
{- "action": "sale",
- "u_device": "SER:COM3",
- "u_devicetype": "ingenico_upp",
- "nsf": "yes",
- "laneid": "4",
- "ordernum": "A13DDES345",
- "u_flags": "NOSIGNATURE|CARDMETA|DELAYRESPONSE",
- "u_language": "en",
- "u_id": "1234",
- "u_rcpt": "yes",
- "amount": "19.92",
- "tax": "1.29",
- "examount": "0.33",
- "surchargeamount": "1.25",
- "u_foodamount": "maybe",
- "u_tipeligibleamount": "string",
- "property1": "string",
- "property2": "string"
}
{- "code": "AUTH",
- "u_errorcode": "SUCCESS",
- "verbiage": "Transaction approved",
- "trackdata": "string",
- "msoft_code": "INT_SUCCESS",
- "phard_code": "SUCCESS",
- "authamount": "6.50",
- "account": "XXXXXXXXXXXX1234",
- "ttid": "96748596765467",
- "u_emv_chip_malfunction": "yes",
- "u_need_signature": "yes",
- "u_tip": "string",
- "cardtype": "VISA",
- "u_cardclass": "UNKNOWN",
- "u_cashback": "string",
- "u_flowflags": "SIGCAPTURED",
- "u_standin": "yes",
- "u_wasfood": "yes",
- "property1": "string",
- "property2": "string"
}
Requests to start a QuickChip transaction with cardholder's data
This is similar in function to a txnrequest message, but it does not accept a transaction amount. It needs to be followed up with a txnfinish or cancel request. Once a card is presented and the cardholder has completed any necessary verification and removed their card, a response will be returned with card information metadata such as the card type, some basic EMV card parameters, and the last 4 digits of the card number.
Though the purpose of this request is to support QuickChip, it still supports non-EMV transactions.
A u_id
unique parameter is required to be sent with this request for
completing the transaction.
libmonetra KVS equivalent for endpoint
u_action
= txnstart
action | string Action the Payment Server should perform on the captured data |
u_device required | string(?i)(HID|USB|SDK)(:?|:.*)|(SER||MFI|BT|BLE|BL... This specifies the path of the card entry device. Required parameter unless
performing a GUI-based action (such as manual keyed entry, or swiping via a
keyboard emulation card reader). Required if
Note: Requires:
|
u_devicetype required | string Enum: "ingenico_rba" "ingenico_upp" "ingenico_tcpx" "idtech_spectrum_pro" "idtech_augusta" "bbpos_cros" "equinox_epe" "idtech_neo" "epson_esc" "star_line" "seiko" "generic_barcode" The unique device type supported as found via a device types request. Requires:
Values:
|
u_flags | string Enum: "DEVICEONLY" "GUIONLY" "KEY" "AVS" "CVV" "GIFTPIN" "NOEXPDATE" "NOTIP" "NOCASHBACK" "NOCONFIRM" "NOSIGNATURE" "DELAYRESPONSE" "CARDMETA" "NOSTANDIN" "PERSISTDEVICE" "EXTERNALSELECT" "DENYLISTQUEUE" Multiple flags may be sent per data ticket request. All flags are separated by a pipe (|) symbol. Flag values (pipe separated):
|
u_language | string Enum: "en" "fr" "es" "de" "it" Used to override terminal defaults for display of text prompts. Not all devices support all languages. Values:
|
u_foodamount | string(?i)maybe|\d+(\.\d{0,2})? Food-qualified amount (E.g. 1.00), or 'maybe' to indicate possible EBT-qualified full or partial order If qualified amount is known, this is the amount of qualified food purchases for EBT Food Stamps (SNAP). It must be provided in order to allow customer prompting for EBT Food Stamp payments when an EBT card is presented. Otherwise, only EBT Cash Benefits will be available for payment. This is a subset of the transaction During a If the amount passed in |
u_id required | string A unique ID (generated by the calling application) that identifies the transaction. This is used for checking the status or canceling the transaction. Without this ID, the transaction state cannot be queried. |
u_rcpt | string The A value of A value of All other values are key/value pairs indicating formatting configurations, separated by semicolons, as in this example:
Receipt configuration options:
|
property name* additional property | string |
{- "action": "sale",
- "u_device": "SER:COM3",
- "u_devicetype": "ingenico_upp",
- "u_flags": "NOSIGNATURE|CARDMETA|DELAYRESPONSE",
- "u_language": "en",
- "u_foodamount": "maybe",
- "u_id": "1234",
- "u_rcpt": "yes",
- "property1": "string",
- "property2": "string"
}
{- "code": "AUTH",
- "u_errorcode": "SUCCESS",
- "verbiage": "Transaction approved",
- "cardtype": "VISA",
- "trackdata": "string",
- "u_cardclass": "UNKNOWN",
- "property1": "string",
- "property2": "string"
}
Close a persistent device connection
Operations using the u_flags=PERSISTDEVICE
will have the
device connection persist internally to speed up subsequent
usage of the device. This is advantageous when using a slow
to connect connective method. For example, Bluetooth LE is
a notoriously slow type in regard to to opening a connection.
In some rare situations it is necessary to close a persistent connection that is being maintained with a device. Only very specific circumstances would this be necessary.
An example, that this operation may apply to is, barcode readers.
Some barcode reads have very slow initialization when opening
a connection. Upwards of 4 seconds. The PERSISTDEVICE
flag would
be necessary to scan multiple items in a reasonable amount of time.
However, the reader will remain in a reading state with all lights on until the underlying connection is closed. This will drain battery for wireless scanners very quickly. To prevent this the following pattern should be used.
PERSISTDEVICE
flagAgain, this example is specific to barcode readers and limitations some models have. This would not apply to EMV card terminals.
Errors returned by this operation can be safely ignored.
libmonetra KVS equivalent for endpoint
u_action
= deviceunpersist
u_device required | string(?i)(HID|USB|SDK)(:?|:.*)|(SER||MFI|BT|BLE|BL... This specifies the path of the card entry device. Required parameter unless
performing a GUI-based action (such as manual keyed entry, or swiping via a
keyboard emulation card reader). Required if
Note: Requires:
|
u_devicetype required | string Enum: "ingenico_rba" "ingenico_upp" "ingenico_tcpx" "idtech_spectrum_pro" "idtech_augusta" "bbpos_cros" "equinox_epe" "idtech_neo" "epson_esc" "star_line" "seiko" "generic_barcode" The unique device type supported as found via a device types request. Requires:
Values:
|
{- "u_device": "SER:COM3",
- "u_devicetype": "ingenico_upp"
}
{- "code": "AUTH",
- "u_errorcode": "SUCCESS",
- "verbiage": "Transaction approved"
}
Provides information about the overall device condition (not configuration). Such as, paper status on printers
libmonetra KVS equivalent for endpoint
u_action
= devicecondition
u_device required | string Example: u_device=SER:COM3 This specifies the path of the card entry device. Required parameter unless
performing a GUI-based action (such as manual keyed entry, or swiping via a
keyboard emulation card reader). Required if
Note: Requires:
|
u_devicetype required | object Enum: "ingenico_rba" "ingenico_upp" "ingenico_tcpx" "idtech_spectrum_pro" "idtech_augusta" "bbpos_cros" "equinox_epe" "idtech_neo" "epson_esc" "star_line" "seiko" "generic_barcode" Example: u_devicetype=ingenico_upp The unique device type supported as found via a device types request. Requires:
Values:
|
curl -X GET 'https://uniterm.test.transafe.com:8123/api/v1/device/condition' \ --basic -u 'test_retail|public:publ1ct3st' \ -G \ -d 'u_device=IPCLIENT:78909876' \ -d 'u_devicetype=ingenico_upp'
{- "code": "AUTH",
- "u_errorcode": "SUCCESS",
- "verbiage": "Transaction approved",
- "property1": "string",
- "property2": "string"
}
Lists information about the connected device.
libmonetra KVS equivalent for endpoint
u_action
= deviceinfo
u_device required | string Example: u_device=SER:COM3 This specifies the path of the card entry device. Required parameter unless
performing a GUI-based action (such as manual keyed entry, or swiping via a
keyboard emulation card reader). Required if
Note: Requires:
|
u_devicetype required | object Enum: "ingenico_rba" "ingenico_upp" "ingenico_tcpx" "idtech_spectrum_pro" "idtech_augusta" "bbpos_cros" "equinox_epe" "idtech_neo" "epson_esc" "star_line" "seiko" "generic_barcode" Example: u_devicetype=ingenico_upp The unique device type supported as found via a device types request. Requires:
Values:
|
curl -X GET 'https://uniterm.test.transafe.com:8123/api/v1/device' \ --basic -u 'test_retail|public:publ1ct3st' \ -G \ -d 'u_device=IPCLIENT:78909876' \ -d 'u_devicetype=ingenico_upp'
{- "code": "AUTH",
- "u_errorcode": "SUCCESS",
- "verbiage": "Transaction approved",
- "device_app": "string",
- "device_appver": "string",
- "device_functionality": "string",
- "device_kernver": "string",
- "device_manuf": "string",
- "device_model": "string",
- "serialnum": "string"
}
Loads a device with EMV and/or Interac parameters
This request will start a terminal download of EMV and/or Interac parameters to
load onto the device being used. Requires username
, password
, u_device
,
and u_devicetype
parameters.
If the loading data for the device is identical to the previous load, this load will be skipped.
Please note that this process may take up to 3 or 4 minutes depending on the processing institution being used and the device being used. The device may also reboot during this process. It is strongly recommended to call this function when a lane opens. However, if it is not called, it will automatically be performed prior to the first transaction.
If the device or merchant account does not support EMV or Interac, this command will simply return success.
libmonetra KVS equivalent for endpoint
u_action
= deviceload
u_device required | string(?i)(HID|USB|SDK)(:?|:.*)|(SER||MFI|BT|BLE|BL... This specifies the path of the card entry device. Required parameter unless
performing a GUI-based action (such as manual keyed entry, or swiping via a
keyboard emulation card reader). Required if
Note: Requires:
|
u_devicetype required | string Enum: "ingenico_rba" "ingenico_upp" "ingenico_tcpx" "idtech_spectrum_pro" "idtech_augusta" "bbpos_cros" "equinox_epe" "idtech_neo" "epson_esc" "star_line" "seiko" "generic_barcode" The unique device type supported as found via a device types request. Requires:
Values:
|
u_forceload | string Enum: "yes" "no" "full" Ignore device load checks and force reload terminal configuration Values:
|
{- "u_device": "SER:COM3",
- "u_devicetype": "ingenico_upp",
- "u_forceload": "yes"
}
{- "code": "AUTH",
- "u_errorcode": "SUCCESS",
- "verbiage": "Transaction approved",
- "property1": "string",
- "property2": "string"
}
Updates the pole display (secondary monitor)
This is only valid after a Quick Chip (txnstart
) message, before txnfinish
is called.
The integrator must send the same u_id
as was sent with the initial
txnstart
request. Devices that support a pole display can have it updated
until the transaction is completed. The text to display in u_message
must be
pre-formatted for the proper width of the display.
libmonetra KVS equivalent for endpoint
u_action
= devicepolemsg
u_id required | string Example: 1234 A unique ID (generated by the calling application) that identifies the transaction. This is used for checking the status or canceling the transaction. Without this ID, the transaction state cannot be queried. |
u_message required | string Request message to show to the customer Requires:
|
{- "u_message": "Hello, Customer"
}
{- "code": "AUTH",
- "u_errorcode": "SUCCESS",
- "verbiage": "Transaction approved"
}
Prints the given text to a built-in receipt printer, if available
The text provided must be formatted properly for the given device. Only plaintext receipts are supported.
libmonetra KVS equivalent for endpoint
u_action
= deviceprint
u_device required | string(?i)(HID|USB|SDK)(:?|:.*)|(SER||MFI|BT|BLE|BL... This specifies the path of the card entry device. Required parameter unless
performing a GUI-based action (such as manual keyed entry, or swiping via a
keyboard emulation card reader). Required if
Note: Requires:
|
u_devicetype required | string Enum: "ingenico_rba" "ingenico_upp" "ingenico_tcpx" "idtech_spectrum_pro" "idtech_augusta" "bbpos_cros" "equinox_epe" "idtech_neo" "epson_esc" "star_line" "seiko" "generic_barcode" The unique device type supported as found via a device types request. Requires:
Values:
|
u_text required | string ASCII pre-formatted text to send to receipt printer Requires:
|
{- "u_device": "SER:COM3",
- "u_devicetype": "ingenico_upp",
- "u_text": "string"
}
{- "code": "AUTH",
- "u_errorcode": "SUCCESS",
- "verbiage": "Transaction approved"
}
Sends a reboot request to the device
libmonetra KVS equivalent for endpoint
u_action
= devicereboot
u_device required | string(?i)(HID|USB|SDK)(:?|:.*)|(SER||MFI|BT|BLE|BL... This specifies the path of the card entry device. Required parameter unless
performing a GUI-based action (such as manual keyed entry, or swiping via a
keyboard emulation card reader). Required if
Note: Requires:
|
u_devicetype required | string Enum: "ingenico_rba" "ingenico_upp" "ingenico_tcpx" "idtech_spectrum_pro" "idtech_augusta" "bbpos_cros" "equinox_epe" "idtech_neo" "epson_esc" "star_line" "seiko" "generic_barcode" The unique device type supported as found via a device types request. Requires:
Values:
|
{- "u_device": "SER:COM3",
- "u_devicetype": "ingenico_upp"
}
{- "code": "AUTH",
- "u_errorcode": "SUCCESS",
- "verbiage": "Transaction approved"
}
Uploads the given file to the device at the requested device path
Not all devices support the concept of file uploads.
This is typically used for updating device firmware.
libmonetra KVS equivalent for endpoint
u_action
= deviceupload
u_device required | string(?i)(HID|USB|SDK)(:?|:.*)|(SER||MFI|BT|BLE|BL... This specifies the path of the card entry device. Required parameter unless
performing a GUI-based action (such as manual keyed entry, or swiping via a
keyboard emulation card reader). Required if
Note: Requires:
|
u_devicetype required | string Enum: "ingenico_rba" "ingenico_upp" "ingenico_tcpx" "idtech_spectrum_pro" "idtech_augusta" "bbpos_cros" "equinox_epe" "idtech_neo" "epson_esc" "star_line" "seiko" "generic_barcode" The unique device type supported as found via a device types request. Requires:
Values:
|
u_b64data required | string[a-zA-Z0-9+/\n]+={0,2}[\n]* Base64-encoded file data Requires:
|
u_filename required | string The value should contain a properly formatted path for the device in use. Some devices like Ingenico RBA just want the filename with no path component. |
{- "u_device": "SER:COM3",
- "u_devicetype": "ingenico_upp",
- "u_b64data": "ABC=",
- "u_filename": "UPDATE.BIN"
}
{- "code": "AUTH",
- "u_errorcode": "SUCCESS",
- "verbiage": "Transaction approved",
- "u_needreboot": "yes"
}
Opens the device's cash drawer
libmonetra KVS equivalent for endpoint
u_action
= opencashdrawer
u_device required | string(?i)(HID|USB|SDK)(:?|:.*)|(SER||MFI|BT|BLE|BL... This specifies the path of the card entry device. Required parameter unless
performing a GUI-based action (such as manual keyed entry, or swiping via a
keyboard emulation card reader). Required if
Note: Requires:
|
u_devicetype required | string Enum: "ingenico_rba" "ingenico_upp" "ingenico_tcpx" "idtech_spectrum_pro" "idtech_augusta" "bbpos_cros" "equinox_epe" "idtech_neo" "epson_esc" "star_line" "seiko" "generic_barcode" The unique device type supported as found via a device types request. Requires:
Values:
|
{- "u_device": "SER:COM3",
- "u_devicetype": "ingenico_upp"
}
{- "code": "AUTH",
- "u_errorcode": "SUCCESS",
- "verbiage": "Transaction approved"
}
u_device required | string Example: u_device=SER:COM3 This specifies the path of the card entry device. Required parameter unless
performing a GUI-based action (such as manual keyed entry, or swiping via a
keyboard emulation card reader). Required if
Note: Requires:
|
u_devicetype required | object Enum: "ingenico_rba" "ingenico_upp" "ingenico_tcpx" "idtech_spectrum_pro" "idtech_augusta" "bbpos_cros" "equinox_epe" "idtech_neo" "epson_esc" "star_line" "seiko" "generic_barcode" Example: u_devicetype=ingenico_upp The unique device type supported as found via a device types request. Requires:
Values:
|
curl -X GET 'https://uniterm.test.transafe.com:8123/api/v1/device/barcode' \ --basic -u 'test_retail|public:publ1ct3st' \ -G \ -d 'u_device=IPCLIENT:78909876' \ -d 'u_devicetype=ingenico_upp'
{- "code": "AUTH",
- "u_errorcode": "SUCCESS",
- "verbiage": "Transaction approved",
- "u_barcode": "string"
}
Closes an existing tab
If a device is not specified, this works the same as force closing a tab. When using a device, the customer will be prompted to accept the amount and sign, if necessary.
libmonetra KVS equivalent for endpoint
u_action
= tab
u_tab
= close
ttid required | string Example: 96748596765467 Transaction identifier |
u_up_amount | string-?\d+(\.\d{0,2})? Tabs can have the stored amount increased or decreased using the For example, the current amount is $15.00. Sending Note: |
amount | string\d*(\.\d{0,2})? Amount of money, including decimal. E.g This is the total amount and is an aggregate of all supplementary amounts. |
tax | string(?i)NT|\d*(\.\d{0,2})? Amount of tax that applies to the order The value 'NT' without the quotes indicates a non-taxable (tax exempt) transaction. |
examount | string\d+(\.\d{0,2})? Extra amount. Typically used for Retail and Restaurant tipping |
cashbackamount | string\d*(\.\d{0,2})? Amount of funds requested as cash to be given to the customer |
surchargeamount | string\d+(\.\d{0,2})? Amount of funds being received as a surcharge Surcharging rules are governed by the card brands. Compliance with brand rules need to be handled by the integrator because they can be highly industry and business type specific. Also, some times when people talk about surcharging, they are really talking about service fees, convenience fees, or cash discounts, which all have different rules even though they are closely related. Surcharges are the ONLY type that requires registration with the card brands and requires you pass the data along to the processing institution and therefore onto the card issuer. This is what this field does, is just pass that data along for transactions matching the surcharge classification (but not service fees, convenience fees, or cash discounts). |
clerkid | string <= 2048 characters Identifier for the clerk running the transaction |
comments | string <= 2048 characters User-defined comments related to the transaction |
custref | string <= 128 characters Customer reference number Typically, a customer PO number but can be other customer reference number |
ordernum | string <= 128 characters Order number An order number is required for all Card Not Present (e.g. Mail Order / Telephone Order and E-commerce) transactions, all transactions for the Restaurant industry, and all Level 2 cards such as Purchase or Corporate cards. Since it is not possible to know the card type prior to a request to UniTerm, an order number should be sent on all transactions. An order number is alphanumeric. However, for the restaurant industry, it should be numeric only. Processors are limited in the number of characters that can be sent as part of a transaction. Non restaurant industry will only have 25 characters sent and restaurant will only have 6. |
ptrannum | string[^0]*\d+ Numeric-only transaction number. If ordernum is present, it will supersede and be preferred over ptrannum |
stationid | string <= 128 characters Identifier for the physical station running the transaction |
u_device | string(?i)(HID|USB|SDK)(:?|:.*)|(SER||MFI|BT|BLE|BL... This specifies the path of the card entry device. Required parameter unless
performing a GUI-based action (such as manual keyed entry, or swiping via a
keyboard emulation card reader). Required if
Note: Requires:
|
u_devicetype | string Enum: "ingenico_rba" "ingenico_upp" "ingenico_tcpx" "idtech_spectrum_pro" "idtech_augusta" "bbpos_cros" "equinox_epe" "idtech_neo" "epson_esc" "star_line" "seiko" "generic_barcode" The unique device type supported as found via a device types request. Requires:
Values:
|
u_flags | string Enum: "DEVICEONLY" "GUIONLY" "KEY" "AVS" "CVV" "GIFTPIN" "NOEXPDATE" "NOTIP" "NOCASHBACK" "NOCONFIRM" "NOSIGNATURE" "DELAYRESPONSE" "CARDMETA" "NOSTANDIN" "PERSISTDEVICE" "EXTERNALSELECT" "DENYLISTQUEUE" Multiple flags may be sent per data ticket request. All flags are separated by a pipe (|) symbol. Flag values (pipe separated):
|
u_language | string Enum: "en" "fr" "es" "de" "it" Used to override terminal defaults for display of text prompts. Not all devices support all languages. Values:
|
u_id | string A unique ID (generated by the calling application) that identifies the transaction. This is used for checking the status or canceling the transaction. Without this ID, the transaction state cannot be queried. |
u_rcpt | string The A value of A value of All other values are key/value pairs indicating formatting configurations, separated by semicolons, as in this example:
Receipt configuration options:
|
{- "u_up_amount": "12.00",
- "amount": "19.92",
- "tax": "1.29",
- "examount": "0.33",
- "cashbackamount": "20.00",
- "surchargeamount": "1.25",
- "clerkid": "Doe-1553",
- "comments": "Extra beef",
- "custref": "55",
- "ordernum": "A13DDES345",
- "ptrannum": "1987",
- "stationid": "7",
- "u_device": "SER:COM3",
- "u_devicetype": "ingenico_upp",
- "u_flags": "NOSIGNATURE|CARDMETA|DELAYRESPONSE",
- "u_language": "en",
- "u_id": "1234",
- "u_rcpt": "yes"
}
{- "code": "AUTH",
- "u_errorcode": "SUCCESS",
- "verbiage": "Transaction approved",
- "msoft_code": "INT_SUCCESS",
- "phard_code": "SUCCESS",
- "authamount": "6.50",
- "account": "XXXXXXXXXXXX1234",
- "ttid": "96748596765467",
- "u_emv_chip_malfunction": "yes",
- "u_need_signature": "yes",
- "u_tip": "string",
- "cardtype": "VISA",
- "u_cardclass": "UNKNOWN",
- "u_cashback": "string",
- "u_flowflags": "SIGCAPTURED",
- "u_standin": "yes",
- "property1": "string",
- "property2": "string"
}
Forces an existing tab to close
The transaction is sent directly to the Payment Server without customer interaction. Useful when a customer leaves without explicitly closing their tab
libmonetra KVS equivalent for endpoint
u_action
= tab
u_tab
= force_close
ttid required | string Example: 96748596765467 Transaction identifier |
u_up_amount | string-?\d+(\.\d{0,2})? Tabs can have the stored amount increased or decreased using the For example, the current amount is $15.00. Sending Note: |
amount | string\d*(\.\d{0,2})? Amount of money, including decimal. E.g This is the total amount and is an aggregate of all supplementary amounts. |
tax | string(?i)NT|\d*(\.\d{0,2})? Amount of tax that applies to the order The value 'NT' without the quotes indicates a non-taxable (tax exempt) transaction. |
examount | string\d+(\.\d{0,2})? Extra amount. Typically used for Retail and Restaurant tipping |
cashbackamount | string\d*(\.\d{0,2})? Amount of funds requested as cash to be given to the customer |
surchargeamount | string\d+(\.\d{0,2})? Amount of funds being received as a surcharge Surcharging rules are governed by the card brands. Compliance with brand rules need to be handled by the integrator because they can be highly industry and business type specific. Also, some times when people talk about surcharging, they are really talking about service fees, convenience fees, or cash discounts, which all have different rules even though they are closely related. Surcharges are the ONLY type that requires registration with the card brands and requires you pass the data along to the processing institution and therefore onto the card issuer. This is what this field does, is just pass that data along for transactions matching the surcharge classification (but not service fees, convenience fees, or cash discounts). |
clerkid | string <= 2048 characters Identifier for the clerk running the transaction |
comments | string <= 2048 characters User-defined comments related to the transaction |
custref | string <= 128 characters Customer reference number Typically, a customer PO number but can be other customer reference number |
ordernum | string <= 128 characters Order number An order number is required for all Card Not Present (e.g. Mail Order / Telephone Order and E-commerce) transactions, all transactions for the Restaurant industry, and all Level 2 cards such as Purchase or Corporate cards. Since it is not possible to know the card type prior to a request to UniTerm, an order number should be sent on all transactions. An order number is alphanumeric. However, for the restaurant industry, it should be numeric only. Processors are limited in the number of characters that can be sent as part of a transaction. Non restaurant industry will only have 25 characters sent and restaurant will only have 6. |
ptrannum | string[^0]*\d+ Numeric-only transaction number. If ordernum is present, it will supersede and be preferred over ptrannum |
stationid | string <= 128 characters Identifier for the physical station running the transaction |
{- "u_up_amount": "12.00",
- "amount": "19.92",
- "tax": "1.29",
- "examount": "0.33",
- "cashbackamount": "20.00",
- "surchargeamount": "1.25",
- "clerkid": "Doe-1553",
- "comments": "Extra beef",
- "custref": "55",
- "ordernum": "A13DDES345",
- "ptrannum": "1987",
- "stationid": "7"
}
{- "code": "AUTH",
- "u_errorcode": "SUCCESS",
- "verbiage": "Transaction approved",
- "msoft_code": "INT_SUCCESS",
- "phard_code": "SUCCESS",
- "authamount": "6.50",
- "account": "XXXXXXXXXXXX1234",
- "ttid": "96748596765467",
- "u_emv_chip_malfunction": "yes",
- "u_need_signature": "yes",
- "u_tip": "string",
- "cardtype": "VISA",
- "u_cardclass": "UNKNOWN",
- "u_cashback": "string",
- "u_flowflags": "SIGCAPTURED",
- "u_standin": "yes"
}
Lists all open tabs for the user
This will return a list of comma-separated values.
The resulting CSV will contain these headers:
ttid, proc, type, entrymode, card, pclevel, account, amount, cardholdername,
clerkid, comments, custref, expdate, examount, cashback, ordernum, ptrannum,
stationid, tax, timestamp
libmonetra KVS equivalent for endpoint
u_action
= tab
u_tab
= list
ttid | string Example: ttid=96748596765467 Transaction identifier |
bdate | string Example: bdate=-6 months Start of date range |
edate | string Example: edate=now End of date range |
amount | string Example: amount=19.92 Amount of money, including decimal. E.g This is the total amount and is an aggregate of all supplementary amounts. |
examount | string Example: examount=0.33 Extra amount. Typically used for Retail and Restaurant tipping |
tax | string Example: tax=1.29 Amount of tax that applies to the order The value 'NT' without the quotes indicates a non-taxable (tax exempt) transaction. |
card | string Example: card=VISA Type of card that was used |
pclevel | object Enum: "0" "1" "2" Example: pclevel=0 Indicates the level of payment card Values:
|
account | string Example: account=1234 Last 4 digits of account number |
expdate | string Example: expdate=0129 Expiration date of the card (MMYY format) |
cardholdername | string Example: cardholdername=John Doe Name of the cardholder. Will be read from account data (EMV, Track 1, etc.) but is not guaranteed to be present. Some presentation methods, such as keyed, do not have any way to capture the name as part of the account data. Further, Visa explicitly does not allow the cardholder name to be transmitted as part of a contactless read. Typically, a contactless read will result in a cardholder name of "/". If the name is known by another means, it can be entered in this parameter to override what was read (or not read) from the card. |
ordernum | string Example: ordernum=A13DDES345 Order number An order number is required for all Card Not Present (e.g. Mail Order / Telephone Order and E-commerce) transactions, all transactions for the Restaurant industry, and all Level 2 cards such as Purchase or Corporate cards. Since it is not possible to know the card type prior to a request to UniTerm, an order number should be sent on all transactions. An order number is alphanumeric. However, for the restaurant industry, it should be numeric only. Processors are limited in the number of characters that can be sent as part of a transaction. Non restaurant industry will only have 25 characters sent and restaurant will only have 6. |
custref | string Example: custref=55 Customer reference number Typically, a customer PO number but can be other customer reference number |
ptrannum | string Example: ptrannum=1987 Numeric-only transaction number. If ordernum is present, it will supersede and be preferred over ptrannum |
clerkid | string Example: clerkid=Doe-1553 Identifier for the clerk running the transaction |
stationid | string Example: stationid=7 Identifier for the physical station running the transaction |
comments | string Example: comments=Extra beef User-defined comments related to the transaction |
curl -X GET 'https://uniterm.test.transafe.com:8123/api/v1/tab' --basic -u 'test_retail|public:publ1ct3st'
{- "code": "AUTH",
- "u_errorcode": "SUCCESS",
- "verbiage": "Transaction approved"
}
Opens a tab, and captures customer card data
libmonetra KVS equivalent for endpoint
u_action
= tab
u_tab
= open
u_device required | string(?i)(HID|USB|SDK)(:?|:.*)|(SER||MFI|BT|BLE|BL... This specifies the path of the card entry device. Required parameter unless
performing a GUI-based action (such as manual keyed entry, or swiping via a
keyboard emulation card reader). Required if
Note: Requires:
|
u_devicetype required | string Enum: "ingenico_rba" "ingenico_upp" "ingenico_tcpx" "idtech_spectrum_pro" "idtech_augusta" "bbpos_cros" "equinox_epe" "idtech_neo" "epson_esc" "star_line" "seiko" "generic_barcode" The unique device type supported as found via a device types request. Requires:
Values:
|
u_flags | string Enum: "DEVICEONLY" "GUIONLY" "KEY" "AVS" "CVV" "GIFTPIN" "NOEXPDATE" "NOTIP" "NOCASHBACK" "NOCONFIRM" "NOSIGNATURE" "DELAYRESPONSE" "CARDMETA" "NOSTANDIN" "PERSISTDEVICE" "EXTERNALSELECT" "DENYLISTQUEUE" Multiple flags may be sent per data ticket request. All flags are separated by a pipe (|) symbol. Flag values (pipe separated):
|
u_language | string Enum: "en" "fr" "es" "de" "it" Used to override terminal defaults for display of text prompts. Not all devices support all languages. Values:
|
u_id | string A unique ID (generated by the calling application) that identifies the transaction. This is used for checking the status or canceling the transaction. Without this ID, the transaction state cannot be queried. |
u_rcpt | string The A value of A value of All other values are key/value pairs indicating formatting configurations, separated by semicolons, as in this example:
Receipt configuration options:
|
{- "u_device": "SER:COM3",
- "u_devicetype": "ingenico_upp",
- "u_flags": "NOSIGNATURE|CARDMETA|DELAYRESPONSE",
- "u_language": "en",
- "u_id": "1234",
- "u_rcpt": "yes"
}
{- "code": "AUTH",
- "u_errorcode": "SUCCESS",
- "verbiage": "Transaction approved",
- "msoft_code": "INT_SUCCESS",
- "phard_code": "SUCCESS",
- "authamount": "6.50",
- "account": "XXXXXXXXXXXX1234",
- "ttid": "96748596765467",
- "u_emv_chip_malfunction": "yes",
- "u_need_signature": "yes",
- "u_tip": "string",
- "cardtype": "VISA",
- "u_cardclass": "UNKNOWN",
- "u_cashback": "string",
- "u_flowflags": "SIGCAPTURED",
- "u_standin": "yes"
}
Gets the total number of open tabs and the total tracked amount across all tabs
The total amount is only useful if using UniTerm to track the total for each
tab by utilizing u_up_amount
. If the POS is tracking the amount itself and
only sending the amount when closing the tab, the aggregate total amount will
most likely be $0.00 and not accurately reflect the outstanding total amount.
libmonetra KVS equivalent for endpoint
u_action
= tab
u_tab
= totals
curl -X GET 'https://uniterm.test.transafe.com:8123/api/v1/tab/totals' --basic -u 'test_retail|public:publ1ct3st'
{- "code": "AUTH",
- "u_errorcode": "SUCCESS",
- "verbiage": "Transaction approved",
- "num_trans": "44",
- "total_amount": "172.01"
}
Updates the metadata on file for a ChipTab.
libmonetra KVS equivalent for endpoint
u_action
= tab
u_tab
= update
ttid required | string Example: 96748596765467 Transaction identifier |
u_up_amount | string-?\d+(\.\d{0,2})? Tabs can have the stored amount increased or decreased using the For example, the current amount is $15.00. Sending Note: |
amount | string\d*(\.\d{0,2})? Amount of money, including decimal. E.g This is the total amount and is an aggregate of all supplementary amounts. |
tax | string(?i)NT|\d*(\.\d{0,2})? Amount of tax that applies to the order The value 'NT' without the quotes indicates a non-taxable (tax exempt) transaction. |
examount | string\d+(\.\d{0,2})? Extra amount. Typically used for Retail and Restaurant tipping |
cashbackamount | string\d*(\.\d{0,2})? Amount of funds requested as cash to be given to the customer |
surchargeamount | string\d+(\.\d{0,2})? Amount of funds being received as a surcharge Surcharging rules are governed by the card brands. Compliance with brand rules need to be handled by the integrator because they can be highly industry and business type specific. Also, some times when people talk about surcharging, they are really talking about service fees, convenience fees, or cash discounts, which all have different rules even though they are closely related. Surcharges are the ONLY type that requires registration with the card brands and requires you pass the data along to the processing institution and therefore onto the card issuer. This is what this field does, is just pass that data along for transactions matching the surcharge classification (but not service fees, convenience fees, or cash discounts). |
clerkid | string <= 2048 characters Identifier for the clerk running the transaction |
comments | string <= 2048 characters User-defined comments related to the transaction |
custref | string <= 128 characters Customer reference number Typically, a customer PO number but can be other customer reference number |
ordernum | string <= 128 characters Order number An order number is required for all Card Not Present (e.g. Mail Order / Telephone Order and E-commerce) transactions, all transactions for the Restaurant industry, and all Level 2 cards such as Purchase or Corporate cards. Since it is not possible to know the card type prior to a request to UniTerm, an order number should be sent on all transactions. An order number is alphanumeric. However, for the restaurant industry, it should be numeric only. Processors are limited in the number of characters that can be sent as part of a transaction. Non restaurant industry will only have 25 characters sent and restaurant will only have 6. |
ptrannum | string[^0]*\d+ Numeric-only transaction number. If ordernum is present, it will supersede and be preferred over ptrannum |
stationid | string <= 128 characters Identifier for the physical station running the transaction |
{- "u_up_amount": "12.00",
- "amount": "19.92",
- "tax": "1.29",
- "examount": "0.33",
- "cashbackamount": "20.00",
- "surchargeamount": "1.25",
- "clerkid": "Doe-1553",
- "comments": "Extra beef",
- "custref": "55",
- "ordernum": "A13DDES345",
- "ptrannum": "1987",
- "stationid": "7"
}
{- "code": "AUTH",
- "u_errorcode": "SUCCESS",
- "verbiage": "Transaction approved"
}
Deletes a tab
The tab is closed but never sent online for authorization.
libmonetra KVS equivalent for endpoint
u_action
= tab
u_tab
= void
ttid required | string Example: 96748596765467 Transaction identifier |
curl -X DELETE 'https://uniterm.test.transafe.com:8123/api/v1/tab/U1294139' --basic -u 'test_retail|public:publ1ct3st'
{- "code": "AUTH",
- "u_errorcode": "SUCCESS",
- "verbiage": "Transaction approved"
}
Requests the user confirm a message presented on the device screen
This can also be used to display an agreement to the customer. If agreed the POS can follow up with a signature request if a record of the confirmation is required.
The optional u_long_message
parameter is used to display additional message
text. Such as agreement text. Not all devices support a long message. Will only
be shown on devices with a screen large enough to accommodate additional
message display.
libmonetra KVS equivalent for endpoint
u_action
= reqconfirm
u_device required | string Example: u_device=SER:COM3 This specifies the path of the card entry device. Required parameter unless
performing a GUI-based action (such as manual keyed entry, or swiping via a
keyboard emulation card reader). Required if
Note: Requires:
|
u_devicetype required | object Enum: "ingenico_rba" "ingenico_upp" "ingenico_tcpx" "idtech_spectrum_pro" "idtech_augusta" "bbpos_cros" "equinox_epe" "idtech_neo" "epson_esc" "star_line" "seiko" "generic_barcode" Example: u_devicetype=ingenico_upp The unique device type supported as found via a device types request. Requires:
Values:
|
u_message required | string Example: u_message=Hello, Customer Request message to show to the customer Requires:
|
u_flags | object Enum: "DEVICEONLY" "GUIONLY" "KEY" "AVS" "CVV" "GIFTPIN" "NOEXPDATE" "NOTIP" "NOCASHBACK" "NOCONFIRM" "NOSIGNATURE" "DELAYRESPONSE" "CARDMETA" "NOSTANDIN" "PERSISTDEVICE" "EXTERNALSELECT" "DENYLISTQUEUE" Example: u_flags=NOSIGNATURE|CARDMETA|DELAYRESPONSE Multiple flags may be sent per data ticket request. All flags are separated by a pipe (|) symbol. Flag values (pipe separated):
|
u_long_message | string Example: u_long_message=Item 1
Item2
Item3 Long message to show to the customer The message will not be formatted to the device screen. It is imperative the message be formatted for the device being used. This includes required line ending type (\r\n vs \n) and line lengths. Requires:
|
curl -X GET 'https://uniterm.test.transafe.com:8123/api/v1/prompt/confirm' \ --basic -u 'test_retail|public:publ1ct3st' \ -G \ -d 'u_device=IPCLIENT:78909876' \ -d 'u_devicetype=ingenico_upp' \ -d 'u_message=Get+Special+Offers?'
{- "code": "AUTH",
- "u_errorcode": "SUCCESS",
- "verbiage": "Transaction approved",
- "u_confirmed": "yes"
}
Requests the user confirm a message presented on the device screen
This can also be used to display an agreement to the customer. If agreed the POS can follow up with a signature request if a record of the confirmation is required.
The optional u_long_message
parameter is used to display additional message
text. Such as agreement text. Not all devices support a long message. Will only
be shown on devices with a screen large enough to accommodate additional
message display.
libmonetra KVS equivalent for endpoint
u_action
= reqconfirm
u_device required | string(?i)(HID|USB|SDK)(:?|:.*)|(SER||MFI|BT|BLE|BL... This specifies the path of the card entry device. Required parameter unless
performing a GUI-based action (such as manual keyed entry, or swiping via a
keyboard emulation card reader). Required if
Note: Requires:
|
u_devicetype required | string Enum: "ingenico_rba" "ingenico_upp" "ingenico_tcpx" "idtech_spectrum_pro" "idtech_augusta" "bbpos_cros" "equinox_epe" "idtech_neo" "epson_esc" "star_line" "seiko" "generic_barcode" The unique device type supported as found via a device types request. Requires:
Values:
|
u_message required | string Request message to show to the customer Requires:
|
u_flags | string Enum: "DEVICEONLY" "GUIONLY" "KEY" "AVS" "CVV" "GIFTPIN" "NOEXPDATE" "NOTIP" "NOCASHBACK" "NOCONFIRM" "NOSIGNATURE" "DELAYRESPONSE" "CARDMETA" "NOSTANDIN" "PERSISTDEVICE" "EXTERNALSELECT" "DENYLISTQUEUE" Multiple flags may be sent per data ticket request. All flags are separated by a pipe (|) symbol. Flag values (pipe separated):
|
u_long_message | string Long message to show to the customer The message will not be formatted to the device screen. It is imperative the message be formatted for the device being used. This includes required line ending type (\r\n vs \n) and line lengths. Requires:
|
{- "u_device": "SER:COM3",
- "u_devicetype": "ingenico_upp",
- "u_message": "Hello, Customer",
- "u_flags": "NOSIGNATURE|CARDMETA|DELAYRESPONSE",
- "u_long_message": "Item 1\nItem2\nItem3"
}
{- "code": "AUTH",
- "u_errorcode": "SUCCESS",
- "verbiage": "Transaction approved",
- "u_confirmed": "yes"
}
Requests input from the user for the given input type
libmonetra KVS equivalent for endpoint
u_action
= reqinput
u_device required | string Example: u_device=SER:COM3 This specifies the path of the card entry device. Required parameter unless
performing a GUI-based action (such as manual keyed entry, or swiping via a
keyboard emulation card reader). Required if
Note: Requires:
|
u_devicetype required | object Enum: "ingenico_rba" "ingenico_upp" "ingenico_tcpx" "idtech_spectrum_pro" "idtech_augusta" "bbpos_cros" "equinox_epe" "idtech_neo" "epson_esc" "star_line" "seiko" "generic_barcode" Example: u_devicetype=ingenico_upp The unique device type supported as found via a device types request. Requires:
Values:
|
u_inputtype required | object Enum: "PHONENUM" "INVOICENUM" "ZIP" "EMAIL" "TIP" "AMOUNT" "LIST" Example: u_inputtype=ZIP Type of user input being requested Values:
|
u_message | string Example: u_message=Hello, Customer Request message to show to the customer Used and required by Requires:
|
u_flags | object Enum: "DEVICEONLY" "GUIONLY" "KEY" "AVS" "CVV" "GIFTPIN" "NOEXPDATE" "NOTIP" "NOCASHBACK" "NOCONFIRM" "NOSIGNATURE" "DELAYRESPONSE" "CARDMETA" "NOSTANDIN" "PERSISTDEVICE" "EXTERNALSELECT" "DENYLISTQUEUE" Example: u_flags=NOSIGNATURE|CARDMETA|DELAYRESPONSE Multiple flags may be sent per data ticket request. All flags are separated by a pipe (|) symbol. Flag values (pipe separated):
|
u_inputlist | string Example: u_inputlist=TEST|123 List of elements to allow selection from Only used by Pipe (|) separated list of elements. E.g For example, with the list |
curl -X GET 'https://uniterm.test.transafe.com:8123/api/v1/prompt/input' \ --basic -u 'test_retail|public:publ1ct3st' \ -G \ -d 'u_device=IPCLIENT:78909876' \ -d 'u_devicetype=ingenico_upp' \ -d 'u_inputtype=ZIP'
{- "code": "AUTH",
- "u_errorcode": "SUCCESS",
- "verbiage": "Transaction approved",
- "u_input": "string",
- "u_tip": "string"
}
Prompts customer for signature
This is for non-financial requests. For financial transactions, a signature will be automatically captured and stored within the Payment Server, so there is no need to call this function.
This should only be used outside of a transaction flow (e.g. Request, Quick, Start, Finish).
libmonetra KVS equivalent for endpoint
u_action
= reqsignature
u_device required | string Example: u_device=SER:COM3 This specifies the path of the card entry device. Required parameter unless
performing a GUI-based action (such as manual keyed entry, or swiping via a
keyboard emulation card reader). Required if
Note: Requires:
|
u_devicetype required | object Enum: "ingenico_rba" "ingenico_upp" "ingenico_tcpx" "idtech_spectrum_pro" "idtech_augusta" "bbpos_cros" "equinox_epe" "idtech_neo" "epson_esc" "star_line" "seiko" "generic_barcode" Example: u_devicetype=ingenico_upp The unique device type supported as found via a device types request. Requires:
Values:
|
u_flags | object Enum: "DEVICEONLY" "GUIONLY" "KEY" "AVS" "CVV" "GIFTPIN" "NOEXPDATE" "NOTIP" "NOCASHBACK" "NOCONFIRM" "NOSIGNATURE" "DELAYRESPONSE" "CARDMETA" "NOSTANDIN" "PERSISTDEVICE" "EXTERNALSELECT" "DENYLISTQUEUE" Example: u_flags=NOSIGNATURE|CARDMETA|DELAYRESPONSE Multiple flags may be sent per data ticket request. All flags are separated by a pipe (|) symbol. Flag values (pipe separated):
|
curl -X GET 'https://uniterm.test.transafe.com:8123/api/v1/prompt/signature' \ --basic -u 'test_retail|public:publ1ct3st' \ -G \ -d 'u_device=IPCLIENT:78909876' \ -d 'u_devicetype=ingenico_upp'
{- "code": "AUTH",
- "u_errorcode": "SUCCESS",
- "verbiage": "Transaction approved",
- "u_signature": "string"
}
Performs a direct pass-through of parameters to the Payment Server
This method will simply proxy requests to the Payment Server. It can be used for transaction modifications (e.g. voids) or for pulling reports from the Payment Server.
Do not use this request if cardholder data needs to be retrieved for the transaction, as it will not be returned.
Sensitive cardholder data is explicitly prohibited from being sent as pass-through.
Users may wish to send their requests directly to the Payment Server rather than using this feature.
libmonetra KVS equivalent for endpoint
u_action
= passthrough
property name* additional property | string |
{- "property1": "string",
- "property2": "string"
}
{- "code": "AUTH",
- "u_errorcode": "SUCCESS",
- "verbiage": "Transaction approved",
- "property1": "string",
- "property2": "string"
}