Versions Compared
Version | Old Version 6 | New Version 7 |
---|---|---|
Changes made by | ||
Saved on |
Key
- This line was added.
- This line was removed.
- Formatting was changed.
Introduction
Mobile Point‐of‐Sales (mPOS) systems that process sensitive payment information are required to certify their payment applications to the Payment Application Data Security Standard (PA‐DSS). The addition of EMV certification and continued need for both encryption and tokenization has become a concern for both merchants and integrators. Instituting and maintaining these standards requires significant financial and employee resources in order to adhere to the Payments Card Industry Data Security Standards (PCI DSS) compliance requirements. Subsequently, any changes made in the mPOS system, may require a partial or full recertification, which increases the cost and time to market. BridgePay has engaged these issues through our product line, the Pay Guardian suite, to better serve the needs of our integrators and merchants.PayGuardian Android is a light weight, highly secure Android application that integrates seamlessly into mPOS applications. PayGuardian Android facilitates the transaction process by handling the collection and transmission of sensitive payment information as an out of scope PA-DSS solution, thereby offloading the certification responsibility from merchants and integrators. PayGuardian Android is EMV enabled, handles point to point encryption, and tokenizes all transactions to ensure transaction processing is seamless and secure.
✅ The mPOS application collects transaction data such as the dollar amount, invoice number, tender type, transaction type, merchant account information, etc…
✅ The mPOS application constructs the transaction request in an XML format upon the selection of the Process button. (See 3.1.6 Sample Examples)
✅ PayGuardian obtains the card information via the claiming of the mPOS device using the Device USB Host connection (re: Ingenico RBA SDK) and validates the transaction request object.
✅ The mPOS device prompts to swipe or insert the card and transmits the card information to the PayGuardian application, which captures the card data as a swiped or EMV transaction respectively.
✅ PayGuardian constructs the payload request and transmits the transaction request to the Payment Gateway.
✅ PayGuardian transmits the transaction response returned from the Payment Gateway back to the mPOS application.
✅ The mPOS application implementation responds accordingly to the transaction response.
Integration Setup
We have created a demonstration project for integrators that can serve as a base for a payment application.
Prerequisites
Android device (min API 26, must support Bluetooth, live internet connection)
ID Tech VP3300 BT
Project Dependencies
In order to simplify testing and distribution, we have created a Core SDK library (pgmobileandroid-n.n.n.aar) and a device wrapper library for each card reader family we support. This ensures that integrators will have a version of the manufacturer’s device library that is compatible with our software.
The example below contains guidance on specific libraries and their usage in the demonstration project and are current as of December 2024.
Note |
---|
Android application permission handling is beyond the scope of this document and is the responsibility of the integrator. We have made every effort to ensure that the core SDK functionality does not trigger unwanted or unexpected permissions requests. Use of the nammu library is taken solely at the risk of the integrator. |
build.gradle (app)
Code Block | ||
---|---|---|
| ||
// Core SDK and device wrapper implementation(files("libs/pgmobileandroid-3.0.0.aar")) implementation(files("libs/pg_idt_wrapper-1.0.0.aar")) // other necessary libraries implementation("com.google.code.gson:gson:2.11.0") implementation("com.google.code.ksoap2-android:ksoap2-android:3.6.2") // provided, optional. // This library is unsupported due to age, but is still hosted publicly at https://github.com/tajchert/Nammu // It is intended for use to smooth out permissions prompts on older, pre API 12 devices. // Integrators should evaluate their specific needs regarding permissions handling. implementation(files("libs/nammu-1.0.0.aar")) // Repo for simplexml - maven(url = "https://oss.sonatype.org/content/repositories/ksoap2-android-releases/") implementation("org.simpleframework:simple-xml:2.7.1") // These libraries provide necessary functionality at the level they are compiled at. // Do not upgrade past this point at the risk of losing Android compatibility. implementation("org.simpleframework:simple-xml:2.7.1") { exclude(module = "xpp3") } implementation("org.apache.commons:commons-lang3:3.15.0") |
build.gradle.kts (Project)
Code Block | ||
---|---|---|
| ||
repositories { google() mavenCentral() maven(url = "https://oss.sonatype.org/content/repositories/ksoap2-android-releases/") } |
PayGuardian initialization
The PayGuardian class is implemented as a singleton and accepts an instance of the PayGuardianDelegate interface to bind events. After instantiation and connection to a CardReader, that delegate is passed into the singleton as well.
Code Block | ||
---|---|---|
| ||
public interface PayGuardianDelegate { void initiateTransaction(PaymentRequest request); void onTransactionStateChanged(TransactionState transactionState, String message); void onReaderStateChanged(ReaderState readerState, String message); void onMessageReceived(String message); void onResponseReceived(PaymentResponse paymentResponse); void onError(ArrayList<String> errors); } |
Code Block | ||
---|---|---|
| ||
payGuardian = PayGuardian.getInstance(); payGuardian.setDelegate(payGuardianDelegate); |
Device Connection
The device wrapper library provides integrators with an implementation of the CardReader interface from the core SDK library. The class name can be expected to be in the format of (device name)Delegate.
Code Block | ||
---|---|---|
| ||
public interface CardReader { int searchForDeviceByName(String name, int timeout); void requestCardRead(Double amount, boolean isRefund); void requestCardRead(Double amount, boolean isRefund, boolean disableEmv, boolean disableCtls); boolean isConnected(); void cancel(); DeviceDetails getDeviceDetails(); } |
Code Block | ||
---|---|---|
| ||
private void attemptConnection(String deviceName) { new Thread(() -> { // TODO: note that this response pattern is IDTech specific runOnUiThread(() -> { VP3300Delegate vp3300Delegate = new VP3300Delegate(this, payGuardian.readerResponseDelegate, new Handler(Looper.getMainLooper())); int rc = vp3300Delegate.searchForDeviceByName(deviceName, 10000); if (rc != 0) { String message = switch (rc) { case 1 -> "Invalid DEVICE_TYPE"; case 2 -> "Bluetooth LE is not supported on this device"; case 3 -> "Bluetooth LE is not available"; case 4 -> "Bluetooth LE is not enabled"; case 5 -> "Device not paired. Please pair first"; default -> "Unknown error"; }; viewModel.appendLogMessage(message); } else { payGuardian.setCardReader(vp3300Delegate); viewModel.appendLogMessage("Found device " + deviceName); } }); }).start(); } |
Info |
---|
While testing with the ID Tech VP3300, we found it helpful to leave it plugged into USB power. The Bluetooth Low Energy scheme will frequently put the reader to sleep. Further, it should not be physically plugged into any computing device as that will supersede a Bluetooth request and return those requests to the wired device regardless of the source. |
Transaction Handling
All transaction calls are made through a direct call to PayGuardian.getInstance().processTransaction or through PayGuardianDelegate.initiateTransaction. The transaction handler will only process a single transaction at a time, and there is no queuing of requests for later processing. Including the payment card information on a transaction will bypass a card read.
Code Block | ||
---|---|---|
| ||
private PaymentRequest buildBasicPaymentRequest() { PaymentRequest paymentRequest = new PaymentRequest(); paymentRequest.setTerminalID(terminalID); paymentRequest.setUsername(userName); paymentRequest.setPassword(password); paymentRequest.setMerchantCode(merchantCode); paymentRequest.setMerchantAccountCode(merchantAccountCode); paymentRequest.setTenderType(TenderType.Credit.toString()); return paymentRequest; } // This will trigger a card read request private void sendSale() { PaymentRequest paymentRequest = buildBasicPaymentRequest(); paymentRequest.setMode(PayGuardianMode.Test.toString()); paymentRequest.setTransType(TransactionType.Sale.toString()); paymentRequest.setAmount("10.00"); payGuardianDelegate.initiateTransaction(paymentRequest); } // This will be sent directly to the gateway private void sendManualSale() { PaymentRequest paymentRequest = buildBasicPaymentRequest(); paymentRequest.setMode(PayGuardianMode.Test.toString()); paymentRequest.setTransType(TransactionType.Sale.toString()); paymentRequest.setAmount("10.00"); paymentRequest.setCardNumber("4111111111111111"); paymentRequest.setExpDate("1225"); paymentRequest.setCvvNumber("123"); payGuardianDelegate.initiateTransaction(paymentRequest); } |
Program Input Object
The following table contains descriptions for the properties of the extension input object. The properties are optional unless otherwise indicated.
Property | Description | Data Type / Min - Max Values | ||||
---|---|---|---|---|---|---|
TenderType | Required. Valid values are: ***UNKNOWN is currently only supported for use with the Ingenico devices. | String; | ||||
TransType | Required. Valid values are: | String; | ||||
TransIndustryType | Optional. Valid values are: | String; | ||||
Amount | Required. Total transaction amount (includes subtotal, cash back, tax, and tip (Format example: 0000.00) | String; | ||||
Username | Required. Username of the Merchant | String; | ||||
Password | Required. Password of the Merchant. | String; | ||||
Street | Optional. Zip code of billing address. | String; | ||||
OrigRefNum | Original reference number. Used for follow‐on transactions (e.g., Void, Reversal). | String; | ||||
Country |
| String; | ||||
Phone |
| String; | ||||
| N/A | |||||
MerchantCode | Required. BridgePay Merchant Code. | String; | ||||
MerchantAccountCode | Required. BridgePay Merchant Account Code. | String; | ||||
InvNum | Required. POS system invoice/tracking number. | String; | ||||
ReferenceID | Optional. Can be populated to echo back a variable in the response message. | String; | ||||
TerminalTypePartialAuthorization | Required. Terminal device type to be used for transaction processing. Valid values are (case-sensitive): | String; | ||||
BankAccountNum | Optional. The bank account number for ACH and Check transactions. | String; | ||||
RoutingNum | Optional. The routing number for ACH and Check transactions. Can contain up to 10 numbers. | String; | ||||
HolderType | Optional. Single character, either P (Personal account) or O (Organization account). | String; | ||||
PartialAuthorizationCardholderName | Optional. Sets the partial authorization flag for a transaction. The default setting is ‘false’ (meaning not active).Name as it appears on the credit card, debit card, or gift card. | String; | ||||
BankAccountNumCardNumber | Optional. The bank account number for ACH and Check transactions. StringAccount number of a credit card, debit card, or gift card used when collecting card data outside of PayGuardian (not recommended). | String; | ||||
RoutingNum | Optional. The routing number for ACH and Check transactions. Can contain up to 10 numbers. | String; | ||||
HolderType | Optional. Single character, either P (Personal account) or O (Organization account). | String; | ||||
CardholderName | Optional. Name as it appears on the ExpDate | Optional. Expiration date of a credit card, debit card, or gift card (required for Token transactions). | String; | |||
CardNumberCvvNumber | Optional. Account number Card verification code of a credit card, debit card, or gift card used when collecting card data outside of PayGuardian (not recommended). | String; | ||||
ExpDateMemo | Optional. Expiration date of a credit card, debit card, or gift card (required for Token transactions). | String; | ||||
CvvNumber | Optional. Card verification code of a credit card, debit card, or gift card used when collecting card data outside of PayGuardian (not recommended). | String; | ||||
Memo | Optional. User supplied data. User supplied data. Valid values are: alphanumeric, dashes, spaces, and periods. | String; | ||||
SoftwareVendor | Optional. Name of vendor that developed the software used in transmitting the transaction. | String; | ||||
DisableEMVHostingSoftware | Optional. Disables EMV capability on the terminal (Not Recommended) | Boolean | ||||
EnableQuickChip | Optional: Enables Quick Chip for EMV transactions (Currently supported only for Ingenico devices) | Boolean | ||||
HostingSoftware | Optional. | String; | String; | |||
VoiceAuthCode | Optional. Authorization Code for Voice Authorizations only when authorization was achieved outside of the network (by phone or other means). | String; | ||||
TaxRate | Optional. Processed as implied decimal. 5.5% would be represented as 550. Additional Tax Amount. REQUIRED FOR LEVEL II/III | String; | ||||
TaxAmount | Optional. Processed as implied decimal. $1.25 would be represented as 125. REQUIRED FOR LEVEL II. | String; | ||||
TaxIndicator | Optional. Valid values are: P (Provided), N (Not Provided), or E (Exempt). REQUIRED FOR LEVEL II/III. | String; | ||||
ShipToName | Optional. Shipping address name. REQUIRED FOR LEVEL II/III. | String; | ||||
ShipToStreet | Optional. Shipping address street. REQUIRED FOR LEVEL II/III. | String; | ||||
ShipToCity | Optional. Shipping address city. REQUIRED FOR LEVEL II/III. | String; | ||||
ShipToState | Optional. Shipping address state. REQUIRED FOR LEVEL II/III. | String; | ||||
ShipToZip | Optional. Shipping address postal code. Accepted formats are Canadian, UK and US (5 and 9 digit variation) postal codes. REQUIRED FOR LEVEL II/III. | String; | ||||
ShipToCountryCode | Optional. Shipping address country code. REQUIRED FOR LEVEL II/III. ISO 3166-1 alpha-2 codes. | String; | ||||
ShippingOriginZip | Availability pending processor certification. Conditional. *** REQUIRED FOR LEVEL III*** Postal code of the origin of the shipment. Accepted formats are Canadian, UK and US (5 and 9 digit variation) postal codes. Alphanumeric characters ONLY (no hyphens or dashes). Alpha characters must be all upper-case. | String; | ||||
DiscountAmount | Availability pending processor certification. Conditional. *** REQUIRED FOR LEVEL III*** Processed as implied decimal. $1.25 would be represented as 125. Additional discount amount. | Integer | ||||
ShippingAmount | Availability pending processor certification. Conditional. *** REQUIRED FOR LEVEL III*** Processed as implied decimal. $1.25 would be represented as 125. Additional discount amount. | Integer | ||||
DutyAmount | Availability pending processor certification. Conditional. *** REQUIRED FOR LEVEL III*** Processed as implied decimal. $1.25 would be represented as 125. Additional discount amount. | Integer | ||||
TaxInvoiceCode | Availability pending processor certification. Conditional. *** REQUIRED FOR LEVEL III*** Must be at least 1 and up to 15 characters. When separate VAT invoice is produced within the context of the order, unique identifier of this invoice. | String | ||||
LocalTaxAmount | Availability pending processor certification. Conditional. *** REQUIRED FOR LEVEL III*** Processed as implied decimal. $1.25 would be represented as 125. Additional discount amount. | Integer | ||||
LocalTaxIndicator | Availability pending processor certification. Conditional. *** REQUIRED FOR LEVEL III*** P (Provided), N (Not Provided), or E (Exempt). | String | ||||
NationalTaxAmount | Availability pending processor certification. Conditional. *** REQUIRED FOR LEVEL III*** Processed as implied decimal. $1.25 would be represented as 125. Additional discount amount. | Integer | ||||
NationalTaxIndicator | Availability pending processor certification. Conditional. *** REQUIRED FOR LEVEL III*** P (Provided), N (Not Provided), or E (Exempt). | String | ||||
OrderCode | Availability pending processor certification. Conditional. *** REQUIRED FOR LEVEL III*** Unique identifier assigned to the order associated with this transaction in submitter's/merchant's front-end/ inventory system. | String | ||||
OrderDate | Availability pending processor certification. Conditional. *** REQUIRED FOR LEVEL III*** Date in format YYYYMMDD. Date when the order associated with the transaction was placed. | String | ||||
CommodityCode | Availability pending processor certification. Conditional. *** REQUIRED FOR LEVEL III*** Acquirer designated standardized code that classifies the group of items associated with this order/transaction. | String | ||||
CustomerAccountTaxID | Availability pending processor certification. Conditional. *** REQUIRED FOR LEVEL III*** VAT registration number of the customer responsible for this transaction. | String | ||||
ItemCount | Availability pending processor certification. Conditional. *** REQUIRED FOR LEVEL III*** The number of items included in the “Item” collection. | TBDInt | ||||
Item | Availability pending processor certification. Conditional. *** REQUIRED FOR LEVEL III*** Used to group the line item details as a collection of individual item contents for an item. The “Item” collection is a repeatable tag within a transaction that consists of the following group of elements: <Item> | Collection | ItemCode | Availability pending processor certification. Conditional - Required when included in "Item" collection. Unique identifier assigned to this item in the submitter’s inventory system. | String | Collection<Item> |
CashBackAmount | Optional. Processed as implied decimal. $20.00 would be represented as 2000. Amount of money returned to a payment card holder. Used for Sale with cash back transactions. | String; | ||||
EnableCashBack | Optional. When set to true, prompts for cashback on the device. | Boolean | ||||
EnforceCardType | Optional. When set to true, prompts for Credit/Debit filtering. | Boolean | ||||
TipRecipientCode | Optional. Server ID for the customer. | String; | ||||
ItemCommodityCode | Availability pending processor certification. Conditional - Required when included in "Item" collection. Acquirer designated standardized code that classifies this item. | String | ||||
ItemDescription | Availability pending processor certification. Conditional - Required when included in "Item" collection. Short description of the item. | String | ||||
ItemQuantity | Availability pending processor certification. Conditional - Required when included in "Item" collection. Quantity of item units purchased as part of this transaction. Up to 4 decimal places. | Decimal | ||||
ItemUnitCostAmt | Availability pending processor certification. Conditional - Required when included in "Item" collection. Processed as implied decimal. $1.25 would be represented as 125. Cost of a single unit of the item. | Integer | ||||
ItemUnitMeasure | Availability pending processor certification. Conditional - Required when included in "Item" collection. Unit of measure used to quantify the items purchased/refunded (e.g. kg, lb., inch). | String | ||||
ItemTaxRate | Availability pending processor certification. Conditional - Required when included in "Item" collection. Processed as implied decimal. 5.5% would be represented as 550. Rate of the tax (if any) charged on this item. | String | ||||
ItemTaxAmount | Availability pending processor certification. Conditional - Required when included in "Item" collection. Processed as implied decimal. $1.25 would be represented as 125. Amount of tax charged for this item. | IntegerPushTipForm | Conditional. Required only when using ‘QueryTip’ function. This function is used to push the ‘Tip Query’ form to the terminal for first time use. | Boolean | ||
QueryTip | Conditional. When set to true, prompts for tip amount entry on the device. Requires pre-requisite form push of the ‘PushTipForm’ function to the terminal for first time use. | Boolean | ||||
PushForms | Conditional. Required only when using 'QueryTip', 'AmountConfirmatin', and/or 'Unknown Tender' functions. This function is ued to push the forms to the terminal for first time use. (Use is only for Ingenico Devices) | Boolean | ||||
PushTenderForm | Conditional. Required only when using the ‘UNKNOWN’ tender type. This function is used to push the ‘Select Tender’ form to the terminal for first time use. | Boolean | ||||
EnableConfirmAmount | Optional. Flag to enable the Amount confirmation; does require a form push. (Use is only for Ingenico Devices) | Boolean | ||||
ConvenienceFee | Convenience Fee. (Format example: 0000.00) The convenience fee is a line Item reference included in a SALE or SALE_AUTH transaction request in which the customer credit or debit card is charged the total sum in the ‘amount’ field where a transaction request contains both the transaction amount + convenience fee in a single transaction. | String; | ||||
ServiceFee | Optional. Separate fee that processes to a separate merchant account (the username and password are passed in with the request message) with a SALE or SALE_AUTH transaction in which the customer credit or debit card will be charged the transaction amount on the merchant account of record, and a service fee amount on a separate transaction to the merchant account designated in the request. | ServiceFee | ||||
ServiceUser | User name of the Service Fee Merchant Account. | String; | ||||
ServicePassword | Password of the ServiceUser. | String; | ||||
ResellerCode | Reseller ID assigned by the gateway for the Reseller of the Service Fee account. | String; | ||||
ItemTaxIndicator | Availability pending processor certification. Conditional - Required when included in "Item" collection. P (Provided), N (Not provided), or E (Exempt). | StringMerchantCode | Merchant ID assigned by the gateway for the Merchant of the Service Fee. | String; | ||
MerchantAccountCode | Merchant Account ID assigned by the gateway for the Merchant Account of the Service Fee. | String; | ||||
ItemTaxCode | Availability pending processor certification. Conditional - Required when included in "Item" collection. Acquirer designated value classifying the tax that was charged for this item. | String | ||||
ItemDiscountRate | Availability pending processor certification. Conditional - Required when included in "Item" collection. Processed as implied decimal. 5.5% would be represented as 550. Rate of discount (if any) that was applied to this item. | Integer | ||||
ItemDiscountAmount | Availability pending processor certification. Conditional - Required when included in "Item" collection. Processed as implied decimal. $1.25 would be represented as 125. Amount of tax charged for this item. | IntegerCardNotPresent | Optional. When set to ‘TRUE’, the transaction is treated as a Card Not Present transaction. Valid values are: TRUE = Card Not Present | Boolean | ||
ForceOnDuplicate | Optional. Can force a duplicate transaction to process when set to true. Valid values are: TRUE = Force duplicate transaction to process | Boolean | ||||
WalletPaymentMethodID | Optional. The ID provided by the Wallet API for the payment method. When using this field, no other payment identifiers are necessary (i.e. PaymentAccountNumber, Track, BankAccountNum, etc) | NSString; | ||||
Wallet | Optional. The ability to create a wallet within processing a request by setting: <Wallet>new</Wallet> | NSString; | ||||
SettlementDelay | Optional. The period for which a Sale-Auth transaction settlement is delayed. | String; | ||||
ItemTotalAmount | Availability pending processor certification. Conditional - Required when included in "Item" collection. Processed as implied decimal. $1.25 would be represented as 125. Amount of tax charged for this item. | Integer | ||||
ItemIsCredit | CustomFields | Optional. The ability to pass custom user defined fields to the gateway via a XML string. | NSString; | |||
CustomFields | Reserved for future use. Availability pending processor certification. Conditional - Required when included in "Item" collection. True = T (Item is being returned), F = False (Default if not passed - Item is being purchased). | String | ||||
CashBackAmount | Optional. Processed as implied decimal. $20.00 would be represented as 2000. Amount of money returned to a payment card holder. Used for Sale with cash back transactions. | String; | ||||
EnableCashBack | Optional. When set to true, prompts for cashback on the device. | Boolean | ||||
EnforceCardType | Optional. When set to true, prompts for Credit/Debit filtering. | Boolean | ||||
TipRecipientCode | Optional. Server ID for the customer. | String; | ||||
PushTipForm | Conditional. Required only when using ‘QueryTip’ function. This function is used to push the ‘Tip Query’ form to the terminal for first time use. | Boolean | ||||
QueryTip | Conditional. When set to true, prompts for tip amount entry on the device. Requires pre-requisite form push of the ‘PushTipForm’ function to the terminal for first time use. | Boolean | ||||
PushForms | Conditional. Required only when using 'QueryTip', 'AmountConfirmatin', and/or 'Unknown Tender' functions. This function is ued to push the forms to the terminal for first time use. (Use is only for Ingenico Devices) | Boolean | ||||
PushTenderForm | Conditional. Required only when using the ‘UNKNOWN’ tender type. This function is used to push the ‘Select Tender’ form to the terminal for first time use. | Boolean | ||||
EnableConfirmAmount | Optional. Flag to enable the Amount confirmation; does require a form push. (Use is only for Ingenico Devices) | Boolean | ||||
ConvenienceFee | Convenience Fee. (Format example: 0000.00) The convenience fee is a line Item reference included in a SALE or SALE_AUTH transaction request in which the customer credit or debit card is charged the total sum in the ‘amount’ field where a transaction request contains both the transaction amount + convenience fee in a single transaction. | String; | ||||
ServiceFee | Optional. Separate fee that processes to a separate merchant account (the username and password are passed in with the request message) with a SALE or SALE_AUTH transaction in which the customer credit or debit card will be charged the transaction amount on the merchant account of record, and a service fee amount on a separate transaction to the merchant account designated in the request. Format: XML String containing ServiceFeeID, Amount, ServiceUser, and Password. Format example: | X | ||||
ServiceUser | User name of the Service Fee Merchant Account. | String; | ||||
ServicePassword | Password of the ServiceUser. | String; | ||||
ResellerCode | Reseller ID assigned by the gateway for the Reseller of the Service Fee account. | String; Optional. Valid Values are: CUSTOMER UNSCHEDULED RECURRING or INSTALLMENT | String; | |||
BridgeCommURL | Optional. The BridgeComm URL can be passed with a transaction request which is used to override the mode selected and passed in the request message and/or in the app. Ex: https://www.bridgepaynetsecuretest.com/paymentservice/requesthandler.svc | URL String |
Item
Property | Description | Data Type / Min - Max Values |
---|---|---|
ItemCode | Availability pending processor certification. Conditional - Required when included in "Item" collection. Unique identifier assigned to this item in the submitter’s inventory system. | String |
ItemCommodityCode | Availability pending processor certification. Conditional - Required when included in "Item" collection. Acquirer designated standardized code that classifies this item. | String |
ItemDescription | Availability pending processor certification. Conditional - Required when included in "Item" collection. Short description of the item. | String |
ItemQuantity | Availability pending processor certification. Conditional - Required when included in "Item" collection. Quantity of item units purchased as part of this transaction. Up to 4 decimal places. | Decimal |
ItemUnitCostAmt | Availability pending processor certification. Conditional - Required when included in "Item" collection. Processed as implied decimal. $1.25 would be represented as 125. Cost of a single unit of the item. | Integer |
ItemUnitMeasure | Availability pending processor certification. Conditional - Required when included in "Item" collection. Unit of measure used to quantify the items purchased/refunded (e.g. kg, lb., inch). | String |
ItemTaxRate | Availability pending processor certification. Conditional - Required when included in "Item" collection. Processed as implied decimal. 5.5% would be represented as 550. Rate of the tax (if any) charged on this item. | String |
MerchantAccountCode
Merchant Account ID assigned by the gateway for the Merchant Account of the Service Fee.
12 |
MerchantCode
Merchant ID assigned by the gateway for the Merchant of the Service Fee.
String;
Min Value = 0;
Max Value = 25
ItemTaxAmount | Availability pending processor certification. Conditional - Required when included in "Item" collection. Processed as implied decimal. $1.25 would be represented as 125. Amount of tax charged for this item. | Integer |
SettlementDelay
Optional. The period for which a Sale-Auth transaction settlement is delayed.
8 |
CardNotPresent
Optional. When set to ‘TRUE’, the transaction is treated as a Card Not Present transaction. Valid values are:
TRUE = Card Not Present
FALSE = Card Present
Boolean
ForceOnDuplicate
Optional. Can force a duplicate transaction to process when set to true. Valid values are:
TRUE = Force duplicate transaction to process
FALSE = Do not process duplicate transaction
Boolean
DisableContactless
Optional. Disable contactless EMV transactions from processing. When set to true, the contactless interface on the Ingenico devices (iCMP, iSMP, iPP320, and iPP350) is disabled.
TRUE = Disables contactless (Default)
False = Enables contactless
Boolean
ConfigureVivopay
Optional. Push config file settings to device (one-time setup).
True = push config file
False = no config (Default)
Boolean
WalletPaymentMethodID
Optional. The ID provided by the Wallet API for the payment method. When using this field, no other payment identifiers are necessary (i.e. PaymentAccountNumber, Track, BankAccountNum, etc)
NSString;
Max Value = 36
Wallet
Optional. The ability to create a wallet within processing a request by setting: <Wallet>new</Wallet>
NSString;
Max Value = 3
ItemTaxIndicator | Availability pending processor certification. Conditional - Required when included in "Item" collection. P (Provided), N (Not provided), or E (Exempt). | String |
ItemTaxCode | Availability pending processor certification. Conditional - Required when included in "Item" collection. Acquirer designated value classifying the tax that was charged for this item. | String |
ItemDiscountRate | Availability pending processor certification. Conditional - Required when included in "Item" collection. Processed as implied decimal. 5.5% would be represented as 550. Rate of discount (if any) that was applied to this item. | Integer |
ItemDiscountAmount | Availability pending processor certification. Conditional - Required when included in "Item" collection. Processed as implied decimal. $1.25 would be represented as 125. Amount of tax charged for this item. | Integer |
ItemTotalAmount | Availability pending processor certification. Conditional - Required when included in "Item" collection. Processed as implied decimal. $1.25 would be represented as 125. Amount of tax charged for this item. | Integer |
8 |
CustomFields
Optional. The ability to pass custom user defined fields to the gateway via a XML string.
Ex: <Current_Location>Florida</Current_Location>
NSString;
Min = 20
Max Value = 500
CustomFields
Reserved for future use. Availability pending processor certification.
Optional. Valid Values are:
CUSTOMER
Cardholder initiated transaction using a stored-credential. (Note: Nothing is actually sent for POS Environment Indicator, but the POS Entry mode will be sent as a "10" to the processors.)
UNSCHEDULED
Merchant initiated transaction that is not part of any specific Recurring or Installment relationship/contract.
RECURRING or INSTALLMENT
BridgeComm was enhanced to allow this field as input* Merchant initiated transaction for either a Recurring or Installment relationship/contract.
String;
Min = 0
Max Value = 14
BridgeCommURL
Optional. The BridgeComm URL can be passed with a transaction request which is used to override the mode selected and passed in the request message and/or in the app. Ex: https://www.bridgepaynetsecuretest.com/paymentservice/requesthandler.svc
URL String
Program Output Object
The following table contains descriptions for the PaymentResponse output object properties.
Note: You should only look at the results in the PaymentResponse
Property
Description
Data Type / Min - Max Values
AuthCode
ItemIsCredit | Availability pending processor certification. Conditional - Required when included in "Item" collection. True = T (Item is being returned), F = False (Default if not passed - Item is being purchased). | String |
Program Output Object
The following table contains descriptions for the PaymentResponse output object properties.
Note: You should only look at the results in the PaymentResponse
Property | Description | Data Type / Min - Max Values | ||||
---|---|---|---|---|---|---|
AuthCode | Transaction authorization code from the payment processor. This value is an approval code for approved transactions or an error code/message for declined transactions. | String; | ||||
ApprovedAmount | The actual amount approved by host. This may differ from the requested amount. | String; | ||||
AvsResponse | AVS response. See AVS Response Codes(3.1.6 Examples) for a list of possible responses. | String; | ||||
BogusAccountNumber | Partially masked card number. The first 6 and last 4 digits of the card number are present with zeros in between. This card number will not pass the mod 10 check. | String; | ||||
CardType | Displays the card type (determined by BIN range). List of items: Visa, Mastercard, Discover, Amex, Diners, JCB, CUP (China Union Pay), Bank, None | String; | ||||
ApprovedAmount | The actual amount approved by host. This may differ from the requested amount.CardModifier | Displays the featured function submitted in addition to the tender type used to process a transaction. List of items: Business, FSA, Commercial, FoodStamp, Check, Savings, Cash, None | String; | |||
CardClass | Displays the tender type used to process a transaction. List of items: Credit, Debit, Gift, Prepaid, EBT, Fleet, None | String; | ||||
AvsResponseCvResponse | AVS The CV response code. See AVS Response Codes(3.1.6 Examples) See CV Response Codes on pages 38 for a list of possible responses. | String; | ||||
BogusAccountNumber | Partially masked card number. The first 6 and last 4 digits of the card number are present with zeros in between. This card number will not pass the mod 10 checkRefNum | Gateway reference/PnRef number. Used for follow‐on transactions (i.e., Void, Reversal). | String; | |||
CardType | Displays the card type (determined by BIN range). List of items: Visa, Mastercard, Discover, Amex, Diners, JCB, CUP (China Union Pay), Bank, None | RemainingBalance | Remaining balance on gift or prepaid card. | String; | CardModifier | Displays the featured function submitted in addition to the tender type used to process a transaction. List of items: Business, FSA, Commercial, FoodStamp, Check, Savings, Cash, None |
RequestedAmount | Original requested amount of the transaction. | String; | ||||
CardClassResultCode | Displays the tender type used to process a transaction. List of items: Credit, Debit, Gift, Prepaid, EBT, Fleet, None | Result code of the transaction. See on page 35 for more information. | String; | |||
CvResponse | The CV response code. See CV Response Codes on pages 38 for a list of possible responsesResultTxt | Details from the processor or payment gateway about the transaction result. | String; | |||
RefNum | Gateway reference/PnRef number. Used for follow‐on transactions (i.e., Void, Reversal)Timestamp | Time and date of the transaction. | String; | |||
RemainingBalance | Remaining balance on gift or prepaid cardExpirationDate | Echo back of the expiration date. | String; | |||
RequestedAmount | Original requested amount of the transactionGatewayMessage | Message from the gateway. | String; | |||
ResultCode | Result code of the transaction. See on page 35 for more informationInternalMessage | Detailed information provided by the gateway / processor regarding results of the transaction request. | String; | |||
ResultTxt | Details from the processor or payment gateway about the transaction resultAVSMessage | Unipay AVS Match Result Message. | String; | |||
Timestamp | Time and date of the transactionCVMessage | Unipay CVV/CVV2 Match Result Message. | String; | |||
ExpirationDate | Echo back of the expiration dateIsoCountryCode | Country code from the gateway. | String; | |||
GatewayMessageIsoRequestDate | Message Requested date from the gateway. | String; | ||||
InternalMessage | Detailed information provided by the gateway / processor regarding results of the transaction requestNetworkReferenceNumber | Gateway Network reference number. | String; | |||
AVSMessage | Unipay AVS Match Result Message. | String; | ||||
CVMessage | Unipay CVV/CVV2 Match Result Message. | String; | ||||
IsoCountryCode | Country code from the gateway. | String; | ||||
IsoRequestDate | Requested date from the gateway. | String; | ||||
NetworkReferenceNumber | Gateway Network reference number. | String; | ||||
15 | ||||||
MerchantCategoryCode | Merchant Category Code from the gateway. | N/A | ||||
NetworkMerchantId | Merchant id from the gateway. | N/A | ||||
NetworkTerminalId | Network terminal id from the gateway. | N/A | ||||
ResponseTypeDescription |
| N/A | ||||
StreetMatchMessage |
| N/A | ||||
ExtData | Returns extra data for the extended data fields submitted in the processed transaction (multiple field information may be returned in XML format). | N/A | ||||
Token | Represents the tokenized card number received from a token request or authorization. | String; | ||||
Memo | Conditional. Present if user previously supplied data. | String; | ||||
ServiceFeeResult | Returns result for Service Fee transactions. Data may be populated in multiple fields and returned in XML format. | String; XML | ||||
EntryMode | Returns back the card entry method: Swipe, EMV, Tap. | String; | ||||
WalletID | Returns the wallet ID. | String; | ||||
WalletPaymentMethodID | Returns the wallet payment method ID. | String; | ||||
WalletResponseMessage | Returns the wallet response message. | String; | ||||
WalletResponseCode | Returns the wallet response code. | String; |
PayGuardian Android XML Data Format
Familiarity of the DLL interface, its properties and its uses is must, and it is the basis of the PayGuardian Android XML format. A request contains a PaymentRequest root tag and nested data elements containing DLL properties as tags. The response XML has a similar framework containing all of the standard response data.
Examples
Basic transaction request / response and receipt output examples.
MSR Sale Type Request
An example of a basic MSR sale transaction request.
Code Block |
---|
payGuardian = new com.bpn.payguardian.android.PayGuardian(getApplicationContext(), this, this);
PaymentRequest paymentRequest = new PaymentRequest();
paymentRequest.setTerminalType(PayGuardian.TERMINAL_TYPE_RBAUSB);
paymentRequest.setUsername("USERNAME");
paymentRequest.setPassword("PASSWORD");
paymentRequest.setMerchantCode("MERCHANT_CODE");
paymentRequest.setMerchantAccountCode("MERCHANT_ACCOUNT_CODE");
paymentRequest.setInvNum("1234");
paymentRequest.setAmount("5.00");
paymentRequest.setTenderType(PayGuardian.TenderTypes.CREDIT.getType());
paymentRequest.setTransType(PayGuardian.TransactionTypes.SALE.getType());
boolean started = payGuardian.processTransaction(paymentRequest, “TEST”);
\ |
MSR Sale Type Response
An example of a basic MSR sale transaction response.
Code Block |
---|
@Override
public void transactionResponse(PaymentResponse response)
{
//handle response
}
response = {PaymentResponse@21368}
AVSMessage = null
CVMessage = null
approvedAmount = {String@21410} "500"
authCode = {String@21411} "101400"
avsResponse = null
bogusAccountNumber = {String@21412} "************9269"
cardType = null
cashBackAmount = null
cvResponse = null
expirationDate = {String@21413} "0325"
extData = null
gatewayMessage = {String@21414} "A01 - Approved"
gatewayResult = null
hostCode = null
hostResponse = null
internalMessage = {String@21415} "Approved: 101400 (approval code)"
isCommercialCard = {String@21416} "False"
isoCountryCode = null
isoCurrencyCode = null
isoRequestDate = null
isoTransactionDate = null
merchantCategoryCode = null
message = null
message1 = null
message2 = null
networkMerchantId = null
networkReferenceNumber = null
networkTerminalId = null
rawResponse = null
refNum = {String@21417} "217228301"
remainingAmount = {String@21418} "000"
remainingBalance = null
requestAmount = null
responseTypeDescription = null
resultCode = {String@21419} "00000"
resultTxt = {String@21420} "Successful Request"
streetMatchMessage = null
submittedAmount = {String@21421} "500"
timeStamp = {String@21422} "20161230"
tipAmount = null
token = {String@21423} "11110000000077149269"
transactionCode = null |
MSR Sale Receipt
An example of the values returned on a basic MSR Sale receipt.
Code Block |
---|
BPNPayment.BPNReceipt:
maskedCardNumber: 5***********0608:
invoice: 8888
seq: 8888
authorizationCode: 290144
entryMethod: Swipe_Read
totalAmount: 55
appLabel:
cardHolderName: (null)
networkMerchantId: 518564010126944
networkTerminalId: PPB01.
cardFirstFour: 5413
cardType: Mastercard
requiresSignature: YES
pinEntered: NO |
Sale_Auth Transaction Type Request
An example of a basic authorization only transaction request.
Code Block |
---|
payGuardian = new com.bpn.payguardian.android.PayGuardian(getApplicationContext(), this, this);
PaymentRequest paymentRequest = new PaymentRequest();
paymentRequest.setTerminalType(PayGuardian.TERMINAL_TYPE_RBAUSB);
paymentRequest.setUsername("USERNAME");
paymentRequest.setPassword("PASSWORD");
paymentRequest.setMerchantCode("MERCHANT_CODE");
paymentRequest.setMerchantAccountCode("MERCHANT_ACCOUNT_CODE");
paymentRequest.setInvNum("1234");
paymentRequest.setAmount("5.00");
paymentRequest.setTenderType(PayGuardian.TenderTypes.CREDIT.getType());
paymentRequest.setTransType(PayGuardian.TransactionTypes.SALE_AUTH.getType());
boolean started = payGuardian.processTransaction(paymentRequest, “TEST”); |
Sale_Auth Transaction Type Response
An example of a basic authorization only transaction response.
Code Block |
---|
@Override
public void transactionResponse(PaymentResponse response)
{
//handle response
}
response = {PaymentResponse@21365}
AVSMessage = null
CVMessage = null
approvedAmount = {String@21406} "500"
authCode = {String@21407} "842171"
avsResponse = null
bogusAccountNumber = {String@21408} "************9269"
cardType = null
cashBackAmount = null
cvResponse = null
expirationDate = {String@21409} "0325"
extData = null
gatewayMessage = {String@21410} "A01 - Approved"
gatewayResult = null
hostCode = null
hostResponse = null
internalMessage = {String@21411} "Approved: 842171 (approval code)"
isCommercialCard = {String@21412} "False"
isoCountryCode = null
isoCurrencyCode = null
isoRequestDate = null
isoTransactionDate = null
merchantCategoryCode = null
message = null
message1 = null
message2 = null
networkMerchantId = null
networkReferenceNumber = null
networkTerminalId = null
rawResponse = null
refNum = {String@21413} "217228401"
remainingAmount = {String@21414} "0"
remainingBalance = null
requestedAmount = null
responseTypeDescription = null
resultCode = {String@21415} "00000"
resultTxt = {String@21416} "Successful Request"
streetMatchMessage = null
submittedAmount = {String@21417} "500"
timeStamp = {String@21418} "20161230"
tipAmount = null
token = {String@21419} "11110000000077149269"
transactionCode = null |
Sale_Auth Receipt
An example of the values returned on a basic authorization only receipt.
Table of Contents
Table of Contents |
---|
The