Version
API version 48.4
Documentation version 48.4
History
Version | Date | Name | Description |
---|---|---|---|
1.0 | 2011/06/10 | Emil Petkov | Initial version |
1.1 | 2011/11/11 | Emil Petkov | Added optional shipping params section for the shipping address |
1.2 | 2012/04/18 | Emil Petkov | Added dynamic descriptor functionality |
1.3 | 2012/08/03 | Emil Petkov | Added new transaction type AVS and Account Verification |
2.0 | 2013/03/29 | Emil Petkov | Added gaming and MOTO flags and support |
2.1 | 2013/04/11 | Emil Petkov | Split Credits with an initial ref transaction and Payouts without a reference transaction |
2.2 | 2013/05/26 | Emil Petkov | Added new transaction type InitRecurringSale3D - recurring payments with initial 3D |
2.3 | 2014/01/15 | Emil Petkov | Removed the transaction types DebitSale and IdealSale |
2.4 | 2014/01/22 | Emil Petkov | Added authorization code and issuer response code to API, section for issuer response codes |
2.5 | 2014/01/29 | Emil Petkov | Moto and gaming flags are now returned in the transaction response if present/marked in the request |
2.6 | 2014/02/05 | Emil Petkov | Dynamic descriptor params are now returned in the transaction response if present in the request |
2.7 | 2014/02/15 | Emil Petkov | Recurring advices are now returned in the transaction response if received from the issuer |
2.8 | 2014/05/01 | Emil Petkov | Added required vs. optional API params |
2.9 | 2014/06/16 | Emil Petkov | Currency handling rework and API description (different currency exponents, etc) |
3.0 | 2014/08/28 | Emil Petkov | Added risk related APIs - chargebacks, retrieval requests, blacklists |
3.1 | 2014/11/25 | Emil Petkov | Added API support for partial approvals |
3.2 | 2014/12/03 | Emil Petkov | Added WPF I18N specifics |
3.3 | 2014/12/08 | Emil Petkov | Added shopping carts and client integrations list |
3.4 | 2014/12/16 | Hristo Tanchev | Now the remote ip can be either a required or optional API param |
3.5 | 2015/02/22 | Dimitar Kostov | Added API for eZeeWallet and PayByVoucher via Yeepay |
3.6 | 2015/02/23 | Hristo Tanchev | Added API for CashU and Paysafecard |
3.7 | 2015/03/13 | Dimitar Kostov | Added API for Sofort |
3.8 | 2015/03/18 | Hristo Tanchev | Added API for PPRO |
3.9 | 2015/04/15 | Emil Petkov | New WPF API and WPF payment methods |
4.0 | 2015/05/14 | Hristo Tanchev | Added API for Neteller and ABN iDEAL |
4.1 | 2015/06/15 | Dimitar Kostov | Added WPF custom attributes - bin, tail |
4.2 | 2015/08/10 | Tsvetelina Borisova | Added WPF custom attributes - default, expiration date |
4.3 | 2015/08/12 | Vladimir Korichkov | Added API for WebMoney and POLi |
4.4 | 2015/08/19 | Tsvetelina Borisova | Added fraud related API for TC40/SAFE (fraud reports) |
4.5 | 2015/08/27 | Emil Petkov | 3D attributes xid and cavv are now not re- quired in the MPI sync attempted only workflow, only eci is |
4.6 | 2015/09/02 | Emil Petkov | New transaction type PayByVoucher Sale for purchasing vouchers via credit cards. Reworked the PayByVouchers section |
4.7 | 2015/09/04 | Emil Petkov | Added penetration testing warning for merchants |
4.8 | 2015/09/06 | Emil Petkov | Reconcile API now works with ARN and transaction ID in addition to unique ID |
4.9 | 2015/09/11 | Hristo Tanchev | Added Electronic Commerce Indicator to notifications |
5.0 | 2015/09/30 | Vladimir Korichkov | Added API for INPay |
5.1 | 2015/12/09 | Pepa Simeonova | Added event parameter to notifications for fraud transactions. |
5.2 | 2016/02/02 | Hristo Tanchev | Added API for P24 |
5.3 | 2016/02/16 | Tsvetelina Borisova | Added ARN in reconcile response if available. |
5.4 | 2016/03/18 | Tsvetelina Borisova | Added page for Manually Reviewed Transactions |
5.5 | 2016/03/17 | Tsvetelina Borisova | Added API for SDD. |
5.6 | 2016/03/28 | Emil Petkov | Extended PayByVouchers processing and WPF APIs with redeem type and card type |
5.7 | 2016/04/08 | Emil Petkov | Added info for statuspage.io, uptime and infrastructure, and new shopping carts |
5.8 | 2016/05/11 | Tsvetelina Borisova | Change the example for chargeback API - amount is returned in minor currency unit |
5.9 | 2016/05/22 | Emil Petkov | Now birth date API param is required only for Visa initial transactions with Financial Service MCCs (e.g. 6012) |
6.0 | 2016/06/30 | Pepa Simeonova | Added dynamic descriptor params to WPF payments. |
6.1 | 2016/07/20 | Stefan Slaveykov | Now usage can be either a required or optional API param |
6.2 | 2016/07/21 | Tsvetelina Borisova | Update documentation for chargebacks API |
6.3 | 2016/12/08 | George Naydenov | Added API for Trustly |
6.4 | 2017/01/20 | Plamen Terziev | Added AVS Codes |
6.5 | 2017/02/16 | Nikolay Petrov | Added API for PayPal Express Checkout |
6.6 | 2017/03/20 | Iskar Enev | Added API for Citadel |
6.7 | 2017/03/30 | Stanislav Mihailov | Added API for Instadebit/iDebit |
6.8 | 2017/03/31 | Tsvetelina Borisova | Added API for SCT Payout |
6.9 | 2017/05/12 | Nikolay Petrov | Added reference transaction unique id to the Reconcile API response |
7.0 | 2017/05/13 | Nikolay Petrov | Added API for Earthport |
7.1 | 2017/05/15 | Stanislav Mihailov | Added API for Wechat |
7.2 | 2017/05/30 | George Naydenov | Added API for Alipay |
7.3 | 2017/06/05 | Hristo Tanchev | Added API for PaySec |
7.4 | 2017/06/06 | Hristo Tenev | Added card brand and card number tags in reconcile response. |
7.5 | 2017/06/27 | Lukasz Wojcik | Added lifetime for WPF Payments. |
7.6 | 2017/07/06 | Nikolay Petrov | Removed AVS transaction type. AVS response code and text are returned in the transactions responses when present and supported or in the notifications for payments with asynchronous workflow. |
7.7 | 2017/07/06 | Iskar Enev | Added APM External Events. |
7.8 | 2017/08/11 | Samuil Goranov | Added support for optional shipping address params in Processing and WPF APIs. |
7.9 | 2017/08/17 | Lukasz Wojcik | Remove remote ip parameter for transactions with reference. It will be copied from reference transaction |
8.0 | 2017/08/18 | Lukasz Wojcik | Added invalid transaction types for amount parameter to WPF response. |
8.1 | 2017/08/18 | Emil Kirilov | Added search option by import date in Chargeback, Retrieval request and Fraud APIs. |
8.2 | 2017/09/05 | George Naydenov | Added API for RPN Payment |
8.3 | 2017/10/13 | Ventsislav Dimitrov | Added API for FashionCheque gift card and split payments. |
8.4 | 2017/10/13 | Pepa Simeonova | Added API for Intersolve gift card and split payments. |
8.5 | 2017/10/13 | Stanislav Mihailov | Added API for TCS gift card and split payments. |
8.6 | 2017/10/23 | Iskar Enev | Added Authentication Services and iSignThis. |
8.7 | 2017/11/02 | George Naydenov | Added API for RPN Payout |
8.8 | 2017/11/24 | Hristo Tenev | Added API for Paycommerce |
8.9 | 2017/11/25 | George Naydenov | API update with new sections Card, 3DS Card, Common. Removing older payment methods. |
9.0 | 2017/12/18 | George Naydenov | Added API for Neosurf. |
9.1 | 2018/01/02 | George Naydenov | Removed API for Inpay, ABN iDeal, Teleingreso and PayByVoucher. |
9.2 | 2018/01/03 | Iskar Enev & Nikolay Petrov | Added Tokenization service. |
9.3 | 2018/01/12 | Hristo Tanchev | Added API for Klarna. |
9.4 | 2018/01/18 | Stefan Petrov | Added ARN in WPF reconcile response if available. |
9.5 | 2018/01/26 | George Naydenov | Added API for Astropay Direct, Pago Facil, Link, Carulla, Davivienda. |
9.6 | 2018/02/22 | George Kostov & Hristo Tenev | Added API for Genesis KYC Services. |
9.7 | 2018/02/22 | Emil Kirilov | Added API for PSE. |
9.8 | 2018/02/26 | Stefan Petrov | Added API for RapiPago, Webpay, Banco de Chile. |
9.9 | 2018/03/01 | Stefan Petrov | Added API for Surtimax, Efecty, Cabal, Cencosud, Hipercard, Elo, Aura, Itau, Bradesco, Tarjeta Shopping, BBVA Bancomer, Boleto, Redpagos, Emprese De Energia, GiroPay, InstantTransfer, Multibanco. |
10.0 | 2018/03/02 | George Naydenov | Added API for OXXO, Argencard, Naranja, Nativa, Cartao Mercado Livre, Astropay Card, Banamex, Santander, Santander Cash, Zimpler PayU. |
10.1 | 2018/03/02 | Emil Kirilov | Added API for Baloto, Banco de Occidente, Banco do Brasil. |
10.2 | 2018/04/10 | Stefan Petrov | Added API for Entercash. |
10.3 | 2018/05/08 | Hristo Tenev | Added API for eZeeWallet Payout. |
10.4 | 2018/05/31 | Maya Nedyalkova | Added 3D MasterCard test cards. |
10.5 | 2018/05/31 | George Naydenov | Added API for QQPay. |
10.6 | 2018/06/22 | Hristo Tanchev | Added API for Credential on File (COF). |
10.7 | 2018/07/05 | George Naydenov | Removed Paysec and added Online Banking OBeP. |
10.8 | 2018/07/18 | Stanislav Mihailov | Added the API param issuer_oct_enabled to Visa-based Account Verification transactions, to allow merchant to verify if issuer supports OCTs for the given PAN |
10.9 | 2018/07/27 | Yordan Pulov | Added Money Transfer support to Payouts. |
11.0 | 2018/08/01 | George Naydenov | Removed Paysec Payout and added Bank Payout. |
11.1 | 2018/08/02 | Stanislav Mihailov | Remove API for Citadel |
11.2 | 2018/08/31 | Hristo Tenev | Added API for BitPay. |
11.3 | 2018/08/31 | Maya Nedyalkova | Add rc_code and rc_description in notification parameters. |
11.4 | 2018/10/10 | Ralitsa Borisova | Remove Paycommerce, RPN Payment, Link, Davivienda, Banco de Chile, Cartao Mercado Livre documentation. |
11.5 | 2018/10/11 | Emil Petkov | Introduced debt repayments - now birth date API param is required also for Mastercard/- Maestro initial transactions with Financial Service MCCs (e.g. 6012), where merchant is UK-based, transaction is domestic (with UK-based bin), and card type is DEBIT. |
11.6 | 2018/11/02 | Yordan Pulov and Stanislav Mihailov | Introduced Travel layer and Added Level 3 Travel API. |
11.7 | 2018/11/21 | Hristo Tenev | Added Payout support for BitPay |
11.8 | 2018/12/05 | Stefan Petrov | Added API for eZeeCard Payout |
11.9 | 2018/12/05 | Nikolay Petrov | Added Pay Later support to the WPF. Introduced Reminders module. |
12.0 | 2019/01/07 | Yordan Pulov | Changed Contract Merchant Category Codes for Level 3 Visa Car and Hotel Rental Transactions. |
12.1 | 2019/01/31 | Aleksandar Krastev | Introduced Consumer API. Extended Tokenization API to require a consumer. Extended WPF and Processing APIs to create consumers and tokenize card details in one step. WPF API can use saved cards to make payments. |
12.2 | 2019/02/18 | Yordan Pulov | Extend the Online Banking bank codes and add payment type. |
12.3 | 2019/02/26 | Stefan Petrov | Added API for Tola payments. |
12.4 | 2019/03/13 | Stanislav Mihailov | Added support for new non-money transfer payout types. |
12.5 | 2019/03/19 | Nikolay Valchanov | Added cardholder and expiration dates params to reconcile APIs. |
12.6 | 2019/03/19 | Vladislav Yakimov | Added retrieve endpoint for the Consumer API. |
12.7 | 2019/03/22 | Ventsislav Dimitrov | Added support for Preauthorizations. |
12.8 | 2019/03/28 | Nikolay Petrov | Added support for importation of external tokens and card details. |
12.9 | 2019/04/01 | Nikolay Petrov & Yasen Angelov | Added support for Pay by Link functionality. |
13.0 | 2019/04/09 | Hristo Tenev | Added API for transaction card expiry date update. |
13.1 | 2019/04/11 | Stanislav Mihailov | Added API support for purchase of cryptocurrency transactions. |
13.2 | 2019/04/12 | George Naydenov | Removed QQPay transaction type. |
13.3 | 2019/04/15 | Nikolay Valchanov | Added usage and description params to WPF reconcile API. |
13.4 | 2019/04/22 | Nikolay Valchanov | Added optional bic param to iDeal transactions. |
13.5 | 2019/05/31 | George Naydenov | Added Genesis Fx Services. |
13.6 | 2019/06/07 | Rumen Milushev | Added WPF API Reconcile by_date. |
13.7 | 2019/06/14 | Yordan Pulov | Extended the Online Banking bank codes and Bank Payout banks. |
13.8 | 2019/07/02 | Aleksandar Krastev | Added Tokenization API get masked card details for token. |
13.9 | 2019/07/04 | Vladislav Yakimov | Added API for TransferTo Payout and TransferTo Payers retrieve. |
14.0 | 2019/07/09 | Stefan Petrov | Extend the Online Banking bank codes. |
14.1 | 2019/07/11 | Pepa Simeonova | Added new money-transfer types. |
14.2 | 2019/07/16 | Hristo Tenev | Added API support for Business attributes. |
14.3 | 2019/07/22 | Pepa Simeonova | Added source_of_funds as an optional API param for OCT types (Credit, Payout) |
14.4 | 2019/08/01 | Stefan Petrov | Removed API for Astropay Card, Astropay Direct, Hipercard, Carulla, Emprese de Energia, Surtimax. |
14.5 | 2019/08/05 | Hristo Tanchev | Extended Processing and WPF APIs support for FX (Forex). |
14.6 | 2019/08/05 | Martin Lazarov | Added reversible amount in Preauthorization reconcile response. |
14.7 | 2019/08/06 | Rumen Milushev | Added MOTO flag to WPF transaction types: Authorize, Authorize3D, Sale, Sale3D. |
14.8 | 2019/08/07 | Yasen Angelov | Added the new optional param reminder_language to the WPF API. |
14.9 | 2019/08/13 | Stefan Petrov | Rebranding African Mobile payments. |
15.0 | 2019/08/21 | Nikolay Petrov | Added new status 'represented' in notifications for Processing and WPF APIs. |
15.1 | 2019/08/22 | Stefan Petrov | Added beneficiary params to refund transaction. |
15.2 | 2019/09/03 | Stefan Petrov | Use sync workflow for Neosurf transaction. |
15.3 | 2019/09/13 | Hristo Tanchev | Extended transaction response with transaction ID form card schemes. |
15.4 | 2019/09/13 | Yordan Pulov | Added Genesis SCA Checker service API. |
15.5 | 2019/09/16 | Nikolay Petrov | Added support for Account Verification to the WPF API. |
15.6 | 2019/09/17 | Ventsislav Dimitrov | Extended the supported Merchant Category Codes for Visa Preauthorization |
15.7 | 2019/09/18 | Aleksandar Krastev | Added Processed Transaction API for Card Present and Card Not Present transactions. |
15.8 | 2019/09/20 | Yordan Pulov | Extended Genesis SCA Checker service API documentation. |
15.9 | 2019/09/20 | Yordan Pulov | Added new fields and changed the endpoint for sending TransferToAPI requests. |
16.0 | 2019/09/24 | Rumen Milushev | Added 'agency_name' to Hotel Rental Travel attributes. |
16.1 | 2019/09/25 | Aleksandar Krastev | Changed filter flags of Processed Transaction API by_date and by_post_date endpoints. |
16.2 | 2019/10/09 | Aleksandar Krastev | Extended Chargeback API to return more attributes; Added flags filtering by origin and type of processing. |
16.3 | 2019/10/10 | Pepa Simeonova | Added new MPI parameters and SCA parameters. |
16.4 | 2019/10/16 | Aleksandar Krastev | Extended Retrieval Request API to return more attributes; Added flags filtering by origin and type of processing. |
16.5 | 2019/10/17 | Martin Lazarov | Extended the supported Merchant Category Codes for Visa Preauthorization. |
16.6 | 2019/10/21 | Yordan Pulov | Added support for UATP Travel. |
16.7 | 2019/10/24 | Rumen Milushev | Transferred Hotel Rentals, Car Rentals and Cruise Lines from Travel Level 3 data to Business Attributes. |
16.8 | 2019/10/24 | Martin Lazarov | Added Reference Transaction Unique ID to notification parameters for the reference-based transactions. |
16.9 | 2019/10/31 | Martin Lazarov | Added Capture tolerance for Mastercard and Maestro Preauthorizations. |
17.0 | 2019/11/05 | Yordan Pulov | Added new fields for TransferTo Payout. |
17.1 | 2019/11/05 | Nikolay Petrov | Added new supported currencies and banks for Bank Payout. |
17.2 | 2019/11/15 | Ventsislav Dimitrov | Added API support for purchasing Mastercard and Maestro crypto-currencies. |
17.3 | 2019/11/15 | Nikolay Petrov | Added optional bank params to the refund transaction. |
17.4 | 2019/11/19 | Stefan Petrov | Added Processed Batches API. |
17.5 | 2019/11/20 | Pepa Simeonova | Added sub_merchant_id as an optional dynamic descriptor param. |
17.6 | 2019/11/20 | Rumen Milushev | Added optional time extensions to the Processing Reconcile and WPF Reconcile APIs. |
17.7 | 2019/11/21 | Nikolay Petrov | Added support for Online Banking Unified Payment Interface (UPI) payment type. |
17.8 | 2019/11/27 | Stefan Petrov | Added Batch and Deposit Slip Numbers to Processed Transaction API response. |
17.9 | 2019/11/28 | Stefan Petrov | Removed API for Entercash and Banamex. |
18.0 | 2019/12/03 | Nikolay Petrov | Made BIC param optional for SddSale and SddInitRecurringSale transactions. |
18.1 | 2019/12/05 | Nikolay Petrov | Added supported bank codes for Online Banking that can be used with Netbanking payment type. |
18.2 | 2019/12/12 | George Naydenov | Added Trustly Select Account API. Extended parameters for Trustly Sale and Bank Pay-out. |
18.3 | 2019/12/18 | Rumen Milushev | Added descriptions for Airlines and Travel agencies in Business Attributes. |
18.4 | 2019/12/20 | George Naydenov | Added birth_date as conditionally required API param for Trustly Sale and Bank Pay-out. |
18.5 | 2020/01/08 | Hristo Tenev | Added Funding Account API for Card Present and Card Not Present transactions. |
18.6 | 2020/01/21 | Sridhar Belagod | Added Trustly Register Account API. |
18.7 | 2020/01/29 | Sridhar Belagod | Marked birth_date as optional param for Trustly and changed description. |
18.8 | 2020/01/29 | Ralitsa Borisova | Added Finnish language as part of the platform internationalization |
18.9 | 2020/01/30 | Sridhar Belagod | Updated supported countries for Trustly Sale. |
19.0 | 2020/02/04 | Dmitri Lihachev | Added API for Apple Pay. |
19.1 | 2020/02/05 | Sridhar Belagod | Removed unique_id param from Trustly RegisterAccount API. Updated birth_date format and extended the example to include country-specific format |
19.2 | 2020/02/05 | Stefan Petrov | Exposed querying and reconciling by ARN for Fraud reports, Chargebacks and Transactions. |
19.3 | 2020/02/21 | Ralitsa Borisova | Updated description for Trustly Sale. |
19.4 | 2020/02/26 | Rumen Milushev | Added batch_slip_number and deposit_slip_number as optional search params for ProcessedTransactions and ProcessedBatches. |
19.5 | 2020/02/26 | Rumen Milushev | Added type and card_number response params to Processed Transactions API response. |
19.6 | 2020/02/28 | Svilen Siderov | Updated MyBank supported countries for PPRO. |
19.7 | 2020/03/11 | Stanislav Mihailov | Added Payment Authorizations API for Card Present and Card Not Present authorizations. |
19.8 | 2020/03/18 | Nikolay Petrov | Added captured flag and capturable_amount param to Reconcile API response for authorizations. |
19.9 | 2020/03/18 | Stefan Petrov | Updated supported countries for PaysafeCard. |
20.0 | 2020/03/19 | Stefan Petrov | Removed France and United Kingdom from the supported countries for Sofort. |
20.1 | 2020/03/18 | Teodor Nikolov | Updated amount fields descriptions. |
20.2 | 2020/03/23 | George Naydenov | Added list of supported clearinghouses for Trustly register account call. |
20.3 | 2020/03/23 | Rumen Milushev | Added merchant_number, merchant_reference_transaction and capture_method to Chargebacks API response. |
20.4 | 2020/03/27 | Rumen Milushev | Unified response param to 'merchant_transaction_reference' in Payment Transactions and Chargebacks API. |
20.5 | 2020/04/03 | Ventsislav Dimitrov | Added asynchronous 3DSv2 support for 3D transaction types |
20.6 | 2020/04/03 | Svilen Siderov | Added card type, card subtype and card issuing bank to the Processing and WPF Reconcile API responses |
20.7 | 2020/04/08 | Stanislav Mihailov | Extended Risk data APIs (TC40/SAFE, Chargebacks, Retrieval Requests) to return a list of records by ARN or by transaction unique ID if the new list mode is enabled |
20.8 | 2020/04/15 | Stanislav Mihailov | Updated amount field for Card Present, Card Not Present and External payment authorizations. |
20.9 | 2020/04/15 | Martin Lazarov | Added details about Async Refund transaction type. |
21.0 | 2020/04/15 | George Naydenov | Added clearing houses list of supported IBANs and account numbers for Trustly Register Account |
21.1 | 2020/04/20 | Ventsislav Dimitrov | Changed the Mastercard test card numbers for card enrolled and card not participating in the 3DSv1. |
21.2 | 2020/04/28 | Stanislav Mihailov | Made gaming flag optional for purchase of VISA cryptocurrency transactions. |
21.3 | 2020/04/28 | Ventsislav Dimitrov | Added additional required recurring params for asynchronous InitRecurringSale3d using 3DSv2 authentication protocol. |
21.4 | 2020/05/05 | Ventsislav Dimitrov | Added more advanced merchant sequence flow diagrams for 3DSv1 and 3DSv2 authentication protocols using the Processing API. |
21.5 | 2020/05/05 | Ralitsa Borisova | Added Norwegian, Danish and Swedish language as part of the platform internationalization. |
21.6 | 2020/05/11 | Svilen Siderov | Added bank account number and bank identifier code to the Processing and WPF Reconcile API responses. |
21.7 | 2020/05/15 | Ventsislav Dimitrov | Added more detailed request examples for synchronous 3DSecure Visa and MasterCard transactions through the 3DSv1 and 3DSv2 authentication protocol. |
21.8 | 2020/05/15 | Ventsislav Dimitrov | Marked xid as out of scope for synchronous 3DSecure transactions using the 3DSv2 authentication protocol. |
21.9 | 2020/05/15 | Ventsislav Dimitrov | Extended the 3DSv2 documentation, authentication flow diagrams, and marked usage as required param when processing asynchronous 3DSecure transaction through 3DSv2 authentication protocol. |
22.0 | 2020/05/19 | Martin Lazarov | Updated the documentation related to Alipay transaction type, its transaction amount limits and currencies. |
22.1 | 2020/06/01 | Mario Chankov | Updated the description related to POLi payment. |
22.2 | 2020/06/01 | Svilen Siderov | Added Alipay Register Merchant API. |
22.3 | 2020/06/09 | Svilen Siderov | Added auth_start_date and auth_end_date to Payment Authorizations API request. |
22.4 | 2020/06/24 | Martin Lazarov | Added authorization_code to the API and WPF notification of various transaction types. |
22.5 | 2020/06/25 | Martin Lazarov | Added retrieval_reference_number to: API/WPF notifications, API/WPF response and API/WPF reconciliation response. |
22.6 | 2020/07/01 | Martin Lazarov | Removed UPI from Online banking supported payment types. Added new transaction type UPI. |
22.7 | 2020/07/07 | Nikolay Petrov | Added support for AliPay QR payment type in the Online Banking. |
22.8 | 2020/07/10 | Mario Chankov | Removed Zimpler and Santander Cash. Changes to supported countries for MyBank, Safetypay and Santander |
22.9 | 2020/07/17 | Ventsislav Dimitrov | Changed the 3DSv2-Method submission from HTTP GET to HTTP POST with signature mechanism, extended 3DSv2 authentication flow diagrams. |
23.0 | 2020/07/17 | Ventsislav Dimitrov | Added API endpoint for handling continuation after 3DSv2-Method submission. |
23.1 | 2020/07/17 | Ventsislav Dimitrov | Added threeds_method_callback_url as optional request param to 3DS transaction types in asynchronous workflow. |
23.2 | 2020/07/17 | Ventsislav Dimitrov | Added 3DS response attributes to the Processing reconciliation and notification for 3DS transaction types in asynchronous workflow. |
23.3 | 2020/07/18 | Ventsislav Dimitrov | Dropped the synchronous 3DSv2-Method workflow handling and authentication flow sequence diagrams. |
23.4 | 2020/07/20 | Alexey Kuznetsov | Renamed Klarna related transaction to Invoice. Also, migrate Klarna items to transaction items and introduce a new payment type for different types of invoices. |
23.5 | 2020/07/21 | Stefan Petrov | Added new pending_hold status for async transactions where finalized by user, but final update from provider not yet received (Sofort, etc) |
23.6 | 2020/07/22 | Stanislav Mihailov | Updated the documentation for TC40/SAFE APIs (fraud reports) when searching by date. |
23.7 | 2020/07/22 | Martin Lazarov | Added details regarding partially_reversed payment transaction state. |
23.8 | 2020/07/22 | Tsvetan Tsvetanov | Changed Sofort transaction parameter name from bank_account_number to iban |
23.9 | 2020/08/04 | Filipp Pirozhkov | Added new tokenization errors and client-side encryption errors. |
24.0 | 2020/08/05 | Vladimir Nudelman | Added return_pending_url as an optional param to the WPF API |
24.1 | 2020/08/05 | Stefan Petrov | Made voucher_number for Neosurf transactions conditionally required. |
24.2 | 2020/08/06 | Vladimir Nudelman | Added cvv_result_code as an optional parameter in the notifications, transaction responses, and reconciliation responses for both WPF and Processing APIs. |
24.3 | 2020/08/17 | Tsvetan Tsvetanov | Added return_success_url_target as optional request param to Trustly Sale via Processing API and WPF. |
24.4 | 2020/08/24 | Pepa Simeonova | Added Funds Transfer BAI and removed MCC restrictions for money transfer payouts. |
24.5 | 2020/08/26 | Martin Lazarov | Added new TransferTo transfer type: C2C (Consumer to Consumer) as well as new conditionally required sender parameters, a table with supported destination countries and currencies, and a link to Retrieve Payers API. |
24.6 | 2020/08/26 | Martin Lazarov | Removed NB as available bank code for INR Online Banking transactions as well as the corresponding Netbanking-related notes. |
24.7 | 2020/09/02 | Eduard Gataullin | Removed currency attribute from Recurring Sale transaction params, as recurring series work only with the same currency as the init recurring and cannot be changed. |
24.8 | 2020/09/09 | Martin Lazarov | Added new conditionally required attributes for TransferTo payouts for the B2B scenario - document_reference_number and purpose_of_remittance . |
24.9 | 2020/09/16 | Alexey Kuznetsov | Added API for Secure Invoice payments. |
25.0 | 2020/09/16 | Martin Lazarov | Renamed the following TransferTo payout attributes: sender_lastname , sender_firstname , ifs_code to: sender_last_name , sender_first_name and indian_financial_system_code . |
25.1 | 2020/09/16 | George Naydenov | Added API for PostFinance. |
25.2 | 2020/09/29 | Martin Lazarov | Clarified the descriptions of the following TransferTo payout attributes: account_type , country , msisdn and sender_msisdn |
25.3 | 2020/10/02 | Maya Nedyalkova | Added capability to AVS response attributes. |
25.4 | 2020/10/21 | Ventsislav Dimitrov | Added field format restrictions to the billing and shipping address for async 3DS transactions that are using the 3DSv2 authentication protocol. |
25.5 | 2020/10/27 | Ventsislav Dimitrov | Added international customer phone field format notes for async 3DS transactions that are using the 3DSv2 authentication protocol. |
25.6 | 2020/10/27 | Ventsislav Dimitrov | Added card holder field format restrictions for async 3DS transactions that are using the 3DSv2 authentication protocol. |
25.7 | 2020/10/28 | Kuznetsov Alexey | Added API for e-wallet solutions. |
25.8 | 2020/10/28 | Ventsislav Dimitrov | Added state field format notes for the billing and shipping attributes of async 3DS transactions that are using the 3DSv2 authentication protocol as per the EMVCo spec for 3DSv2.1. |
25.9 | 2020/10/28 | Ventsislav Dimitrov | Added hints for building the signatures in the 3DSv2 scope of 3DS transactions that require 3DS-Method submission. |
26.0 | 2020/11/04 | Ralitsa Borisova | Extend MCC range for Airlines segment in Business Attributes. |
26.1 | 2020/11/04 | Maya Nedyalkova | Added funds status attribute to the Reconcile API responses. |
26.2 | 2020/11/13 | Pepa Simeonova & Ventsislav Dimitrov | Added support for 3DSv2 authentication protocol to the Web Payment Form. |
26.3 | 2020/11/16 | Pepa Simeonova & Ventsislav Dimitrov | Added additional 3DS attributes to the WPF Notification and WPF reconcile API response. |
26.4 | 2020/11/18 | Ventsislav Dimitrov | Changed the additional purchase and recurring params of the 3DSv2 authentication protocol to optional for 3DS transactions through the processing API. |
26.5 | 2020/11/24 | Martin Lazarov | Update the description of payment_type for Online Banking transactions. |
26.6 | 2020/11/24 | George Naydenov | Extend Online Banking banks list and supported currencies. |
26.7 | 2020/12/01 | Mario Chankov | Removed Bancolombia and DirectDebit as supported bank codes for ARS and COP currencies under Online Banking. |
26.8 | 2020/12/01 | Stanislav Mihailov | Added scheme_settlement_date to Processing API and Processing API/WPF API reconciliation responses. Extended the scheme_transaction_identifier description and added it to WPF API reconciliation response. |
26.9 | 2020/12/03 | George Naydenov | Removed national_id attribute for Online Banking. |
27.0 | 2020/12/08 | Martin Lazarov | Added support for sca_params for Authorize and Sale transaction types and updated the description for the exemption field. |
27.1 | 2020/12/08 | Stanislav Mihailov | Added credential_on_file_settlement_date attribute to Authorize and Sale payment transaction types. Extended the Credential On File section with a description for merchant_unscheduled COF type. |
27.2 | 2020/12/08 | Vladimir Nudelman | Added support for auth_network_outage exemption to Authorize and Sale transactions. |
27.3 | 2020/12/15 | Ventsislav Dimitrov | Added information for low_risk SCA exemption to sync/async 3DSv2 transactions and extended the transaction example requests. |
27.4 | 2020/12/15 | Ventsislav Dimitrov | Changed the usage param to optional for async 3DS transactions through the 3DSv2 authentication protocol. |
27.5 | 2020/12/16 | Maya Nedyalkova | Removed API for QIWI and InstantTransfer. |
27.6 | 2020/12/30 | Ventsislav Dimitrov | Extended the validation and description of the browser request parameters in the scope of 3DS transactions through the 3DSv2 authentication protocol. |
27.7 | 2021/01/06 | Martin Lazarov | Added an example EEA MasterCard card number for simulating the low-risk exemption request in synchronous 3DSv2 workflow. |
27.8 | 2021/01/26 | Martin Lazarov | Extended the description of the color_depth attribute as part of the required async 3DSv2 browser device channel attributes within the 3DSv2 authentication protocol. |
27.9 | 2021/01/26 | Teodor Nikolov | Removed API for Trustly withdrawal. |
28.0 | 2021/01/28 | Stefan Petrov | Added bank codes for P24. |
28.1 | 2021/01/28 | Eduard Gataullin | Added verification and verification status KYC endpoints. |
28.2 | 2020/02/04 | Ventsislav Dimitrov | Added support for numeric chars in the browser language subtag for transactions with 3DSv2 authentication protocol. |
28.3 | 2021/02/05 | Pavel Abolmasov | Added return_pending_url as optional param for APMs via Processing API. |
28.4 | 2021/02/12 | Maya Nedyalkova | Added description for the bic field to iDeal. Included warning for iframes usage. |
28.5 | 2021/02/16 | Ventsislav Dimitrov | Extended the list with the originated IPs for asynchronous payment notifications. |
28.6 | 2021/02/12 | Eduard Gataullin | Added background checks support to verification KYC endpoints. |
28.7 | 2021/02/18 | Stanislav Mihailov | Added an example EEA Visa card number, CAVV and ECI for simulating the low-risk exemption request in synchronous 3DSv2 workflow. |
28.8 | 2021/03/12 | Evgeny Zhdanov | Added funds_status and account_holder attributes to WPF reconcile, notification, and to reconcile params. |
28.9 | 2021/03/17 | Pepa Simeonova | Added sca_preference to WPF API params. |
29.0 | 2021/03/18 | Martin Lazarov | Added support for zero-value amounts with the card-based transaction types - Sale, Sale3D, Authorize, Authorize3D, Init Recurring Sale, Init Recurring Sale3D. |
29.1 | 2021/03/24 | Martin Lazarov | Added a notice for amount restrictions of the Partial Reversal transactions. |
29.2 | 2021/04/29 | Eduard Gataullin | Added support for an optional reference_id parameter to verification KYC endpoints. |
29.3 | 2021/05/11 | Martin Lazarov | Added payment_type to the list of supported business attributes. |
29.4 | 2021/05/14 | Atanas Zlatarev | Removed Spain from the supported countries of MyBank transaction. |
29.5 | 2021/05/19 | Maya Nedyalkova | Added support for Revolut to iDeal transactions. |
29.6 | 2021/05/19 | Simeon Angelov | Extended supported currencies for Neosurf. |
29.7 | 2021/06/22 | Hristo Tanchev | Extended Init Recurring with scheme_settlement_date and scheme_transaction_identifier attributes. |
29.8 | 2021/07/09 | Nikola Yurukov | Updated WPF transaction types. |
29.9 | 2021/07/15 | Ventsislav Dimitrov | Added additional originating IPs for the asynchronous payment notifications on the Staging environment. |
30.0 | 2021/07/21 | Mario Chankov | Removed Moneyou from the list of available issuers for the iDeal payment method. |
30.1 | 2021/07/22 | Rumen Milushev | Added Russian mobile sale and mobile payout transaction types. |
30.2 | 2021/08/03 | George Naydenov | Extended the description for online banking and transaction types that are going to be deprecated. |
30.3 | 2021/08/06 | Ventsislav Dimitrov | Extended the description note with the allowed characters of the card_holder request param for Payout with Visa or MasterCard gambling transactions regarding winnings. |
30.4 | 2021/08/16 | Mario Chankov | Added Moldova (MD) to the list of supported countries for the Paysafecard transaction type. |
30.5 | 2021/08/16 | Pepa Simeonova | Added sender_birth_date to money-transfer payout params. |
30.6 | 2021/08/18 | Simeon Angelov | Extended the list with supported currencies for Bitpay Sale transaction type. |
30.7 | 2021/08/23 | Simeon Angelov | Updated the list with supported countries for Bitpay transaction types. |
30.8 | 2021/09/03 | Ventsislav Dimitrov | Added additional originating IPs for the asynchronous payment notifications on the Production environment. |
30.9 | 2021/09/09 | Eduard Gataullin | Made the country parameter optional and added support for address_backside_proof_required and expiry_date as optional parameters for the verification KYC endpoint. |
31.0 | 2021/09/14 | Svilen Siderov | Added API for Google Pay. |
31.1 | 2021/09/27 | Ventsislav Dimitrov | Added a warning note how to avoid Cross-origin resource sharing issues during 3DS-Method-Continue submission in the 3DSv2 authentication protocol. |
31.2 | 2021/09/28 | Svilen Siderov | Removed API for Earthport. |
31.3 | 2021/10/05 | Pepa Simeonova | Added scheme response code and recurring advice in the notifications, transaction responses, and reconciliation responses for both WPF and Processing APIs. |
31.4 | 2021/10/12 | Ralitsa Tsonova | Clarified the descriptions for amount , currency and chargeback_amount , chargeback_currency in Chargeback API section. |
31.5 | 2021/10/15 | Nikolay Petrov | Added optional purpose_of_payment parameter for Visa OCTs. |
31.6 | 2021/10/26 | Simeon Angelov | Added support for Low Risk and Low Value SCA exemptions to the WPF API. |
31.7 | 2021/11/01 | George Naydenov | Added SCA reasons for not honoring exemption. |
31.8 | 2021/11/09 | Svilen Siderov | Added a new payment type for Google Pay API. |
31.9 | 2021/11/24 | Teodor Nikolov | Added additional gateways support for the eWallet transaction type with a restricted list of providers. |
32.0 | 2021/12/08 | Hristo Tanchev | Added MOTO flag to WPF transaction types: InitRecurringSale and InitRecurringSale3D. |
32.1 | 2021/12/09 | George Naydenov | Added Interac Combined Pay-in bank code for Online Banking transaction |
32.2 | 2021/12/14 | Blagoy Vangelov | Added new transaction type PIX. |
32.3 | 2021/12/17 | Hristo Tanchev | Added support for managed recurring. |
32.4 | 2021/12/21 | Simeon Angelov | Added ECI to the 3DS attributes in the transaction responses and reconciliation responses for both WPF and Processing APIs. |
32.5 | 2021/12/21 | Slavcho Savov | Added support for Shopware and Magento 2.x EE, ECE in the Shopping Carts section. Removed the deprecated Magento 1.x from the supported shopping cart plugins. |
32.6 | 2021/12/14 | Svilen Siderov | Added API for PayPal transaction type. |
32.7 | 2022/01/10 | Boris Kolev | Updated supported banks list for bank payouts - extended banks list for CLP currency. |
32.8 | 2022/01/11 | Georgi Naydenov | Updated supported banks list for bank payouts - extended banks list for CAD currency. |
32.9 | 2021/01/13 | Teodor Nikolov | Added report_date to the Fraud Report API response. |
33.0 | 2022/01/13 | Svilen Siderov | Replaced API for PaypalExpress with new express payment type for PayPal API. |
33.1 | 2022/02/02 | Ventsislav Dimitrov | Add support for ApplePay on Web Payment Form's express checkout page. |
33.2 | 2022/02/03 | Yordan Pulov | Extended KYC verification creation request with optional params. |
33.3 | 2022/02/09 | Boris Kolev | Added search by Report Date for Fraud Report API. |
33.4 | 2022/02/09 | Muhammad Moawaz Ayub | Added API for retrieving Rapid Dispute Resolutions. |
33.5 | 2022/02/10 | Yuliyan Dudin | Added scheme_transaction_identifier and scheme_settlement_date to the API and WPF notifications. |
33.6 | 2022/02/15 | Boris Kolev | Changed recurring payment type to init_recurring_sale for Mobile-Tokenized transactions like Apple Pay and Google Pay. |
33.7 | 2022/02/10 | Evgeny Zhdanov | Extended Bank Pay-out id_card_number with link. Added more bank names for BRL. |
33.8 | 2022/02/22 | Teodor Nikolov | Added card issuing country to the Processing and WPF Reconcile API responses. |
33.9 | 2022/02/24 | Boris Kolev | Changed payment_type to payment_subtype for Mobile-Tokenized transactions like Apple Pay and Google Pay. |
34.0 | 2022/02/28 | Mario Chankov | Changed the bic and iban request parameters for Giropay to optional. |
34.1 | 2022/03/01 | Ventsislav Dimitrov | Added support for payment subtype sale to Apple Pay Processing and WPF API. |
34.2 | 2022/03/04 | Blagoy Vangelov | Removed consumer_reference for PIX transaction type. The first_name and last_name in billing_address become required for PIX. |
34.3 | 2022/03/07 | Simeon Angelov | Added 3DS authentication status reason code to: API/WPF notifications, API/WPF response and API/WPF reconciliation response. |
34.4 | 2022/03/02 | Milen Matev | Added information for the different environments in a new Environments section. |
34.5 | 2022/03/17 | Ivan Kolev | Added new chargeback response parameters: chargeback_account_amount , chargeback_account_currency , merchant_funding_amount , merchant_funding_currency |
34.6 | 2022/03/17 | Boris Kolev | Changed the 3DS-Method status callback from synchronous to asynchronous for all 3DSv2 authentication flows. |
34.7 | 2022/03/17 | Boris Kolev | Extended the 3DSv2 authentication flows with conflict response in case of duplicated 3DS-Method continue is requested. |
34.8 | 2022/03/22 | Ivan Kolev | Extended the WPF Notification and Async Notification with additional optional parameters that can be requested by the merchant. |
34.9 | 2022/03/22 | Svilen Siderov | Added web_payment_form_id parameter to WPF create request parameters. |
35.0 | 2022/04/04 | Ilya Rogozin | Added Tokenized e-Commerce section and introduced scheme_tokenized attribute to Processing API for transactions with scheme tokenization support. |
35.1 | 2022/04/07 | Ivan Kolev | Added document_expiry_date to KYC verification status response. |
35.2 | 2022/04/07 | Ivan Kolev | Changed KYC requests domains and endpoints. |
35.3 | 2022/04/11 | Boris Kolev | Added service_provider_name as a request param to the Money Transfer Payouts. |
35.4 | 2022/04/21 | Boris Kolev | Added support for cryptocurrency Visa OCT transactions (Credit and Payout). |
35.5 | 2022/04/27 | Boris Kolev | Updated the MYR currency bank codes for online_banking . |
35.6 | 2022/04/28 | Pepa Simeonova | Added customer_identification to Visa OCT transactions (Credit and Payout) for Brazil and Qatar. |
35.7 | 2022/05/10 | Preslav Nedev | Added bank_code and payment_type to the Online Banking transaction response. |
35.8 | 2022/05/16 | Blagoy Vangelov | Added transaction_id attribute to Processed Transaction API response for card not present payment requests only. |
35.9 | 2022/05/18 | Boris Kolev | Updated the MYR currency bank codes for online_banking . |
36.0 | 2022/05/31 | Muhammad Moawaz Ayub | Removed MCC restriction for crypto with Visa. |
36.1 | 2022/05/31 | Ivan Kolev | Added optional sub-parameters: allow_offline and allow_online to both document and face parameters to enrich the flexibility of the kyc verification request. |
36.2 | 2022/07/07 | Simeon Angelov | Added an asynchronous authentication workflow handling for GooglePay transactions thru the 3DS authentication protocol for PAN-ONLY transactions inside the European Economic Area (EEA). |
36.3 | 2022/07/07 | Boris Kolev | Added BCT bank code to EUR currency for online_banking . |
36.4 | 2022/06/28 | Ivan Kolev | Changed the description of signature in KYC service notification to indicate that it is now being generated by using the API login instead of the API password. |
36.5 | 2022/07/13 | Evgeny Zhdanov | Added bank_payout_verification_digit attribute to Bank Payout and barcode, digitable_line, ticket_expiry_date attribute to Boleto. |
36.6 | 2022/08/02 | Preslav Nedev | Added business attributes to Trustly Sale transactions. |
36.7 | 2022/08/24 | Atanas Zlatarev | Fixed discrepancies in description for iDeal, Sofort and asynchronous transaction notifications. |
36.8 | 2022/08/30 | Boris Kolev | Updated the SGD currency bank codes for online_banking . |
36.9 | 2022/10/06 | Evgeny Zhdanov | Updated bank_account_type attribute values related to Itau for Bank Pay-out. |
37.0 | 2022/10/05 | Boris Kolev | Added recurring_category as an optional request parameter in InitialRecurringSale and InitialRecurringSale3d transactions for both API and WPF requests. |
37.1 | 2022/10/07 | Boris Kolev | Added sca_exemption_result to API and WPF transaction responses, reconciliation responses, and notifications. |
37.2 | 2022/10/17 | Teodor Nikolov | Removed API for TrustPay . |
37.3 | 2022/11/04 | Maya Nedyalkova | Updated the list of supported banks for BRL currency. |
37.4 | 2022/11/07 | Boris Kolev | Decommissioned 3DSv1 authentication protocol. |
37.5 | 2022/11/16 | Preslav Nedev | Added WPF States section and linked status field of WPF transactions to it. |
37.6 | 2022/11/17 | George Naydenov | Added new recurring types for sale and authorize and their 3DS variants. Added deprecation notice to the initial and subsequent recurring transaction types. |
37.7 | 2022/12/20 | Pepa Simeonova | Added managed recurring params for recurring transactions with Indian cards. |
37.8 | 2022/12/21 | Preslav Nedev | Added additional Visa specific authentication status reason codes. |
37.9 | 2022/12/22 | Simeon Angelov | Added Dynamic Descriptor params to GooglePay and ApplePay transactions. |
38.0 | 2023/01/03 | Teodor Nikolov | Added currency as an additional parameter to Processing and WPF notifications. |
38.1 | 2023/01/20 | Martin Lazarov | Added capture_method to the Processed Transactions API response. |
38.2 | 2023/01/25 | Muhammad Moawaz Ayub | Added ACS transaction ID and 3DS challenge indicator as optional params for the 3DS transactions in synchronous workflow. |
38.3 | 2023/02/28 | Mladen Rusev | Added company_name and mandate_reference as optional params for SddSale transactions. |
38.4 | 2023/03/02 | Atanas Naydenov | Added additional values to Recurring Advice table. |
38.5 | 2023/03/22 | Imran Zahoor | Updated Bank-payouts list of banks for BRL currency. |
38.6 | 2023/03/29 | Georgi Naydenov | Added subsequent recurring type for Authorize transactions. |
38.7 | 2023/04/04 | Imran Zahoor | Added a verification reference id endpoint for KYC to allow registration of reference ids in Genesis. |
38.8 | 2023/04/07 | Imran Zahoor | Added a new optional parameter: check_duplicate_attribute to the KYC verification request to allow enabling of duplicate detection service. |
38.9 | 2023/04/12 | Muhammad Moawaz Ayub | Updated descriptions for VISA AVS codes. |
39.0 | 2023/04/20 | Umair Aziz | Extended the list with Recurring advice codes. |
39.1 | 2023/04/24 | Pepa Simeonova | Add user_category for online_banking and upi . |
39.2 | 2023/04/25 | George Naydenov | Added Recurring V2. |
39.3 | 2023/04/26 | Muhammad Moawaz Ayub | Extended the AVS status codes and response processors description. |
39.4 | 2023/04/28 | Umair Aziz | Changed the default authorization timeframe and removed MCC restrictions for Visa pre-authorizations and incrementals. |
39.5 | 2023/05/03 | Blagoy Vangelov | Added BL bank code to PLN currency for online_banking |
39.6 | 2023/05/10 | Ralitsa Galabova | Added Account Verification V2. |
39.7 | 2023/05/15 | Blagoy Vangelov | Renamed BL bank code to BLK |
39.8 | 2023/05/16 | Preslav Nedev | Updated documentation on Verification Status response for Shufti Pro . |
39.9 | 2023/05/26 | Imran Zahoor | Added a new parameter bank_code for Bank Pay-out transactions with BRL currency. |
40.0 | 2023/05/26 | Dimitar Natskin | Updated the Shopping Carts section and deprecated Shopware 5.x plugin. |
40.1 | 2023/06/13 | Imran Zahoor | Renamed the parameter check_duplicate_attribute of the KYC verification request to check_duplicate_request . |
40.2 | 2023/06/14 | Ilya Rogozin | Added possibility for customizing the signature algorithm in the Processing Notifications. |
40.3 | 2023/06/19 | Umair Aziz | Added missing voucher number to example requests for Neosurf transaction. |
40.4 | 2023/06/21 | Evgeny Zhdanov | Added payment_type as conditionally required param to BankPayout transactions. |
40.5 | 2023/06/22 | Pepa Simeonova | Added additional parameters to the dynamic descriptors. |
40.6 | 2023/06/27 | Boris Kolev | Changed the merchant_zip_code to be a required parameter for VISA OCT transactions with Australian or Canadian card bins. |
40.7 | 2023/07/04 | Teodor Nikolov | Marked first and last name of the billing address as optional params for PIX transactions. |
40.8 | 2023/07/04 | Svilen Siderov | Updated description for the additional dynamic descriptors parameters. |
40.9 | 2023/07/04 | Muhammad Moawaz Ayub | Added return_success_url and return_failure_url as conditionally required parameters for Neosurf transactions. |
41.0 | 2023/07/11 | Boris Kolev | Updated the THB and VDN currency bank codes for online_banking . |
41.1 | 2023/07/05 | Mladen Rusev | Changed bank codes for banks handling IDR currency. |
41.2 | 2023/07/20 | Imran Zahoor | Updated description of bank_code and bank_name for Bank Pay-out transactions with BRL currency. |
41.3 | 2023/07/20 | Mladen Rusev | Marked the consumer State in Tokenization as optional for US, CA and CN countries. |
41.4 | 2023/07/21 | Muhammad Moawaz Ayub | Added auth_network_outage to the list of available exemption types. |
41.5 | 2023/08/02 | Teodor Nikolov | Marked country of the billing address as optional param for PIX transactions. |
41.6 | 2023/08/17 | Muhammad Moawaz Ayub | Added Funding Transaction support. |
41.7 | 2023/08/17 | Boris Kolev | Removed unused THB currency bank code for online_banking . |
41.8 | 2023/09/07 | Svilen Siderov | Added new parameters for bank_payout transaction. |
41.9 | 2023/09/14 | Simeon Angelov | Added MXN currency support and additional account details response params for Online Banking transactions. |
42.0 | 2023/09/21 | Ilya Rogozin | Extended the asynchronous 3DSv2 behaviour for handling invalid submission of 3DS-Method-Continue API calls. |
42.1 | 2023/09/28 | Aleksandar Krastev | Added return_success_url and return_failure_url as conditionally required parameters for SddSale and SddInitRecurringSale transactions. |
42.2 | 2023/09/29 | Boris Kolev | Added more testing cards numbers for the 3DSv2 testing section |
42.3 | 2023/10/06 | Svilen Siderov | Added support on Processing and WPF APIs for Account Name Inquiries |
42.4 | 2023/10/20 | Dimitar Natskin | Added Genesis Ruby SDK. |
42.5 | 2023/10/26 | Aleksandar Krastev | Added return_pending_url as conditionally required parameter for SddSale and SddInitRecurringSale transactions. |
42.6 | 2023/10/26 | Umair Aziz | Extended the example responses for Single Reconciliation and async 3DSv2 flows. |
42.7 | 2023/11/02 | Svilen Siderov | Updated bank_account_type attribute values for Bank Payout. |
42.8 | 2023/11/15 | Preslav Nedev | Added customer_id as required parameter for Paysafecard transactions. |
42.9 | 2023/11/20 | Pepa Simeonova | Added new recurring advice codes. |
43.0 | 2023/11/29 | Blagoy Vangelov | Added new status 'representment reversed' in notifications for Processing and WPF APIs, and a new RepresentmentReversal transaction type. |
43.1 | 2023/12/04 | Yordan Pulov, Svilen Siderov, Martin Lazarov | Introduced new Smart Routing API layer allowing for simpler and more efficient gateway integration. |
43.2 | 2023/12/08 | Hristo Tanchev | Added support for non-referenced subsequent recurring transactions. |
43.3 | 2023/12/11 | Aleksandar Krastev | Added Rapid Dispute Resolution Reversal transaction type to API. |
43.4 | 2023/12/13 | Artur Veletskiy | Added new Billing Transactions API |
43.5 | 2023/12/14 | Blagoy Vangelov | Added an optional merchant_website parameter to the eZeeWallet transaction type for both Processing API and WPF API |
43.6 | 2023/12/14 | Blagoy Vangelov | Rename "Blik One Click" payment method to "BLIK" for Online banking. |
43.7 | 2024/02/07 | Kaloyan Mirchev | Added CPF/CNPJ checks for Genesis KYC Service. |
43.8 | 2024/02/15 | Muhammad Moawaz Ayub | Corrected response params for the Rapid Dispute Resolution. |
43.9 | 2024/02/20 | Artur Veletskiy | Updated date only format for Billing Transactions API response. |
44.0 | 2024/02/22 | Dimitar Natskin | Added Spree Commerce Shopping Cart plugin. |
44.1 | 2024/02/22 | Svilen Siderov | Added Neighborhood as address parameter for processing API and WPF. |
44.2 | 2024/02/23 | Aleksandar Krastev | Added TRL bank code to EUR and GBP currencies for online_banking . |
44.3 | 2024/02/23 | Mladen Rusev | Added return_pending_url parameter to PIX documentation. |
44.4 | 2024/02/27 | Blagoy Vangelov | merchant_website is now required for the eZeeWallet transaction type for both Processing API and WPF API. |
44.5 | 2024/02/29 | Simeon Angelov | Changed the purpose_of_payment to required API param for Visa OCT transactions with recipients in Argentina, Bangladesh, Egypt, India, Chile and Colombia. |
44.6 | 2024/03/01 | Atanas Naydenov | Added Scheme response codes and removed Issuer response codes. |
44.7 | 2024/03/06 | Kaloyan Mirchev | Added descriptions for CPF/CNPJ checks API response. |
44.8 | 2024/03/07 | Muhammad Moawaz Ayub | Added additional MCCs to the list for own-account Funding Transactions. |
44.9 | 2024/03/20 | Vladislav Vodenicharski | Extended lifetime validity for Web Payment Form payments to 3 months |
45.0 | 2024/03/11 | Blagoy Vangelov | Added birth_date , incorporation_date , gender , martial_status , sender_occupation , mothers_name , nationality , country_of_origin , birth_city , birth_state , company_type , company_activity optional parameters to PIX transaction type. |
45.1 | 2024/04/08 | Martin Lazarov | Added new recurring advice code for Sanctions Scoring Service. |
45.2 | 2024/04/09 | Boris Kolev | Added a new optional request parameter - protocol_sub_version to synchronous 3DS transactions. Also, added the 3DS protocol sub-version in reconciliation responses and notifications for Processing and WPF APIs. |
45.3 | 2024/06/03 | Ilya Rogozin | Added a new scheme_transaction_link_id attribute for the Processing and WPF API responses including reconciliation responses and notifications. |
45.4 | 2024/08/13 | Simeon Angelov | Added a list with supported countries for GooglePay transactions. |
45.5 | 2024/08/16 | Ilya Rogozin | Added a new payment_account_reference attribute for the Processing and WPF API responses, reconciliation responses and notifications. |
45.6 | 2024/08/28 | Ilya Rogozin | Extended the list of payment type values for the Online Banking transaction. Added description for Cash transactions. |
45.7 | 2024/09/04 | Lachezar Tsvetkov | Added optional background_checks .filters attribute for KYC Create Verification. |
45.8 | 2024/09/05 | Simeon Angelov | Added 0-amount support for GooglePay and ApplePay transactions. |
45.9 | 2024/09/09 | Atanas Naydenov | Updated scheme response codes Visa - 1A and Mastercard - 65. |
46.0 | 2024/09/12 | Ilya Rogozin | Added extended initial recurring type support to GooglePay and ApplePay transactions. |
46.1 | 2024/10/02 | Lachezar Tsvetkov | Changed the document_supported_types and redirect_url parameters in KYC Create Verification optional to allow for synchronous checks. |
46.2 | 2024/10/08 | Muhammad Moawaz Ayub | Added VISA Funding Transaction support. |
46.3 | 2024/10/09 | Muhammad Moawaz Ayub | Added region availability for Account Name Inquiry Service Functionality. |
46.4 | 2024/10/15 | Muhammad Moawaz Ayub | Extended the list with recurring advice codes. |
46.5 | 2024/10/16 | Svilen Siderov | Added additional dynamic descriptor parameters related to acceptor geographic coordinates. |
46.6 | 2024/10/16 | Atanas Naydenov | Remove API for Giropay transaction type, as it is shut down after June 30 2024. |
46.7 | 2024/10/16 | Boris Kolev | Added a new scheme_max_settlement_date attribute for the Processing and WPF API responses including reconciliation responses and notifications. Also, the Scheme Max Settlement Date is taken into account and might be prioritized during Capture transactions. |
46.8 | 2024/10/18 | Muhammad Moawaz Ayub | Added support for liquid assets in OCT and AFT transactions. |
46.9 | 2024/10/18 | Simeon Angelov | Updated supported countries for MyBank transaction type. |
47.0 | 2024/10/21 | Lachezar Tsvetkov | Added a new optional parameter background_checks .match_score in KYC Create Verification. |
47.1 | 2024/10/22 | Svilen Siderov | Extended Money transfer Payout with the credential_on_file_transaction_identifier parameter. |
47.2 | 2024/10/22 | Ilya Rogozin | Added a new attribute scheme_authentication_data_quality to the Processing and WPF API responses, as well as reconciliation responses and notifications. |
47.3 | 2024/10/23 | Mladen Rusev | Described response CSV file format part of the Importation of external tokens and card details workflow. |
47.4 | 2024/10/29 | Mladen Rusev | Added support for AUD currency and PID bank code for Online Banking transaction. |
47.5 | 2024/11/15 | Yordan Pulov | Added support of installments. |
47.6 | 2024/11/15 | Ilya Rogozin | Added new attributes scheme_pan_indicator and scheme_pan_tail to the Processing and WPF API responses, as well as reconciliation responses and notifications. |
47.7 | 2024/11/21 | Milen Matev | Extended FX service API response examples. |
47.8 | 2024/12/05 | Kaloyan Mirchev | Extend Bank Pay-Out request optional parameters. |
47.9 | 2024/12/09 | Muhammad Moawaz Ayub | Added Account Funding Transaction support on the Web Payment Form. |
48.0 | 2024/12/20 | Zdravko Chorlev | Added initial recurring support to the SCA Checker service API. |
48.1 | 2024/12/20 | Artur Veletskiy | Extended Billing Transactions API with additional request and response parameters. |
48.2 | 2025/01/09 | Ilya Rogozin | Added support for the NZD currency and the POLI bank code for Online Banking transactions. |
48.3 | 2025/01/14 | Muhammad Moawaz Ayub | Added AFT support for Apple Pay and Google Pay transactions. |
48.4 | 2025/01/14 | Svilen Siderov | Extended AVS Status codes with single character codes description. |
Introduction
You can get PHP SDK from https://github.com/GenesisGateway/genesis_php
Installation:
Get the SDK from GitHub and load it with Composer autoloader or include it in your own autoloader (The SDK uses PSR-4 spec).
git clone http://github.com/GenesisGateway/genesis_php genesis_php
cd genesis_php
composer install
You can get Node.js SDK from https://github.com/GenesisGateway/genesis.js
Installation:
Get the SDK from GitHub
git clone http://github.com/GenesisGateway/genesis.js genesis.js
cd genesis.js
npm install
Or install it using npm
npm install genesis.js
You can get Java SDK from http://github.com/GenesisGateway/genesis_java
Installation:
Get the SDK from GitHub and install Maven plugin
git clone http://github.com/GenesisGateway/genesis_java genesis_java
cd genesis_java
mvn clean install
Finally add this to your pom.xml file:com.emerchantpay.gateway genesis-java 1.16.4
You can get cURL from https://curl.haxx.se
This document describes the usage of the payment gateway XML/JSON/GraphQL API.
The API allows you to trigger all supported transactions of the gateway and to retrieve information about transactions existing in the gateway. You can also retrieve chargeback information.
The payment API is synchronous (except for 3-D secure payments), it accepts HTTP POST or XML data and returns XML/JSON data. Connections are always secured via SSL both in test and live mode. Be sure to set Content-type: text/xml in your headers.
Audience
This document is intended for technical staff integrating the XML/JSON API in the merchant’s organization.
It is required that readers have working knowledge of programming languages, XML and JSON formats and UTF8 encodings.
Authentication
<?php
use \Genesis\Config as GenesisConfig;
// Load the pre-configured ini file...
GenesisConfig::loadSettings('/path/to/config.ini');
// ...OR, optionally, you can set the credentials manually
GenesisConfig::setEndpoint('<set_your_endpoint>');
GenesisConfig::setEnvironment('<set_your_environment>');
GenesisConfig::setUsername('<enter_your_username>');
GenesisConfig::setPassword('<enter_your_password>');
GenesisConfig::setToken('<enter_your_token>');
// You can find example configuration file in root directory of the module
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;;
import com.emerchantpay.gateway.util.Configuration;
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
You can override the path to the directory holding your configuration files (by default its config in the root directory of the module) via environmental variable NODE_CONFIG_DIR.
The first file to parse configuration from, is <your-config-dir>/default.json and based on the environment variable (NODE_ENV), you can specify your custom file; for example <your-config-dir>/<NODE_ENV_NAME>.json.
Its good practice to prevent web/direct access to your config directory and protect the files inside
Send username and password directly in url
curl https://username:password@staging.gate.emerchantpay.net:443/process/TERMINAL-TOKEN
Or use -u flag
curl -u username:password https://staging.gate.emerchantpay.net:443/process/TERMINAL-TOKEN
To interact with the payment API, you need to provide login credentials using standard HTTP Basic Authentication. (credentials can be found in your Admin interface.)
To decrease network traffic and response times, we recommend that you enforce sending authentication credentials directly in the first request.
Some implementations like e.g. the Java HTTPClient automatically try to guess the best authentication scheme. This can be overridden by setting the authorization to preemptive:
Environments
There are two environments which can be used by merchants - production and staging, also known as test environment.
The staging environment is used only for TESTING purposes. When you are processing a payment using your configuration for the test environment the payment WILL NOT bring a real financial impact. This environment is used only to simulate and test different payment scenarios.
In the production environment you cannot use any simulated test data. When you are processing payments using your configuration for the production environment the payment WILL bring a real financial impact.
URLs
Server API
API methods are called with the following structure:
https://gate.emerchantpay.net/process/TERMINAL_TOKEN/
Single transaction reconciles can be done via this URL:
https://gate.emerchantpay.net/reconcile/TERMINAL_TOKEN/
Date range reconciles can be done via this URL:
https://gate.emerchantpay.net/reconcile/by_date/TERMINAL_TOKEN/
This URL allows retrieval of a list of supported banks based on the customers country and/or currency:
https://gate.emerchantpay.net/retrieve_inpay_banks/TERMINAL_TOKEN/
For the test system use the following URLs:
https://staging.gate.emerchantpay.net/process/TERMINAL_TOKEN/
https://staging.gate.emerchantpay.net/reconcile/TERMINAL_TOKEN/
https://staging.gate.emerchantpay.net/reconcile/by_date/TERMINAL_TOKEN/
https://staging.gate.emerchantpay.net/retrieve_inpay_banks/TERMINAL_TOKEN/
WPF
The URL for the WPF API create method is:
https://wpf.emerchantpay.net/wpf
For the test system the URL is:
https://staging.wpf.emerchantpay.net/wpf
The URL for the WPF API reconcile method is:
https://wpf.emerchantpay.net/wpf/reconcile
For the test system the URL is:
https://staging.wpf.emerchantpay.net/wpf/reconcile
Your admin panel can be found here:
https://merchant.emerchantpay.net/
Consumer API
Create consumer:
https://gate.emerchantpay.net/v1/create_consumer/
Retrieve consumer:
https://gate.emerchantpay.net/v1/retrieve_consumer/
Update consumer:
https://gate.emerchantpay.net/v1/update_consumer/
Disable consumer:
https://gate.emerchantpay.net/v1/disable_consumer/
Enable consumer:
https://gate.emerchantpay.net/v1/enable_consumer/
Get consumer cards:
https://gate.emerchantpay.net/v1/get_consumer_cards/
For the test system use the following URLs:
https://staging.gate.emerchantpay.net/v1/create_consumer/
https://staging.gate.emerchantpay.net/v1/update_consumer/
https://staging.gate.emerchantpay.net/v1/disable_consumer/
https://staging.gate.emerchantpay.net/v1/enable_consumer/
https://staging.gate.emerchantpay.net/v1/get_consumer_cards/
Tokenization API
Tokenize cardholder data:
https://gate.emerchantpay.net/v1/tokenize/
Detokenize cardholder data:
https://gate.emerchantpay.net/v1/detokenize/
Update the cardholder data (PAN cannot be updated):
https://gate.emerchantpay.net/v1/update_token/
Validate if given token is valid for the merchant:
https://gate.emerchantpay.net/v1/validate_token/
Delete a token:
https://gate.emerchantpay.net/v1/delete_token/
Exchange masked cardholder data for token:
https://gate.emerchantpay.net/v1/get_card/
For the test system use the following URLs:
https://staging.gate.emerchantpay.net/v1/tokenize/
https://staging.gate.emerchantpay.net/v1/detokenize/
https://staging.gate.emerchantpay.net/v1/update_token/
https://staging.gate.emerchantpay.net/v1/validate_token/
https://staging.gate.emerchantpay.net/v1/delete_token/
https://staging.gate.emerchantpay.net/v1/get_card/
Genesis KYC Services JSON API
Testing environment
Create Consumer:
POST https://staging.kyc.emerchantpay.net/api/v1/create_consumer
Update Consumer:
POST https://staging.kyc.emerchantpay.net/api/v1/update_consumer
Create Transaction:
POST https://staging.kyc.emerchantpay.net/api/v1/create_transaction
Update Transaction:
POST https://staging.kyc.emerchantpay.net/api/v1/update_transaction
Upload Document:
POST https://staging.kyc.emerchantpay.net/api/v1/upload_document
Download Document:
POST https://staging.kyc.emerchantpay.net/api/v1/download_document
Verify Phone:
POST https://staging.kyc.emerchantpay.net/api/v1/verify_phone
Verify Identity:
POST https://staging.kyc.emerchantpay.net/api/v1/verify_identity
Verify Bank Account:
POST https://staging.kyc.emerchantpay.net/api/v1/verify_bank_account
Create Authentication:
POST https://staging.kyc.emerchantpay.net/api/v1/create_authentication
Update Authentication:
POST https://staging.kyc.emerchantpay.net/api/v1/update_authentication
Create Verification:
POST https://staging.kyc.emerchantpay.net/api/v1/verifications
Check Verification Status:
POST https://staging.kyc.emerchantpay.net/api/v1/verifications/status
Register Reference_ID:
POST https://staging.kyc.emerchantpay.net/api/v1/verifications/register
Production environment
Genesis KYC Services JSON API URLs for production environment:
Create Consumer:
POST https://kyc.emerchantpay.net/api/v1/create_consumer
Update Consumer:
POST https://kyc.emerchantpay.net/api/v1/update_consumer
Create Transaction:
POST https://kyc.emerchantpay.net/api/v1/create_transaction
Update Transaction:
POST https://kyc.emerchantpay.net/api/v1/update_transaction
Upload Document:
POST https://kyc.emerchantpay.net/api/v1/upload_document
Download Document:
POST https://kyc.emerchantpay.net/api/v1/download_document
Verify Phone:
POST https://kyc.emerchantpay.net/api/v1/verify_phone
Verify Identity:
POST https://kyc.emerchantpay.net/api/v1/verify_identity
Verify Bank Account:
POST https://kyc.emerchantpay.net/api/v1/verify_bank_account
Create Authentication:
POST https://kyc.emerchantpay.net/api/v1/create_authentication
Update Authentication:
POST https://kyc.emerchantpay.net/api/v1/update_authentication
Create Verification:
POST https://kyc.emerchantpay.net/api/v1/verifications
Check Verification Status:
POST https://kyc.emerchantpay.net/api/v1/verifications/status
Transaction API
Update expiration date:
PUT https://gate.emerchantpay.net/v1/transaction/expiry_date/:transaction_unique_id
For the test system use the following URLs:
PUT https://staging.gate.emerchantpay.net/v1/transaction/expiry_date/:transaction_unique_id
Smart Routing API
For the test system use the following URLs:
POST https://staging.api.emerchantpay.net/transactions
With authentication params in the URL:
POST https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.api.emerchantpay.net/transactions
For the production system use the following URLs:
POST https://prod.api.emerchantpay.net/transactions
With authentication params in the URL:
POST https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@prod.api.emerchantpay.net/transactions
Billing Transactions API
Testing environment
POST https://staging.api.emerchantpay.net/billing_transactions/v1/graphql
Production environment
POST https://prod.api.emerchantpay.net/billing_transactions/v1/graphql
Transactions
Invoking a Transaction
A transaction is invoked via HTTPS POST, parameters are passed as XML with UTF-8 encoding.
Card
Recurring V2
A recurring transaction describes a payment where the cardholder’s account is periodically charged for a repeated delivery and use of a product or service (subscription, membership fee, etc.) over time. A recurring payment consists of an initial transaction and one or several repeated subsequent transactions. The ”initial” transaction contains all relevant card and cardholder data, while the subsequent repeated transaction references an identifier which is returned with the response to the initial request.
Initial Recurring
Sale(3D) or Authorize(3D) with recurring_type initial marks an initialization of recurring series. Subsequent recurring transactions use initial Sale(3D) or Authorize(3D) as a reference for the recurring series.
Note that if an initial recurring is fully refunded or referenced by a fraud transaction(ChargebackTransaction / ChargebackReversalTransaction / RepresentmentTransaction / SecondChargebackTransaction), the recurring series is stopped and no more Subsequent recurring transactions can be performed for that recurring series.
If an initial recurring is partially refunded, the recurring series can continue with more Subsequent recurring transactions.
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Sale');
$request = $genesis->request();
$request
->setRecurringType('initial')
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('4200000000000000')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
->setRecurringCategory('subscription')
// Account Owner
->setAccountFirstName('Travis')
->setAccountMiddleName('Joe')
->setAccountLastName('Pastrana');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.SaleRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
SaleRequest request = new SaleRequest();
request.setRecurringType("initial");
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4200000000000000");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
request.setRecurringCategory("subscription");
// Account Owner
request.setAccountFirstname("Travis");
request.setAccountMiddlename("Joe");
request.setAccountLastname("Pastrana");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.sale(
{
"recurring_type": "initial",
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "4200000000000000",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"business_attributes": {
"event_start_date": "17-02-2025",
"event_end_date": "26-02-2025",
"event_organizer_id": "20192375",
"event_id": "1912"
},
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"recurring_category": "subscription",
"account_owner": {
"first_name": "Travis",
"middle_name": "Joe",
"last_name": "Pastrana"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>sale</transaction_type>
<recurring_type>initial</recurring_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4200000000000000</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<business_attributes>
<event_start_date>17-02-2025</event_start_date>
<event_end_date>26-02-2025</event_end_date>
<event_organizer_id>20192375</event_organizer_id>
<event_id>1912</event_id>
</business_attributes>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<recurring_category>subscription</recurring_category>
<account_owner>
<first_name>Travis</first_name>
<middle_name>Joe</middle_name>
<last_name>Pastrana</last_name>
</account_owner>
</payment_transaction>'
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Authorize');
$request = $genesis->request();
$request
->setRecurringType('initial')
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('4200000000000000')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
->setRecurringCategory('subscription');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.AuthorizeRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
AuthorizeRequest request = new AuthorizeRequest();
request.setRecurringType("initial");
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4200000000000000");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
request.setRecurringCategory("subscription");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.authorize(
{
"recurring_type": "initial",
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "4200000000000000",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"business_attributes": {
"event_start_date": "17-02-2025",
"event_end_date": "26-02-2025",
"event_organizer_id": "20192375",
"event_id": "1912"
},
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"recurring_category": "subscription"
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>authorize</transaction_type>
<recurring_type>initial</recurring_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4200000000000000</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<business_attributes>
<event_start_date>17-02-2025</event_start_date>
<event_end_date>26-02-2025</event_end_date>
<event_organizer_id>20192375</event_organizer_id>
<event_id>1912</event_id>
</business_attributes>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<recurring_category>subscription</recurring_category>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: sale, sale3d, authorize or authorize3d |
recurring_type | required | string(255) | Specifies recurring type of the transaction, 'initial' |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
moto | optional | "true" | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech-support@emerchantpay.com for more details |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
amount | required | integer >= 0 | Transaction amount in minor currency unit, see Currency and Amount Handling for details. In certain cases, it is possible to submit a transaction with a zero-value amount in order not to charge the consumer with the initial recurring, but with the followed RecurringSale transactions only. For more information regarding the use cases and scenario, Contact tech-support@emerchantpay.com for more details. |
currency | required | string(3) | Currency code in ISO 4217 |
card_holder | required | string(255) | Full name of customer as printed on credit card (first name and last name at least) |
card_number | required | 13 to 16 digits | Complete cc number of customer |
cvv | required* | 3 to 4 digits | cvv of cc, requirement is based on terminal configuration |
expiration_month | required | MM | Expiration month as printed on credit card |
expiration_year | required | YYYY | Expiration year as printed on credit card |
token | optional | string(36) | See Tokenization for more details. If present, the cardholder parameters can be omitted. Cannot be set together with remember_card |
remember_card | optional | "true" | See Tokenize. Tokenizes cardholder parameters. Cannot be set together with token |
consumer_id | optional | string(10) | See Consumers and Tokenization. Combine with remember_card to tokenize or with token to use token |
scheme_tokenized | required* | "true" | Required when the card_number is DPAN instead of Funding Primary Account Number, see Tokenized e-commerce for details |
recurring_category | optional | string | Specifies whether the recurring transaction is a subscription(fixed amount, fixed intervals)or if it is a standing order(varying amount, fixed intervals). The allowed values aresubscription and standing_order . The default value is subscription |
credential_on_file | required* | See Credential On File (COF) for more details | |
initial_customer_initiated | required* | string(18) | Initial transaction initiated by customer. Required for external tokenization, and optional for gateway-based tokenization |
subsequent_customer_initiated | required* | string(18) | Subsequent transaction initiated by customer. Required for external tokenization, and optional for gateway-based tokenization |
merchant_unscheduled | optional | string(20) | Transaction is initiated by the merchant |
credential_on_file_transaction_identifier | optional | string(15..32) | See Credential On File (COF) for more details |
credential_on_file_settlement_date | optional | string(4) | See Credential On File (COF) for more details |
customer_email | required* | e-mail address | Must contain valid e-mail of customer |
customer_phone | required* | string(32) | Must contain valid phone number of customer |
birth_date | required* | dd-mm-yyyy | Required when MCC is a Financial Services one (e.g. MCC 6012) and either card brand is Visa or Mastercard/Maestro with UK-based merchant, UK-based bin (domestic), and DEBIT card type |
document_id | required* | string(255) | Document ID value. |
fx_rate_id | optional | integer | See Get rates for FX Service. Offers the option to use a specific FX rate to convert the transaction processing amount. Used FX rate should have the same source currency as the processing currency. Contact tech-support@emerchantpay.com for more details |
business_attributes | required* | Check business attributes section. | |
event_start_date | required* | dd-mm-yyyy | The date when event starts in format dd-mm-yyyy |
event_end_date | required* | dd-mm-yyyy | The date when event ends in format dd-mm-yyyy |
event_organizer_id | required* | string | |
event_id | required* | string | |
date_of_order | required* | dd-mm-yyyy | The date when order was placed in format dd-mm-yyyy |
delivery_date | required* | dd-mm-yyyy | Date of the expected delivery in format dd-mm-yyyy |
name_of_the_supplier | required* | string | |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required* | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
neighborhood | optional | string(255) | Neighborhood |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
account_owner | optional | Account owner parameters related to account owner inquiry requests | |
first_name | optional | string(35) | Account owner first name |
middle_name | optional | string(35) | Account owner middle name |
last_name | optional | string(35) | Account owner last name |
dynamic_descriptor_params | optional | ||
merchant_name | optional | string(25) | Allows to dynamically override the charge descriptor |
merchant_city | optional | string(13) | Allows to dynamically override the merchant phone number |
sub_merchant_id | optional | string(15) | Allows to dynamically override the sub-merchant ID. |
merchant_country | optional | string(3) | Allows to dynamically override the merchant country. |
merchant_state | optional | string(3) | Allows to dynamically override the merchant subdivision code. |
merchant_zip_code | optional | string(10) | Allows to dynamically override the merchant zip/postal code. Required for VISA OCT transactions with Australian and Canadian card bins. |
merchant_address | optional | string(48) | Allows to dynamically override the merchant address. |
merchant_url | optional | string(60) | Allows to dynamically override the merchant URL |
merchant_phone | optional | string(16) | Allows to dynamically override the merchant phone number. |
merchant_service_city | optional | string(13) | Allows to dynamically override the merchant service city. |
merchant_service_country | optional | string(3) | Allows to dynamically override the merchant service country. |
merchant_service_state | optional | string(3) | Allows to dynamically override the merchant service subdivision code. |
merchant_service_zip_code | optional | string(10) | Allows to dynamically override the merchant service zip/postal code. |
merchant_service_phone | optional | string(16) | Allows to dynamically override the merchant service phone number. |
merchant_geo_coordinates | optional | string(20) | Allows to dynamically override the merchant geographic coordinates. |
merchant_service_geo_coordinates | optional | string(20) | Allows to dynamically override the merchant service geographic coordinates. |
required* = conditionally required
Successful Response
stdClass Object
(
[transaction_type] => sale
[recurring_type] => initial
[status] => approved
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[consumer_id] => 123456
[token] => ee946db8-d7db-4bb7-b608-b65b153e127d
[avs_response_code] => 5I
[avs_response_text] => Response provided by issuer processor; Address information not verified
[cvv_result_code] => M
[authorization_code] => 345678
[retrieval_reference_number] => 016813015184
[response_code] => 00
[technical_message] => Transaction successful!
[message] => Transaction successful!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:44.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
[scheme_transaction_identifier] => 019091214161031
[scheme_settlement_date] => 0117
[scheme_response_code] => 00
[reason_for_not_honoring_exemption] => 8A01
[sca_exemption_result] => 13
[account_owner] => {"first_name"=>"Travis", "middle_name"=>"Joe", "last_name"=>"Pastrana"}
)
<payment_response content=[
<transaction_type content=[sale]>
<recurring_type content=[initial]>
<status content=[approved]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<consumer_id content=[123456]>
<token content=[ee946db8-d7db-4bb7-b608-b65b153e127d]>
<avs_response_code content=[5I]>
<avs_response_text content=[Response provided by issuer processor; Address information not verified]>
<cvv_result_code content=[M]>
<authorization_code content=[345678]>
<retrieval_reference_number content=[016813015184]>
<response_code content=[00]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<timestamp content=[2025-01-16T10:23:44Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[true]>
<scheme_transaction_identifier content=[019091214161031]>
<scheme_settlement_date content=[0117]>
<scheme_response_code content=[00]>
<reason_for_not_honoring_exemption content=[8A01]>
<sca_exemption_result content=[13]>
<account_owner content=[{"first_name"=>"Travis", "middle_name"=>"Joe", "last_name"=>"Pastrana"}]>
]>
{
transaction_type: "sale",
recurring_type: "initial",
status: "approved",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
consumer_id: "123456",
token: "ee946db8-d7db-4bb7-b608-b65b153e127d",
avs_response_code: "5I",
avs_response_text: "Response provided by issuer processor; Address information not verified",
cvv_result_code: "M",
authorization_code: "345678",
retrieval_reference_number: "016813015184",
response_code: "00",
technical_message: "Transaction successful!",
message: "Transaction successful!",
timestamp: "2025-01-16T10:23:44Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "true",
scheme_transaction_identifier: "019091214161031",
scheme_settlement_date: "0117",
scheme_response_code: "00",
reason_for_not_honoring_exemption: "8A01",
sca_exemption_result: "13",
account_owner: "{"first_name"=>"Travis", "middle_name"=>"Joe", "last_name"=>"Pastrana"}",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>sale</transaction_type>
<recurring_type>initial</recurring_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<consumer_id>123456</consumer_id>
<token>ee946db8-d7db-4bb7-b608-b65b153e127d</token>
<avs_response_code>5I</avs_response_code>
<avs_response_text>Response provided by issuer processor; Address information not verified</avs_response_text>
<cvv_result_code>M</cvv_result_code>
<authorization_code>345678</authorization_code>
<retrieval_reference_number>016813015184</retrieval_reference_number>
<response_code>00</response_code>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:44Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
<scheme_transaction_identifier>019091214161031</scheme_transaction_identifier>
<scheme_settlement_date>0117</scheme_settlement_date>
<scheme_response_code>00</scheme_response_code>
<reason_for_not_honoring_exemption>8A01</reason_for_not_honoring_exemption>
<sca_exemption_result>13</sca_exemption_result>
<account_owner>
<first_name>Travis</first_name>
<middle_name>Joe</middle_name>
<last_name>Pastrana</last_name>
</account_owner>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
recurring_type | string(255) | The recurring type(initial, subsequent or managed) |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
consumer_id | string(10) | Consumer unique reference. See Consumers |
token | string(36) | Plain-text token value. See Tokenization |
moto | 'true' | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech support for more details. |
avs_response_code | string(255) | Generated by the card network on trying to match the billing address when performing the address verification. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
avs_response_text | string(255) | Gives the human response text for the AVS response code above. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
cvv_result_code | string(1) | Card Verification Value response code. Optional, returned only if acquirer supports it |
authorization_code | string(6) | Generated by the card network when an authorisation has occurred, used to identify that auth. Consists of 6 alphanumeric chars |
retrieval_reference_number | string(255) | A reference number used for tracking all messages related to a given cardholder transaction returned by some acquirers. |
response_code | string(2) | Defines the result of a transaction with the acquirer, the status of a message or some action taken or required. Contact tech-support@emerchantpay.com for more details. |
recurring_advice_code | string(2) | Optional, if received in the response from the issuer |
recurring_advice_text | string | Optional, describes the specific recurring advice code |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
partial_approval | string(4) | Optional, set to ’true’ if partial approval happened. Partially approved amount is then in the amount field. Check Partial Approvals for details |
sent_to_acquirer | string(255) | "true" or "false" |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
scheme_transaction_identifier | string(32) | Id defined by card schemes. Corresponds to NETWORK DATA (field 63) for MasterCard or TRANS ID (field 62.2/125) for VISA. |
scheme_settlement_date | string(4) | MasterCard settlement date in MMDD format (e.g. 0117). Corresponds to NETWORK DATA (field 15). |
scheme_response_code | string(2) | The response code returned from the schemes. See Scheme response codes for details. |
recurring_advice_code | string(2) | Optional, if received in the response from the issuer |
recurring_advice_text | string | Optional, describes the specific recurring advice code |
reason_for_not_honoring_exemption | string | Reason for not honoring exemption. Check SCA Reason For Not Honoring Exemption Values. |
sca_exemption_result | string | SCA exemption result. Check SCA Exemption Result Values. |
Error Response
stdClass Object
(
[transaction_type] => sale
[recurring_type] => initial
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[response_code] => 57
[code] => 340
[message] => billing_address[zip_code] is invalid!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:44.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => false
)
<payment_response content=[
<transaction_type content=[sale]>
<recurring_type content=[initial]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<response_code content=[57]>
<code content=[340]>
<message content=[billing_address[zip_code] is invalid!]>
<timestamp content=[2025-01-16T10:23:44Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[false]>
]>
{
transaction_type: "sale",
recurring_type: "initial",
status: "error",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
response_code: "57",
code: "340",
message: "billing_address[zip_code] is invalid!",
timestamp: "2025-01-16T10:23:44Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "false",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>sale</transaction_type>
<recurring_type>initial</recurring_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<response_code>57</response_code>
<code>340</code>
<message>billing_address[zip_code] is invalid!</message>
<timestamp>2025-01-16T10:23:44Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
recurring_type | string(255) | The recurring type(initial, subsequent or managed) |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
Subsequent Recurring
A Subsequent recurring transaction is a ”repeated” transaction that follows and references an Initial recurring transaction.
The card and cardholder data is omitted. Note that Subsequent recurring can be partially or fully refunded if the configuration allows it, and this will not stop the recurring series.
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Sale');
$request = $genesis->request();
$request
->setRecurringType('subsequent')
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReferenceId('43672')
->setAmount('100');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.SaleRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
SaleRequest request = new SaleRequest();
request.setRecurringType("subsequent");
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setReferenceId("43672");
request.setAmount(new BigDecimal(100));
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.sale(
{
"recurring_type": "subsequent",
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"reference_id": "43672",
"amount": "100",
"business_attributes": {
"event_start_date": "17-02-2025",
"event_end_date": "26-02-2025",
"event_organizer_id": "20192375",
"event_id": "1912"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>sale</transaction_type>
<recurring_type>subsequent</recurring_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<reference_id>43672</reference_id>
<amount>100</amount>
<business_attributes>
<event_start_date>17-02-2025</event_start_date>
<event_end_date>26-02-2025</event_end_date>
<event_organizer_id>20192375</event_organizer_id>
<event_id>1912</event_id>
</business_attributes>
</payment_transaction>'
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Authorize');
$request = $genesis->request();
$request
->setRecurringType('subsequent')
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReferenceId('43672')
->setAmount('100');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.AuthorizeRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
AuthorizeRequest request = new AuthorizeRequest();
request.setRecurringType("subsequent");
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setReferenceId("43672");
request.setAmount(new BigDecimal(100));
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.authorize(
{
"recurring_type": "subsequent",
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"reference_id": "43672",
"amount": "100",
"business_attributes": {
"event_start_date": "17-02-2025",
"event_end_date": "26-02-2025",
"event_organizer_id": "20192375",
"event_id": "1912"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>authorize</transaction_type>
<recurring_type>subsequent</recurring_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<reference_id>43672</reference_id>
<amount>100</amount>
<business_attributes>
<event_start_date>17-02-2025</event_start_date>
<event_end_date>26-02-2025</event_end_date>
<event_organizer_id>20192375</event_organizer_id>
<event_id>1912</event_id>
</business_attributes>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: sale or authorize |
recurring_type | required | string(255) | Specifies recurring type of the transaction, 'subsequent' |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
gaming | optional | "true" | Signifies whether a gaming transaction is performed. Gaming transactions usually use MCC 7995. Contact tech-support@emerchantpay.com for more details |
moto | optional | "true" | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech-support@emerchantpay.com for more details |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
reference_id | required | string(32) | Unique id returned by corresponding transaction |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
business_attributes | required* | Check business attributes section. | |
event_start_date | required* | dd-mm-yyyy | The date when event starts in format dd-mm-yyyy |
event_end_date | required* | dd-mm-yyyy | The date when event ends in format dd-mm-yyyy |
event_organizer_id | required* | string | |
event_id | required* | string | |
date_of_order | required* | dd-mm-yyyy | The date when order was placed in format dd-mm-yyyy |
delivery_date | required* | dd-mm-yyyy | Date of the expected delivery in format dd-mm-yyyy |
name_of_the_supplier | required* | string |
required* = conditionally required
Successful Response
stdClass Object
(
[transaction_type] => sale
[recurring_type] => subsequent
[status] => approved
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[authorization_code] => 345678
[retrieval_reference_number] => 016813015184
[response_code] => 00
[technical_message] => Transaction successful!
[message] => Transaction successful!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:44.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[sent_to_acquirer] => true
[scheme_response_code] => 00
[reason_for_not_honoring_exemption] => 8A01
[sca_exemption_result] => 13
)
<payment_response content=[
<transaction_type content=[sale]>
<recurring_type content=[subsequent]>
<status content=[approved]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<authorization_code content=[345678]>
<retrieval_reference_number content=[016813015184]>
<response_code content=[00]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<timestamp content=[2025-01-16T10:23:44Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<sent_to_acquirer content=[true]>
<scheme_response_code content=[00]>
<reason_for_not_honoring_exemption content=[8A01]>
<sca_exemption_result content=[13]>
]>
{
transaction_type: "sale",
recurring_type: "subsequent",
status: "approved",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
authorization_code: "345678",
retrieval_reference_number: "016813015184",
response_code: "00",
technical_message: "Transaction successful!",
message: "Transaction successful!",
timestamp: "2025-01-16T10:23:44Z",
descriptor: "Descriptor one",
amount: "100",
sent_to_acquirer: "true",
scheme_response_code: "00",
reason_for_not_honoring_exemption: "8A01",
sca_exemption_result: "13",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>sale</transaction_type>
<recurring_type>subsequent</recurring_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<authorization_code>345678</authorization_code>
<retrieval_reference_number>016813015184</retrieval_reference_number>
<response_code>00</response_code>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:44Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<sent_to_acquirer>true</sent_to_acquirer>
<scheme_response_code>00</scheme_response_code>
<reason_for_not_honoring_exemption>8A01</reason_for_not_honoring_exemption>
<sca_exemption_result>13</sca_exemption_result>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
recurring_type | string(255) | The recurring type(initial, subsequent or managed) |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
authorization_code | string(6) | Generated by the card network when an authorisation has occurred, used to identify that auth. Consists of 6 alphanumeric chars |
retrieval_reference_number | string(255) | A reference number used for tracking all messages related to a given cardholder transaction returned by some acquirers. |
response_code | string(2) | Defines the result of a transaction with the acquirer, the status of a message or some action taken or required. Contact tech-support@emerchantpay.com for more details. |
recurring_advice_code | string(2) | Optional, if received in the response from the issuer |
recurring_advice_text | string | Optional, describes the specific recurring advice code |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
sent_to_acquirer | string(255) | "true" or "false" |
scheme_response_code | string(2) | The response code returned from the schemes. See Scheme response codes for details. |
recurring_advice_code | string(2) | Optional, if received in the response from the issuer |
recurring_advice_text | string | Optional, describes the specific recurring advice code |
Error Response
stdClass Object
(
[transaction_type] => sale
[recurring_type] => subsequent
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[response_code] => 57
[code] => 340
[message] => billing_address[zip_code] is invalid!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:44.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[sent_to_acquirer] => false
)
<payment_response content=[
<transaction_type content=[sale]>
<recurring_type content=[subsequent]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<response_code content=[57]>
<code content=[340]>
<message content=[billing_address[zip_code] is invalid!]>
<timestamp content=[2025-01-16T10:23:44Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<sent_to_acquirer content=[false]>
]>
{
transaction_type: "sale",
recurring_type: "subsequent",
status: "error",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
response_code: "57",
code: "340",
message: "billing_address[zip_code] is invalid!",
timestamp: "2025-01-16T10:23:44Z",
descriptor: "Descriptor one",
amount: "100",
sent_to_acquirer: "false",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>sale</transaction_type>
<recurring_type>subsequent</recurring_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<response_code>57</response_code>
<code>340</code>
<message>billing_address[zip_code] is invalid!</message>
<timestamp>2025-01-16T10:23:44Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
recurring_type | string(255) | The recurring type(initial, subsequent or managed) |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
gaming | 'true' | Signifies whether a gaming transaction is performed. Gaming transactions usually use MCC 7995, contact tech support for more details. |
moto | 'true' | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech support for more details. |
response_code | string(2) | Defines the result of a transaction with the acquirer, the status of a message or some action taken or required. Contact tech-support@emerchantpay.com for more details. |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
sent_to_acquirer | string(255) | "true" or "false" |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
Non-referenced Subsequent Recurring
To allow for frictionless migration of merchant recurring traffic from other gateways without requiring an initial
recurring transaction yet again Sale or Authorize with
recurring_type subsequent does not need to use initial Sale or
Authorize as a reference for the recurring series in the cases when the
credential_on_file_transaction_identifier
and credential_on_file_settlement_date
parameters are provided in the
transaction request for specific acquirers, please contact Tech Support for more details.
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Sale');
$request = $genesis->request();
$request
->setRecurringType('subsequent')
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('4200000000000000')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCredentialOnFileTransactionIdentifier('MCSQF8SOC')
->setCredentialOnFileSettlementDate('0107')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
->setRecurringCategory('subscription')
// Account Owner
->setAccountFirstName('Travis')
->setAccountMiddleName('Joe')
->setAccountLastName('Pastrana');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.SaleRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
SaleRequest request = new SaleRequest();
request.setRecurringType("subsequent");
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4200000000000000");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCredentialOnFileTransactionIdentifier("MCSQF8SOC");
request.setCredentialOnFileSettlementDate("0107");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
request.setRecurringCategory("subscription");
// Account Owner
request.setAccountFirstname("Travis");
request.setAccountMiddlename("Joe");
request.setAccountLastname("Pastrana");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.sale(
{
"recurring_type": "subsequent",
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "4200000000000000",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"credential_on_file_transaction_identifier": "MCSQF8SOC",
"credential_on_file_settlement_date": "0107",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"business_attributes": {
"event_start_date": "17-02-2025",
"event_end_date": "26-02-2025",
"event_organizer_id": "20192375",
"event_id": "1912"
},
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"recurring_category": "subscription",
"account_owner": {
"first_name": "Travis",
"middle_name": "Joe",
"last_name": "Pastrana"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>sale</transaction_type>
<recurring_type>subsequent</recurring_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4200000000000000</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<credential_on_file_transaction_identifier>MCSQF8SOC</credential_on_file_transaction_identifier>
<credential_on_file_settlement_date>0107</credential_on_file_settlement_date>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<business_attributes>
<event_start_date>17-02-2025</event_start_date>
<event_end_date>26-02-2025</event_end_date>
<event_organizer_id>20192375</event_organizer_id>
<event_id>1912</event_id>
</business_attributes>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<recurring_category>subscription</recurring_category>
<account_owner>
<first_name>Travis</first_name>
<middle_name>Joe</middle_name>
<last_name>Pastrana</last_name>
</account_owner>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: authorize or sale |
recurring_type | required | string(255) | Specifies recurring type of the transaction, 'subsequent' |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
moto | optional | "true" | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech-support@emerchantpay.com for more details |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
amount | required | integer >= 0 | Transaction amount in minor currency unit, see Currency and Amount Handling for details. In certain cases, it is possible to submit a transaction with a zero-value amount in order not to charge the consumer with the initial recurring, but with the followed RecurringSale transactions only. For more information regarding the use cases and scenario, Contact tech-support@emerchantpay.com for more details. |
currency | required | string(3) | Currency code in ISO 4217 |
card_holder | required | string(255) | Full name of customer as printed on credit card (first name and last name at least) |
card_number | required | 13 to 16 digits | Complete cc number of customer |
cvv | required* | 3 to 4 digits | cvv of cc, requirement is based on terminal configuration |
expiration_month | required | MM | Expiration month as printed on credit card |
expiration_year | required | YYYY | Expiration year as printed on credit card |
token | optional | string(36) | See Tokenization for more details. If present, the cardholder parameters can be omitted. Cannot be set together with remember_card |
remember_card | optional | "true" | See Tokenize. Tokenizes cardholder parameters. Cannot be set together with token |
consumer_id | optional | string(10) | See Consumers and Tokenization. Combine with remember_card to tokenize or with token to use token |
scheme_tokenized | required* | "true" | Required when the card_number is DPAN instead of Funding Primary Account Number, see Tokenized e-commerce for details |
recurring_category | optional | string | Specifies whether the recurring transaction is a subscription(fixed amount, fixed intervals)or if it is a standing order(varying amount, fixed intervals). The allowed values aresubscription and standing_order . The default value is subscription |
credential_on_file | required* | See Credential On File (COF) for more details | |
merchant_unscheduled | optional | string(20) | Transaction is initiated by the merchant |
credential_on_file_transaction_identifier | required | string(9..15) | See Credential On File (COF) for more details. Required for Non-referenced Recurring transactions. The length of the value should be 15 for Visa cards, and 9..12 for Mastercard/Maestro cards |
credential_on_file_settlement_date | required* | See Credential On File (COF) for more details. Required for Mastercard/Maestro cards | |
customer_email | required* | e-mail address | Must contain valid e-mail of customer |
customer_phone | required* | string(32) | Must contain valid phone number of customer |
birth_date | required* | dd-mm-yyyy | Required when MCC is a Financial Services one (e.g. MCC 6012) and either card brand is Visa or Mastercard/Maestro with UK-based merchant, UK-based bin (domestic), and DEBIT card type |
document_id | required* | string(255) | Document ID value. |
fx_rate_id | optional | integer | See Get rates for FX Service. Offers the option to use a specific FX rate to convert the transaction processing amount. Used FX rate should have the same source currency as the processing currency. Contact tech-support@emerchantpay.com for more details |
business_attributes | required* | Check business attributes section. | |
event_start_date | required* | dd-mm-yyyy | The date when event starts in format dd-mm-yyyy |
event_end_date | required* | dd-mm-yyyy | The date when event ends in format dd-mm-yyyy |
event_organizer_id | required* | string | |
event_id | required* | string | |
date_of_order | required* | dd-mm-yyyy | The date when order was placed in format dd-mm-yyyy |
delivery_date | required* | dd-mm-yyyy | Date of the expected delivery in format dd-mm-yyyy |
name_of_the_supplier | required* | string | |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required* | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
neighborhood | optional | string(255) | Neighborhood |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
account_owner | optional | Account owner parameters related to account owner inquiry requests | |
first_name | optional | string(35) | Account owner first name |
middle_name | optional | string(35) | Account owner middle name |
last_name | optional | string(35) | Account owner last name |
dynamic_descriptor_params | optional | ||
merchant_name | optional | string(25) | Allows to dynamically override the charge descriptor |
merchant_city | optional | string(13) | Allows to dynamically override the merchant phone number |
sub_merchant_id | optional | string(15) | Allows to dynamically override the sub-merchant ID. |
merchant_country | optional | string(3) | Allows to dynamically override the merchant country. |
merchant_state | optional | string(3) | Allows to dynamically override the merchant subdivision code. |
merchant_zip_code | optional | string(10) | Allows to dynamically override the merchant zip/postal code. Required for VISA OCT transactions with Australian and Canadian card bins. |
merchant_address | optional | string(48) | Allows to dynamically override the merchant address. |
merchant_url | optional | string(60) | Allows to dynamically override the merchant URL |
merchant_phone | optional | string(16) | Allows to dynamically override the merchant phone number. |
merchant_service_city | optional | string(13) | Allows to dynamically override the merchant service city. |
merchant_service_country | optional | string(3) | Allows to dynamically override the merchant service country. |
merchant_service_state | optional | string(3) | Allows to dynamically override the merchant service subdivision code. |
merchant_service_zip_code | optional | string(10) | Allows to dynamically override the merchant service zip/postal code. |
merchant_service_phone | optional | string(16) | Allows to dynamically override the merchant service phone number. |
merchant_geo_coordinates | optional | string(20) | Allows to dynamically override the merchant geographic coordinates. |
merchant_service_geo_coordinates | optional | string(20) | Allows to dynamically override the merchant service geographic coordinates. |
required* = conditionally required
Successful Response
stdClass Object
(
[transaction_type] => sale
[recurring_type] => subsequent
[status] => approved
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[consumer_id] => 123456
[token] => ee946db8-d7db-4bb7-b608-b65b153e127d
[avs_response_code] => 5I
[avs_response_text] => Response provided by issuer processor; Address information not verified
[cvv_result_code] => M
[authorization_code] => 345678
[retrieval_reference_number] => 016813015184
[response_code] => 00
[technical_message] => Transaction successful!
[message] => Transaction successful!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:44.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
[scheme_transaction_identifier] => 019091214161031
[scheme_settlement_date] => 0117
[scheme_response_code] => 00
[reason_for_not_honoring_exemption] => 8A01
[sca_exemption_result] => 13
[account_owner] => {"first_name"=>"Travis", "middle_name"=>"Joe", "last_name"=>"Pastrana"}
)
<payment_response content=[
<transaction_type content=[sale]>
<recurring_type content=[subsequent]>
<status content=[approved]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<consumer_id content=[123456]>
<token content=[ee946db8-d7db-4bb7-b608-b65b153e127d]>
<avs_response_code content=[5I]>
<avs_response_text content=[Response provided by issuer processor; Address information not verified]>
<cvv_result_code content=[M]>
<authorization_code content=[345678]>
<retrieval_reference_number content=[016813015184]>
<response_code content=[00]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<timestamp content=[2025-01-16T10:23:44Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[true]>
<scheme_transaction_identifier content=[019091214161031]>
<scheme_settlement_date content=[0117]>
<scheme_response_code content=[00]>
<reason_for_not_honoring_exemption content=[8A01]>
<sca_exemption_result content=[13]>
<account_owner content=[{"first_name"=>"Travis", "middle_name"=>"Joe", "last_name"=>"Pastrana"}]>
]>
{
transaction_type: "sale",
recurring_type: "subsequent",
status: "approved",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
consumer_id: "123456",
token: "ee946db8-d7db-4bb7-b608-b65b153e127d",
avs_response_code: "5I",
avs_response_text: "Response provided by issuer processor; Address information not verified",
cvv_result_code: "M",
authorization_code: "345678",
retrieval_reference_number: "016813015184",
response_code: "00",
technical_message: "Transaction successful!",
message: "Transaction successful!",
timestamp: "2025-01-16T10:23:44Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "true",
scheme_transaction_identifier: "019091214161031",
scheme_settlement_date: "0117",
scheme_response_code: "00",
reason_for_not_honoring_exemption: "8A01",
sca_exemption_result: "13",
account_owner: "{"first_name"=>"Travis", "middle_name"=>"Joe", "last_name"=>"Pastrana"}",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>sale</transaction_type>
<recurring_type>subsequent</recurring_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<consumer_id>123456</consumer_id>
<token>ee946db8-d7db-4bb7-b608-b65b153e127d</token>
<avs_response_code>5I</avs_response_code>
<avs_response_text>Response provided by issuer processor; Address information not verified</avs_response_text>
<cvv_result_code>M</cvv_result_code>
<authorization_code>345678</authorization_code>
<retrieval_reference_number>016813015184</retrieval_reference_number>
<response_code>00</response_code>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:44Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
<scheme_transaction_identifier>019091214161031</scheme_transaction_identifier>
<scheme_settlement_date>0117</scheme_settlement_date>
<scheme_response_code>00</scheme_response_code>
<reason_for_not_honoring_exemption>8A01</reason_for_not_honoring_exemption>
<sca_exemption_result>13</sca_exemption_result>
<account_owner>
<first_name>Travis</first_name>
<middle_name>Joe</middle_name>
<last_name>Pastrana</last_name>
</account_owner>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
recurring_type | string(255) | The recurring type(initial, subsequent or managed) |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
consumer_id | string(10) | Consumer unique reference. See Consumers |
token | string(36) | Plain-text token value. See Tokenization |
moto | 'true' | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech support for more details. |
avs_response_code | string(255) | Generated by the card network on trying to match the billing address when performing the address verification. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
avs_response_text | string(255) | Gives the human response text for the AVS response code above. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
cvv_result_code | string(1) | Card Verification Value response code. Optional, returned only if acquirer supports it |
authorization_code | string(6) | Generated by the card network when an authorisation has occurred, used to identify that auth. Consists of 6 alphanumeric chars |
retrieval_reference_number | string(255) | A reference number used for tracking all messages related to a given cardholder transaction returned by some acquirers. |
response_code | string(2) | Defines the result of a transaction with the acquirer, the status of a message or some action taken or required. Contact tech-support@emerchantpay.com for more details. |
recurring_advice_code | string(2) | Optional, if received in the response from the issuer |
recurring_advice_text | string | Optional, describes the specific recurring advice code |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
partial_approval | string(4) | Optional, set to ’true’ if partial approval happened. Partially approved amount is then in the amount field. Check Partial Approvals for details |
sent_to_acquirer | string(255) | "true" or "false" |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
scheme_transaction_identifier | string(32) | Id defined by card schemes. Corresponds to NETWORK DATA (field 63) for MasterCard or TRANS ID (field 62.2/125) for VISA. |
scheme_settlement_date | string(4) | MasterCard settlement date in MMDD format (e.g. 0117). Corresponds to NETWORK DATA (field 15). |
scheme_response_code | string(2) | The response code returned from the schemes. See Scheme response codes for details. |
recurring_advice_code | string(2) | Optional, if received in the response from the issuer |
recurring_advice_text | string | Optional, describes the specific recurring advice code |
reason_for_not_honoring_exemption | string | Reason for not honoring exemption. Check SCA Reason For Not Honoring Exemption Values. |
sca_exemption_result | string | SCA exemption result. Check SCA Exemption Result Values. |
Error Response
stdClass Object
(
[transaction_type] => sale
[recurring_type] => subsequent
[status] => declined
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 510
[technical_message] => Invalid Issuer
[message] => Transaction failed, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:44.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[sale]>
<recurring_type content=[subsequent]>
<status content=[declined]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<code content=[510]>
<technical_message content=[Invalid Issuer]>
<message content=[Transaction failed, please contact support!]>
<timestamp content=[2025-01-16T10:23:44Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "sale",
recurring_type: "subsequent",
status: "declined",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
code: "510",
technical_message: "Invalid Issuer",
message: "Transaction failed, please contact support!",
timestamp: "2025-01-16T10:23:44Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>sale</transaction_type>
<recurring_type>subsequent</recurring_type>
<status>declined</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>510</code>
<technical_message>Invalid Issuer</technical_message>
<message>Transaction failed, please contact support!</message>
<timestamp>2025-01-16T10:23:44Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
recurring_type | string(255) | The recurring type(initial, subsequent or managed) |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
Error Response
stdClass Object
(
[transaction_type] => sale
[recurring_type] => subsequent
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[response_code] => 57
[code] => 510
[message] => Transaction failed, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:44.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => false
)
<payment_response content=[
<transaction_type content=[sale]>
<recurring_type content=[subsequent]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<response_code content=[57]>
<code content=[510]>
<message content=[Transaction failed, please contact support!]>
<timestamp content=[2025-01-16T10:23:44Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[false]>
]>
{
transaction_type: "sale",
recurring_type: "subsequent",
status: "error",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
response_code: "57",
code: "510",
message: "Transaction failed, please contact support!",
timestamp: "2025-01-16T10:23:44Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "false",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>sale</transaction_type>
<recurring_type>subsequent</recurring_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<response_code>57</response_code>
<code>510</code>
<message>Transaction failed, please contact support!</message>
<timestamp>2025-01-16T10:23:44Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
recurring_type | string(255) | The recurring type(initial, subsequent or managed) |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
Recurring for Indian cards
Recurring transactions with cards issued in India are subject to special rules. Prior to requesting a recurring series, the merchant should register the recurring agreement as per the Reserve Bank of India (RBI) regulations.
After that, use the managed_recurring
params section in order to provide the params from the agreement. Should be sent in both Initial and Subsequent recurring transactions.
How to use managed recurring for Indian cards in Processing API
Requests
Managed Recurring
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Sale');
$request = $genesis->request();
$request
->setRecurringType('managed')
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setToken('ee946db8-d7db-4bb7-b608-b65b153e127d')
->setCardHolder('Travis Pastrana')
->setCvv('834')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
->setManagedRecurring('{"mode"=>"manual", "payment_type"=>"subsequent", "amount_type"=>"fixed", "frequency"=>"weekly", "registration_reference_number"=>"123434", "max_amount"=>200, "max_count"=>99, "validated"=>"true"}');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.SaleRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
SaleRequest request = new SaleRequest();
request.setRecurringType("managed");
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setToken("ee946db8-d7db-4bb7-b608-b65b153e127d");
request.setCardHolder("Travis Pastrana");
request.setCvv("834");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
request.setManagedRecurring("{"mode"=>"manual", "payment_type"=>"subsequent", "amount_type"=>"fixed", "frequency"=>"weekly", "registration_reference_number"=>"123434", "max_amount"=>200, "max_count"=>99, "validated"=>"true"}");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.sale(
{
"recurring_type": "managed",
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"token": "ee946db8-d7db-4bb7-b608-b65b153e127d",
"card_holder": "Travis Pastrana",
"cvv": "834",
"expiration_month": "12",
"expiration_year": 2026,
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"managed_recurring": {
"mode": "manual",
"payment_type": "subsequent",
"amount_type": "fixed",
"frequency": "weekly",
"registration_reference_number": "123434",
"max_amount": 200,
"max_count": 99,
"validated": "true"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>sale</transaction_type>
<recurring_type>managed</recurring_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<token>ee946db8-d7db-4bb7-b608-b65b153e127d</token>
<card_holder>Travis Pastrana</card_holder>
<cvv>834</cvv>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<managed_recurring>
<mode>manual</mode>
<payment_type>subsequent</payment_type>
<amount_type>fixed</amount_type>
<frequency>weekly</frequency>
<registration_reference_number>123434</registration_reference_number>
<max_amount>200</max_amount>
<max_count>99</max_count>
<validated>true</validated>
</managed_recurring>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
recurring_type | required | string(255) | Specifies recurring type of the transaction, 'managed' |
managed_recurring | required | ||
mode | required | String | Fill in with 'manual'. This indicates that the merchant will manually manage the subsequent recurring transactions. |
payment_type | required | String | Type of the current recurring transaction. Values: initial, subsequent, modification, cancellation |
amount_type | required | String | Type of the amount. Values: fixed, max |
frequency | required | String | Frequency of the subsequent transactions. Values: daily, twice_weekly, weekly, ten_days, fortnightly, monthly, every_two_months, trimester, quarterly, twice_yearly, annually, unscheduled |
registration_reference_number | required | String(35) | Reference number as per the agreement. |
max_amount | required | Integer | Maximum amount as per the agreement. |
max_count | required | Integer | Maximum transactions count as per the agreement. 99 - indicates infinite subsequent payments. |
validated | required | String | Indicates if the current transaction is valid as per the registered agreement. Values: true, false |
required* = conditionally required
How to use managed recurring for Indian cards in WPF API
Requests
Merchants can send managed recurring params in the request when creating Initial recurring transactions via our WPF API.
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('WPF\Create');
$request = $genesis->request();
$request
->setRecurringType('initial')
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setDescription('You are about to buy 3 shoes at www.shoes.com!')
->setNotificationUrl('https://www.example.com/notification')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setReturnCancelUrl('http://www.example.com/cancel.html')
->setAmount('100')
->setCurrency('USD')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
->setLifetime('60')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
// Risk Params
->setRiskUserId('123456')
// Transaction Types
->addTransactionType('transaction_type')
->setRememberCard('true')
->setManagedRecurring('');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.wpf.WPFCreateRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
WPFCreateRequest request = new WPFCreateRequest();
request.setRecurringType("initial");
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setDescription("You are about to buy 3 shoes at www.shoes.com!");
request.setNotificationUrl(new URL("https://www.example.com/notification"));
request.setReturnSuccessUrl(new URL("http://www.example.com/success"));
request.setReturnFailureUrl(new URL("http://www.example.com/failure"));
request.setReturnCancelUrl(new URL("http://www.example.com/cancel.html"));
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
request.setLifetime(60);
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
// Risk Params
request.setRiskUserId("123456");
// Transaction Types
request.addTransactionType("transaction_type").done();
request.setRememberCard("true");
request.setManagedRecurring("");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.wpf_create(
{
"recurring_type": "initial",
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"description": "You are about to buy 3 shoes at www.shoes.com!",
"notification_url": "https://www.example.com/notification",
"return_success_url": "http://www.example.com/success",
"return_failure_url": "http://www.example.com/failure",
"return_cancel_url": "http://www.example.com/cancel.html",
"amount": "100",
"currency": "USD",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"lifetime": 60,
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"risk_params": {
"user_id": "123456"
},
"transaction_types": [
"transaction_type"
],
"remember_card": "true",
"managed_recurring": null
}
).send()
.then(success)
.catch(failure);
Request
curl https://staging.wpf.emerchantpay.net/wpf \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<wpf_payment>
<transaction_type>wpf_create</transaction_type>
<recurring_type>initial</recurring_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<description>You are about to buy 3 shoes at www.shoes.com!</description>
<notification_url>https://www.example.com/notification</notification_url>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<return_cancel_url>http://www.example.com/cancel.html</return_cancel_url>
<amount>100</amount>
<currency>USD</currency>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<lifetime>60</lifetime>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<risk_params>
<user_id>123456</user_id>
</risk_params>
<transaction_types>
<transaction_type>
<name>sale</name>
<recurring_type>managed</recurring_type>
<managed_recurring>
<mode>manual</mode>
<payment_type>subsequent</payment_type>
<amount_type>fixed</amount_type>
<frequency>weekly</frequency>
<registration_reference_number>123434</registration_reference_number>
<max_amount>200</max_amount>
<max_count>99</max_count>
<validated>true</validated>
</managed_recurring>
</transaction_type>
</transaction_types>
<remember_card>true</remember_card>
<wpf_payment>managed_recurring</wpf_payment>
</wpf_payment>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
recurring_type | required | string(255) | Specifies recurring type of the transaction, 'managed' |
managed_recurring | required | ||
mode | required | String | Fill in with 'manual'. This indicates that the merchant will manually manage the subsequent recurring transactions. |
payment_type | required | String | Type of the current recurring transaction. Values: initial, subsequent, modification, cancellation |
amount_type | required | String | Type of the amount. Values: fixed, max |
frequency | required | String | Frequency of the subsequent transactions. Values: daily, twice_weekly, weekly, ten_days, fortnightly, monthly, every_two_months, trimester, quarterly, twice_yearly, annually, unscheduled |
registration_reference_number | required | String(35) | Reference number as per the agreement. |
max_amount | required | Integer | Maximum amount as per the agreement. |
max_count | required | Integer | Maximum transactions count as per the agreement. 99 - indicates infinite subsequent payments. |
validated | required | String | Indicates if the current transaction is valid as per the registered agreement. Values: true, false |
required* = conditionally required
Recurring Transactions
A recurring transaction describes a payment where the cardholder’s account is periodically charged for a repeated delivery and use of a product or service (subscription, membership fee, etc.) over time. A recurring payment consists of an initial transaction and one or several repeated transactions. The ”initial” transaction contains all relevant card and cardholder data, while the subsequent repeated transaction references an identifier which is returned with the response to the initial request.
Init Recurring Sale
An InitRecurringSale transaction initializes a recurring payment and is equal to a normal SaleTransaction except that it can be referenced as ”initial” transaction in a RecurringSale transaction.
Note that if an InitRecurringSale is fully refunded, the recurring series is stopped and no more RecurringSales can be performed for that recurring series.
If an InitRecurringSale is partially refunded, the recurring series can continue with more RecurringSales
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Recurring\InitRecurringSale');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('4200000000000000')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
->setRecurringCategory('subscription')
// Account Owner
->setAccountFirstName('Travis')
->setAccountMiddleName('Joe')
->setAccountLastName('Pastrana');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.recurring.InitRecurringSale;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
InitRecurringSale request = new InitRecurringSale();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4200000000000000");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
request.setRecurringCategory("subscription");
// Account Owner
request.setAccountFirstname("Travis");
request.setAccountMiddlename("Joe");
request.setAccountLastname("Pastrana");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.init_recurring_sale(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "4200000000000000",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"business_attributes": {
"event_start_date": "17-02-2025",
"event_end_date": "26-02-2025",
"event_organizer_id": "20192375",
"event_id": "1912"
},
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"recurring_category": "subscription",
"account_owner": {
"first_name": "Travis",
"middle_name": "Joe",
"last_name": "Pastrana"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>init_recurring_sale</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4200000000000000</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<business_attributes>
<event_start_date>17-02-2025</event_start_date>
<event_end_date>26-02-2025</event_end_date>
<event_organizer_id>20192375</event_organizer_id>
<event_id>1912</event_id>
</business_attributes>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<recurring_category>subscription</recurring_category>
<account_owner>
<first_name>Travis</first_name>
<middle_name>Joe</middle_name>
<last_name>Pastrana</last_name>
</account_owner>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: init_recurring_sale |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
moto | optional | "true" | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech-support@emerchantpay.com for more details |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
amount | required | integer >= 0 | Transaction amount in minor currency unit, see Currency and Amount Handling for details. In certain cases, it is possible to submit a transaction with a zero-value amount in order not to charge the consumer with the initial recurring, but with the followed RecurringSale transactions only. For more information regarding the use cases and scenario, Contact tech-support@emerchantpay.com for more details. |
currency | required | string(3) | Currency code in ISO 4217 |
card_holder | required | string(255) | Full name of customer as printed on credit card (first name and last name at least) |
card_number | required | 13 to 16 digits | Complete cc number of customer |
cvv | required* | 3 to 4 digits | cvv of cc, requirement is based on terminal configuration |
expiration_month | required | MM | Expiration month as printed on credit card |
expiration_year | required | YYYY | Expiration year as printed on credit card |
token | optional | string(36) | See Tokenization for more details. If present, the cardholder parameters can be omitted. Cannot be set together with remember_card |
remember_card | optional | "true" | See Tokenize. Tokenizes cardholder parameters. Cannot be set together with token |
consumer_id | optional | string(10) | See Consumers and Tokenization. Combine with remember_card to tokenize or with token to use token |
scheme_tokenized | required* | "true" | Required when the card_number is DPAN instead of Funding Primary Account Number, see Tokenized e-commerce for details |
recurring_category | optional | string | Specifies whether the recurring transaction is a subscription(fixed amount, fixed intervals)or if it is a standing order(varying amount, fixed intervals). The allowed values aresubscription and standing_order . The default value is subscription |
credential_on_file | required* | See Credential On File (COF) for more details | |
initial_customer_initiated | required* | string(18) | Initial transaction initiated by customer. Required for external tokenization, and optional for gateway-based tokenization |
subsequent_customer_initiated | required* | string(18) | Subsequent transaction initiated by customer. Required for external tokenization, and optional for gateway-based tokenization |
merchant_unscheduled | optional | string(20) | Transaction is initiated by the merchant |
credential_on_file_transaction_identifier | optional | string(15..32) | See Credential On File (COF) for more details |
credential_on_file_settlement_date | optional | string(4) | See Credential On File (COF) for more details |
customer_email | required* | e-mail address | Must contain valid e-mail of customer |
customer_phone | required* | string(32) | Must contain valid phone number of customer |
birth_date | required* | dd-mm-yyyy | Required when MCC is a Financial Services one (e.g. MCC 6012) and either card brand is Visa or Mastercard/Maestro with UK-based merchant, UK-based bin (domestic), and DEBIT card type |
document_id | required* | string(255) | Document ID value. |
fx_rate_id | optional | integer | See Get rates for FX Service. Offers the option to use a specific FX rate to convert the transaction processing amount. Used FX rate should have the same source currency as the processing currency. Contact tech-support@emerchantpay.com for more details |
business_attributes | required* | Check business attributes section. | |
event_start_date | required* | dd-mm-yyyy | The date when event starts in format dd-mm-yyyy |
event_end_date | required* | dd-mm-yyyy | The date when event ends in format dd-mm-yyyy |
event_organizer_id | required* | string | |
event_id | required* | string | |
date_of_order | required* | dd-mm-yyyy | The date when order was placed in format dd-mm-yyyy |
delivery_date | required* | dd-mm-yyyy | Date of the expected delivery in format dd-mm-yyyy |
name_of_the_supplier | required* | string | |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required* | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
neighborhood | optional | string(255) | Neighborhood |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
funding | optional | Funding Transaction Params | |
identifier_type | required* | string | This is only required in case of Mastercard. Type of Funding Transaction. Please check Identifier Types |
business_application_identifier | required* | string | This is only required in case of VISA. Type of VISA Funding Transaction. Please check BAI |
receiver | optional | Funding Transaction Receiver details | |
first_name | required* | string | First name of the receiver |
last_name | required* | string | Last name of the receiver |
country | required* | string(2) | Country code in ISO 3166 |
account_number | required* | string | Receiver account number. Mandatory for Mastercard. If Sender Reference Number is provided then it becomes optional for VISA |
account_number_type | required* | string | This is only required in case of Mastercard. Receiver account number type. Please check Receiver Account Types |
address | required* | string | Receiver address. Only required in case of VISA and Canadian cards |
state | required* | string | Receiver state. Only required in case of VISA and Canadian cards |
city | required* | string | Receiver city. Only required in case of VISA and Canadian cards |
sender | optional | Funding Transaction Sender details | |
name | required* | string | Sender name. Only required in case of VISA |
reference_number | required* | string | Sender Reference Number. Only required in case of VISA. This is option if Receiver Account Number is provided |
country | required* | string | Sender country. Only required in case of VISA. If not provided billing address is used |
address | required* | string | Sender address. Only required in case of VISA. If not provided billing address is used |
state | required* | string | Sender state. Only required in case of VISA and Canadian card. If not provided billing address is used |
city | required* | string | Sender city. Only required in case of VISA. If not provided billing address is used |
account_owner | optional | Account owner parameters related to account owner inquiry requests | |
first_name | optional | string(35) | Account owner first name |
middle_name | optional | string(35) | Account owner middle name |
last_name | optional | string(35) | Account owner last name |
dynamic_descriptor_params | optional | ||
merchant_name | optional | string(25) | Allows to dynamically override the charge descriptor |
merchant_city | optional | string(13) | Allows to dynamically override the merchant phone number |
sub_merchant_id | optional | string(15) | Allows to dynamically override the sub-merchant ID. |
merchant_country | optional | string(3) | Allows to dynamically override the merchant country. |
merchant_state | optional | string(3) | Allows to dynamically override the merchant subdivision code. |
merchant_zip_code | optional | string(10) | Allows to dynamically override the merchant zip/postal code. Required for VISA OCT transactions with Australian and Canadian card bins. |
merchant_address | optional | string(48) | Allows to dynamically override the merchant address. |
merchant_url | optional | string(60) | Allows to dynamically override the merchant URL |
merchant_phone | optional | string(16) | Allows to dynamically override the merchant phone number. |
merchant_service_city | optional | string(13) | Allows to dynamically override the merchant service city. |
merchant_service_country | optional | string(3) | Allows to dynamically override the merchant service country. |
merchant_service_state | optional | string(3) | Allows to dynamically override the merchant service subdivision code. |
merchant_service_zip_code | optional | string(10) | Allows to dynamically override the merchant service zip/postal code. |
merchant_service_phone | optional | string(16) | Allows to dynamically override the merchant service phone number. |
merchant_geo_coordinates | optional | string(20) | Allows to dynamically override the merchant geographic coordinates. |
merchant_service_geo_coordinates | optional | string(20) | Allows to dynamically override the merchant service geographic coordinates. |
required* = conditionally required
Successful Response
stdClass Object
(
[transaction_type] => init_recurring_sale
[status] => approved
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[consumer_id] => 123456
[token] => ee946db8-d7db-4bb7-b608-b65b153e127d
[avs_response_code] => 5I
[avs_response_text] => Response provided by issuer processor; Address information not verified
[cvv_result_code] => M
[authorization_code] => 345678
[retrieval_reference_number] => 016813015184
[response_code] => 00
[technical_message] => Transaction successful!
[message] => Transaction successful!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:45.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
[scheme_transaction_identifier] => 019091214161031
[scheme_settlement_date] => 0117
[scheme_response_code] => 00
[reason_for_not_honoring_exemption] => 8A01
[sca_exemption_result] => 13
[account_owner] => {"first_name"=>"Travis", "middle_name"=>"Joe", "last_name"=>"Pastrana"}
)
<payment_response content=[
<transaction_type content=[init_recurring_sale]>
<status content=[approved]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<consumer_id content=[123456]>
<token content=[ee946db8-d7db-4bb7-b608-b65b153e127d]>
<avs_response_code content=[5I]>
<avs_response_text content=[Response provided by issuer processor; Address information not verified]>
<cvv_result_code content=[M]>
<authorization_code content=[345678]>
<retrieval_reference_number content=[016813015184]>
<response_code content=[00]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<timestamp content=[2025-01-16T10:23:45Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[true]>
<scheme_transaction_identifier content=[019091214161031]>
<scheme_settlement_date content=[0117]>
<scheme_response_code content=[00]>
<reason_for_not_honoring_exemption content=[8A01]>
<sca_exemption_result content=[13]>
<account_owner content=[{"first_name"=>"Travis", "middle_name"=>"Joe", "last_name"=>"Pastrana"}]>
]>
{
transaction_type: "init_recurring_sale",
status: "approved",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
consumer_id: "123456",
token: "ee946db8-d7db-4bb7-b608-b65b153e127d",
avs_response_code: "5I",
avs_response_text: "Response provided by issuer processor; Address information not verified",
cvv_result_code: "M",
authorization_code: "345678",
retrieval_reference_number: "016813015184",
response_code: "00",
technical_message: "Transaction successful!",
message: "Transaction successful!",
timestamp: "2025-01-16T10:23:45Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "true",
scheme_transaction_identifier: "019091214161031",
scheme_settlement_date: "0117",
scheme_response_code: "00",
reason_for_not_honoring_exemption: "8A01",
sca_exemption_result: "13",
account_owner: "{"first_name"=>"Travis", "middle_name"=>"Joe", "last_name"=>"Pastrana"}",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>init_recurring_sale</transaction_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<consumer_id>123456</consumer_id>
<token>ee946db8-d7db-4bb7-b608-b65b153e127d</token>
<avs_response_code>5I</avs_response_code>
<avs_response_text>Response provided by issuer processor; Address information not verified</avs_response_text>
<cvv_result_code>M</cvv_result_code>
<authorization_code>345678</authorization_code>
<retrieval_reference_number>016813015184</retrieval_reference_number>
<response_code>00</response_code>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:45Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
<scheme_transaction_identifier>019091214161031</scheme_transaction_identifier>
<scheme_settlement_date>0117</scheme_settlement_date>
<scheme_response_code>00</scheme_response_code>
<reason_for_not_honoring_exemption>8A01</reason_for_not_honoring_exemption>
<sca_exemption_result>13</sca_exemption_result>
<account_owner>
<first_name>Travis</first_name>
<middle_name>Joe</middle_name>
<last_name>Pastrana</last_name>
</account_owner>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
consumer_id | string(10) | Consumer unique reference. See Consumers |
token | string(36) | Plain-text token value. See Tokenization |
moto | 'true' | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech support for more details. |
avs_response_code | string(255) | Generated by the card network on trying to match the billing address when performing the address verification. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
avs_response_text | string(255) | Gives the human response text for the AVS response code above. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
cvv_result_code | string(1) | Card Verification Value response code. Optional, returned only if acquirer supports it |
authorization_code | string(6) | Generated by the card network when an authorisation has occurred, used to identify that auth. Consists of 6 alphanumeric chars |
retrieval_reference_number | string(255) | A reference number used for tracking all messages related to a given cardholder transaction returned by some acquirers. |
response_code | string(2) | Defines the result of a transaction with the acquirer, the status of a message or some action taken or required. Contact tech-support@emerchantpay.com for more details. |
recurring_advice_code | string(2) | Optional, if received in the response from the issuer |
recurring_advice_text | string | Optional, describes the specific recurring advice code |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
partial_approval | string(4) | Optional, set to ’true’ if partial approval happened. Partially approved amount is then in the amount field. Check Partial Approvals for details |
sent_to_acquirer | string(255) | "true" or "false" |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
scheme_transaction_identifier | string(32) | Id defined by card schemes. Corresponds to NETWORK DATA (field 63) for MasterCard or TRANS ID (field 62.2/125) for VISA. |
scheme_settlement_date | string(4) | MasterCard settlement date in MMDD format (e.g. 0117). Corresponds to NETWORK DATA (field 15). |
scheme_response_code | string(2) | The response code returned from the schemes. See Scheme response codes for details. |
recurring_advice_code | string(2) | Optional, if received in the response from the issuer |
recurring_advice_text | string | Optional, describes the specific recurring advice code |
reason_for_not_honoring_exemption | string | Reason for not honoring exemption. Check SCA Reason For Not Honoring Exemption Values. |
sca_exemption_result | string | SCA exemption result. Check SCA Exemption Result Values. |
Error Response
stdClass Object
(
[transaction_type] => init_recurring_sale
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[response_code] => 57
[code] => 340
[message] => billing_address[zip_code] is invalid!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:45.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => false
)
<payment_response content=[
<transaction_type content=[init_recurring_sale]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<response_code content=[57]>
<code content=[340]>
<message content=[billing_address[zip_code] is invalid!]>
<timestamp content=[2025-01-16T10:23:45Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[false]>
]>
{
transaction_type: "init_recurring_sale",
status: "error",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
response_code: "57",
code: "340",
message: "billing_address[zip_code] is invalid!",
timestamp: "2025-01-16T10:23:45Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "false",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>init_recurring_sale</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<response_code>57</response_code>
<code>340</code>
<message>billing_address[zip_code] is invalid!</message>
<timestamp>2025-01-16T10:23:45Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
Recurring Sale
A RecurringSale transaction is a ”repeated” transaction which follows and references a Init Recurring Sale transaction.
The card and cardholder data is omitted. Note that RecurringSales can be partially or fully refunded if configuration allows it, and this will not stop the recurring series.
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Recurring\RecurringSale');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReferenceId('43672')
->setAmount('100');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.recurring.RecurringSale;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
RecurringSale request = new RecurringSale();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setReferenceId("43672");
request.setAmount(new BigDecimal(100));
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.recurring_sale(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"reference_id": "43672",
"amount": "100",
"business_attributes": {
"event_start_date": "17-02-2025",
"event_end_date": "26-02-2025",
"event_organizer_id": "20192375",
"event_id": "1912"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>recurring_sale</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<reference_id>43672</reference_id>
<amount>100</amount>
<business_attributes>
<event_start_date>17-02-2025</event_start_date>
<event_end_date>26-02-2025</event_end_date>
<event_organizer_id>20192375</event_organizer_id>
<event_id>1912</event_id>
</business_attributes>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: recurring_sale |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
gaming | optional | "true" | Signifies whether a gaming transaction is performed. Gaming transactions usually use MCC 7995. Contact tech-support@emerchantpay.com for more details |
moto | optional | "true" | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech-support@emerchantpay.com for more details |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
reference_id | required | string(32) | Unique id returned by corresponding transaction |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
business_attributes | required* | Check business attributes section. | |
event_start_date | required* | dd-mm-yyyy | The date when event starts in format dd-mm-yyyy |
event_end_date | required* | dd-mm-yyyy | The date when event ends in format dd-mm-yyyy |
event_organizer_id | required* | string | |
event_id | required* | string | |
date_of_order | required* | dd-mm-yyyy | The date when order was placed in format dd-mm-yyyy |
delivery_date | required* | dd-mm-yyyy | Date of the expected delivery in format dd-mm-yyyy |
name_of_the_supplier | required* | string | |
funding | optional | Funding Transaction Params | |
identifier_type | required* | string | This is only required in case of Mastercard. Type of Funding Transaction. Please check Identifier Types |
business_application_identifier | required* | string | This is only required in case of VISA. Type of VISA Funding Transaction. Please check BAI |
receiver | optional | Funding Transaction Receiver details | |
first_name | required* | string | First name of the receiver |
last_name | required* | string | Last name of the receiver |
country | required* | string(2) | Country code in ISO 3166 |
account_number | required* | string | Receiver account number. Mandatory for Mastercard. If Sender Reference Number is provided then it becomes optional for VISA |
account_number_type | required* | string | This is only required in case of Mastercard. Receiver account number type. Please check Receiver Account Types |
address | required* | string | Receiver address. Only required in case of VISA and Canadian cards |
state | required* | string | Receiver state. Only required in case of VISA and Canadian cards |
city | required* | string | Receiver city. Only required in case of VISA and Canadian cards |
sender | optional | Funding Transaction Sender details | |
name | required* | string | Sender name. Only required in case of VISA |
reference_number | required* | string | Sender Reference Number. Only required in case of VISA. This is option if Receiver Account Number is provided |
country | required* | string | Sender country. Only required in case of VISA. If not provided billing address is used |
address | required* | string | Sender address. Only required in case of VISA. If not provided billing address is used |
state | required* | string | Sender state. Only required in case of VISA and Canadian card. If not provided billing address is used |
city | required* | string | Sender city. Only required in case of VISA. If not provided billing address is used |
required* = conditionally required
Successful Response
stdClass Object
(
[transaction_type] => recurring_sale
[status] => approved
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[authorization_code] => 345678
[retrieval_reference_number] => 016813015184
[response_code] => 00
[technical_message] => Transaction successful!
[message] => Transaction successful!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:45.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[sent_to_acquirer] => true
[scheme_response_code] => 00
[reason_for_not_honoring_exemption] => 8A01
[sca_exemption_result] => 13
)
<payment_response content=[
<transaction_type content=[recurring_sale]>
<status content=[approved]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<authorization_code content=[345678]>
<retrieval_reference_number content=[016813015184]>
<response_code content=[00]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<timestamp content=[2025-01-16T10:23:45Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<sent_to_acquirer content=[true]>
<scheme_response_code content=[00]>
<reason_for_not_honoring_exemption content=[8A01]>
<sca_exemption_result content=[13]>
]>
{
transaction_type: "recurring_sale",
status: "approved",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
authorization_code: "345678",
retrieval_reference_number: "016813015184",
response_code: "00",
technical_message: "Transaction successful!",
message: "Transaction successful!",
timestamp: "2025-01-16T10:23:45Z",
descriptor: "Descriptor one",
amount: "100",
sent_to_acquirer: "true",
scheme_response_code: "00",
reason_for_not_honoring_exemption: "8A01",
sca_exemption_result: "13",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>recurring_sale</transaction_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<authorization_code>345678</authorization_code>
<retrieval_reference_number>016813015184</retrieval_reference_number>
<response_code>00</response_code>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:45Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<sent_to_acquirer>true</sent_to_acquirer>
<scheme_response_code>00</scheme_response_code>
<reason_for_not_honoring_exemption>8A01</reason_for_not_honoring_exemption>
<sca_exemption_result>13</sca_exemption_result>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
authorization_code | string(6) | Generated by the card network when an authorisation has occurred, used to identify that auth. Consists of 6 alphanumeric chars |
retrieval_reference_number | string(255) | A reference number used for tracking all messages related to a given cardholder transaction returned by some acquirers. |
response_code | string(2) | Defines the result of a transaction with the acquirer, the status of a message or some action taken or required. Contact tech-support@emerchantpay.com for more details. |
recurring_advice_code | string(2) | Optional, if received in the response from the issuer |
recurring_advice_text | string | Optional, describes the specific recurring advice code |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
sent_to_acquirer | string(255) | "true" or "false" |
scheme_response_code | string(2) | The response code returned from the schemes. See Scheme response codes for details. |
recurring_advice_code | string(2) | Optional, if received in the response from the issuer |
recurring_advice_text | string | Optional, describes the specific recurring advice code |
Error Response
stdClass Object
(
[transaction_type] => recurring_sale
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[response_code] => 57
[code] => 340
[message] => billing_address[zip_code] is invalid!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:45.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[sent_to_acquirer] => false
)
<payment_response content=[
<transaction_type content=[recurring_sale]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<response_code content=[57]>
<code content=[340]>
<message content=[billing_address[zip_code] is invalid!]>
<timestamp content=[2025-01-16T10:23:45Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<sent_to_acquirer content=[false]>
]>
{
transaction_type: "recurring_sale",
status: "error",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
response_code: "57",
code: "340",
message: "billing_address[zip_code] is invalid!",
timestamp: "2025-01-16T10:23:45Z",
descriptor: "Descriptor one",
amount: "100",
sent_to_acquirer: "false",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>recurring_sale</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<response_code>57</response_code>
<code>340</code>
<message>billing_address[zip_code] is invalid!</message>
<timestamp>2025-01-16T10:23:45Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
gaming | 'true' | Signifies whether a gaming transaction is performed. Gaming transactions usually use MCC 7995, contact tech support for more details. |
moto | 'true' | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech support for more details. |
response_code | string(2) | Defines the result of a transaction with the acquirer, the status of a message or some action taken or required. Contact tech-support@emerchantpay.com for more details. |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
sent_to_acquirer | string(255) | "true" or "false" |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
Recurring for Indian cards
Recurring transactions with cards issued in India are subject to special rules. Prior to requesting the recurring transaction, the merchant should register the recurring agreement as per the Reserve bank of India (RBI) regulations.
After that, use the managed_recurring
params section in order to provide the params from the agreement. Should be sent in both initial and subsequent recurring transactions.
How to use managed recurring for Indian cards in Processing API
Requests
Managed Recurring
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Recurring\InitRecurringSale');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setToken('ee946db8-d7db-4bb7-b608-b65b153e127d')
->setCardHolder('Travis Pastrana')
->setCvv('834')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
->setManagedRecurring('{"mode"=>"manual", "payment_type"=>"subsequent", "amount_type"=>"fixed", "frequency"=>"weekly", "registration_reference_number"=>"123434", "max_amount"=>200, "max_count"=>99, "validated"=>"true"}');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.recurring.InitRecurringSale;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
InitRecurringSale request = new InitRecurringSale();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setToken("ee946db8-d7db-4bb7-b608-b65b153e127d");
request.setCardHolder("Travis Pastrana");
request.setCvv("834");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
request.setManagedRecurring("{"mode"=>"manual", "payment_type"=>"subsequent", "amount_type"=>"fixed", "frequency"=>"weekly", "registration_reference_number"=>"123434", "max_amount"=>200, "max_count"=>99, "validated"=>"true"}");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.init_recurring_sale(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"token": "ee946db8-d7db-4bb7-b608-b65b153e127d",
"card_holder": "Travis Pastrana",
"cvv": "834",
"expiration_month": "12",
"expiration_year": 2026,
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"managed_recurring": {
"mode": "manual",
"payment_type": "subsequent",
"amount_type": "fixed",
"frequency": "weekly",
"registration_reference_number": "123434",
"max_amount": 200,
"max_count": 99,
"validated": "true"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<token>ee946db8-d7db-4bb7-b608-b65b153e127d</token>
<card_holder>Travis Pastrana</card_holder>
<cvv>834</cvv>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<managed_recurring>
<mode>manual</mode>
<payment_type>subsequent</payment_type>
<amount_type>fixed</amount_type>
<frequency>weekly</frequency>
<registration_reference_number>123434</registration_reference_number>
<max_amount>200</max_amount>
<max_count>99</max_count>
<validated>true</validated>
</managed_recurring>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
managed_recurring | required | ||
mode | required | String | Fill in with 'manual'. This indicates that the merchant will manually manage the subsequent recurring transactions. |
payment_type | required | String | Type of the current recurring transaction. Values: initial, subsequent, modification, cancellation |
amount_type | required | String | Type of the amount. Values: fixed, max |
frequency | required | String | Frequency of the subsequent transactions. Values: daily, twice_weekly, weekly, ten_days, fortnightly, monthly, every_two_months, trimester, quarterly, twice_yearly, annually, unscheduled |
registration_reference_number | required | String(35) | Reference number as per the agreement. |
max_amount | required | Integer | Maximum amount as per the agreement. |
max_count | required | Integer | Maximum transactions count as per the agreement. 99 - indicates infinite subsequent payments. |
validated | required | String | Indicates if the current transaction is valid as per the registered agreement. Values: true, false |
required* = conditionally required
How to use managed recurring for Indian cards in WPF API
Requests
Merchants can send managed recurring params in the request when creating initial recurring transactions via our WPF API.
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('WPF\Create');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setDescription('You are about to buy 3 shoes at www.shoes.com!')
->setNotificationUrl('https://www.example.com/notification')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setReturnCancelUrl('http://www.example.com/cancel.html')
->setAmount('100')
->setCurrency('USD')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
->setLifetime('60')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
// Risk Params
->setRiskUserId('123456')
// Transaction Types
->addTransactionType('transaction_type')
->setRememberCard('true')
->setManagedRecurring('');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.wpf.WPFCreateRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
WPFCreateRequest request = new WPFCreateRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setDescription("You are about to buy 3 shoes at www.shoes.com!");
request.setNotificationUrl(new URL("https://www.example.com/notification"));
request.setReturnSuccessUrl(new URL("http://www.example.com/success"));
request.setReturnFailureUrl(new URL("http://www.example.com/failure"));
request.setReturnCancelUrl(new URL("http://www.example.com/cancel.html"));
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
request.setLifetime(60);
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
// Risk Params
request.setRiskUserId("123456");
// Transaction Types
request.addTransactionType("transaction_type").done();
request.setRememberCard("true");
request.setManagedRecurring("");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.wpf_create(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"description": "You are about to buy 3 shoes at www.shoes.com!",
"notification_url": "https://www.example.com/notification",
"return_success_url": "http://www.example.com/success",
"return_failure_url": "http://www.example.com/failure",
"return_cancel_url": "http://www.example.com/cancel.html",
"amount": "100",
"currency": "USD",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"lifetime": 60,
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"risk_params": {
"user_id": "123456"
},
"transaction_types": [
"transaction_type"
],
"remember_card": "true",
"managed_recurring": null
}
).send()
.then(success)
.catch(failure);
Request
curl https://staging.wpf.emerchantpay.net/wpf \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<wpf_payment>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<description>You are about to buy 3 shoes at www.shoes.com!</description>
<notification_url>https://www.example.com/notification</notification_url>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<return_cancel_url>http://www.example.com/cancel.html</return_cancel_url>
<amount>100</amount>
<currency>USD</currency>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<lifetime>60</lifetime>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<risk_params>
<user_id>123456</user_id>
</risk_params>
<transaction_types>
<transaction_type>
<name>init_recurring_sale</name>
<managed_recurring>
<mode>manual</mode>
<payment_type>subsequent</payment_type>
<amount_type>fixed</amount_type>
<frequency>weekly</frequency>
<registration_reference_number>123434</registration_reference_number>
<max_amount>200</max_amount>
<max_count>99</max_count>
<validated>true</validated>
</managed_recurring>
</transaction_type>
</transaction_types>
<remember_card>true</remember_card>
<wpf_payment>managed_recurring</wpf_payment>
</wpf_payment>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
managed_recurring | required | ||
mode | required | String | Fill in with 'manual'. This indicates that the merchant will manually manage the subsequent recurring transactions. |
payment_type | required | String | Type of the current recurring transaction. Values: initial, subsequent, modification, cancellation |
amount_type | required | String | Type of the amount. Values: fixed, max |
frequency | required | String | Frequency of the subsequent transactions. Values: daily, twice_weekly, weekly, ten_days, fortnightly, monthly, every_two_months, trimester, quarterly, twice_yearly, annually, unscheduled |
registration_reference_number | required | String(35) | Reference number as per the agreement. |
max_amount | required | Integer | Maximum amount as per the agreement. |
max_count | required | Integer | Maximum transactions count as per the agreement. 99 - indicates infinite subsequent payments. |
validated | required | String | Indicates if the current transaction is valid as per the registered agreement. Values: true, false |
required* = conditionally required
Authorize
With authorize transactions, you can confirm that a credit card is valid and reserve the desired amount on the card.
After settling the transaction (e.g. shipping the goods), you can then capture the amount. The customer will not be billed until the capture has taken place, but the amount is reserved and the customer’s credit card limit is reduced. Authorizes will automatically be cancelled after a certain timeframe, most likely one week.
For a typical e-commerce application it is recommended to authorize the amount on incoming orders and capture it when shipping the goods. If you are selling services or non-tangible goods, you can use the sale transaction, which combines authorize and capture.
If you choose not to serve the customer, consider to void the authorize to unfreeze the amount on the client’s credit card.
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Authorize');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('4200000000000000')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
// Account Owner
->setAccountFirstName('Travis')
->setAccountMiddleName('Joe')
->setAccountLastName('Pastrana');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.AuthorizeRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
AuthorizeRequest request = new AuthorizeRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4200000000000000");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
// Account Owner
request.setAccountFirstname("Travis");
request.setAccountMiddlename("Joe");
request.setAccountLastname("Pastrana");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.authorize(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "4200000000000000",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"business_attributes": {
"event_start_date": "17-02-2025",
"event_end_date": "26-02-2025",
"event_organizer_id": "20192375",
"event_id": "1912"
},
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"account_owner": {
"first_name": "Travis",
"middle_name": "Joe",
"last_name": "Pastrana"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>authorize</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4200000000000000</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<business_attributes>
<event_start_date>17-02-2025</event_start_date>
<event_end_date>26-02-2025</event_end_date>
<event_organizer_id>20192375</event_organizer_id>
<event_id>1912</event_id>
</business_attributes>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<account_owner>
<first_name>Travis</first_name>
<middle_name>Joe</middle_name>
<last_name>Pastrana</last_name>
</account_owner>
</payment_transaction>'
Funding Transaction Example
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<payment_transaction>transaction_type</payment_transaction>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4200000000000000</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<business_attributes>
<event_start_date>17-02-2025</event_start_date>
<event_end_date>26-02-2025</event_end_date>
<event_organizer_id>20192375</event_organizer_id>
<event_id>1912</event_id>
</business_attributes>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<account_owner>
<first_name>Travis</first_name>
<middle_name>Joe</middle_name>
<last_name>Pastrana</last_name>
</account_owner>
<funding>
<identifier_type>business_disbursement</identifier_type>
<receiver>
<first_name>Hamza</first_name>
<last_name>Arshad</last_name>
<country>AF</country>
<account_number>090078601</account_number>
<account_number_type>iban</account_number_type>
<address>Gulberg 21 street</address>
<state>CN</state>
<city>Lahore</city>
</receiver>
</funding>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: authorize |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
gaming | optional | "true" | Signifies whether a gaming transaction is performed. Gaming transactions usually use MCC 7995. Contact tech-support@emerchantpay.com for more details |
moto | optional | "true" | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech-support@emerchantpay.com for more details |
crypto | optional | "true" | Signifies whether a purchase of crypto-currency transaction is performed. Must be populated when purchasing crypto-currency with a VISA card. Must be populated when purchasing crypto-currency with a MASTER or INTL MAESTRO card and MCC is one of 6051, 6211. Contact tech-support@emerchantpay.com for more details |
preauthorization | optional | "true" | Signifies whether a preauthorization transaction is performed. Check the Preauthorizations section or contact tech support for more details. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
amount | required | integer >= 0 | Transaction amount in minor currency unit, see Currency and Amount Handling for details. In certain cases, it is possible to submit a transaction with a zero-value amount to act as an account verification transaction - Contact tech-support@emerchantpay.com for more details regarding this scenario. |
currency | required | string(3) | Currency code in ISO 4217 |
card_holder | required | string(255) | Full name of customer as printed on credit card (first name and last name at least) |
card_number | required | 13 to 16 digits | Complete cc number of customer |
cvv | required* | 3 to 4 digits | cvv of cc, requirement is based on terminal configuration |
expiration_month | required | MM | Expiration month as printed on credit card |
expiration_year | required | YYYY | Expiration year as printed on credit card |
token | optional | string(36) | See Tokenization for more details. If present, the cardholder parameters can be omitted. Cannot be set together with remember_card |
remember_card | optional | "true" | See Tokenize. Tokenizes cardholder parameters. Cannot be set together with token |
consumer_id | optional | string(10) | See Consumers and Tokenization. Combine with remember_card to tokenize or with token to use token |
scheme_tokenized | required* | "true" | Required when the card_number is DPAN instead of Funding Primary Account Number, see Tokenized e-commerce for details |
recurring_type | optional | string(255) | Specifies recurring type of the transaction, can be 'initial', 'managed' or 'subsequent'. |
installment_plan_id | optional | string | The ID of the chosen installment plan. Check Installments for more details. |
installment_plan_reference | optional | string | The installment plan reference identifier returned by the schemes. |
credential_on_file | required* | See Credential On File (COF) for more details | |
initial_customer_initiated | required* | string(18) | Initial transaction initiated by customer. Required for external tokenization, and optional for gateway-based tokenization |
subsequent_customer_initiated | required* | string(18) | Subsequent transaction initiated by customer. Required for external tokenization, and optional for gateway-based tokenization |
merchant_unscheduled | optional | string(20) | Transaction is initiated by the merchant |
credential_on_file_transaction_identifier | optional | string(15..32) | See Credential On File (COF) for more details |
credential_on_file_settlement_date | optional | string(4) | See Credential On File (COF) for more details |
customer_email | required* | e-mail address | Must contain valid e-mail of customer |
customer_phone | required* | string(32) | Must contain valid phone number of customer |
birth_date | required* | dd-mm-yyyy | Required when MCC is a Financial Services one (e.g. MCC 6012) and either card brand is Visa or Mastercard/Maestro with UK-based merchant, UK-based bin (domestic), and DEBIT card type |
document_id | required* | string(255) | Document ID value. |
fx_rate_id | optional | integer | See Get rates for FX Service. Offers the option to use a specific FX rate to convert the transaction processing amount. Used FX rate should have the same source currency as the processing currency. Contact tech-support@emerchantpay.com for more details |
business_attributes | required* | Check business attributes section. | |
event_start_date | required* | dd-mm-yyyy | The date when event starts in format dd-mm-yyyy |
event_end_date | required* | dd-mm-yyyy | The date when event ends in format dd-mm-yyyy |
event_organizer_id | required* | string | |
event_id | required* | string | |
date_of_order | required* | dd-mm-yyyy | The date when order was placed in format dd-mm-yyyy |
delivery_date | required* | dd-mm-yyyy | Date of the expected delivery in format dd-mm-yyyy |
name_of_the_supplier | required* | string | |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required* | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
neighborhood | optional | string(255) | Neighborhood |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
sca_params | optional | SCA params | |
exemption | optional | string | The exemption that the transaction should take advantage of. Note that the requested exemption may not be accepted due to internal risk validations. Check SCA exemption values. |
visa_merchant_id | required5 | string(8) | VMID assigned by Visa if participating in Trusted merchant program. |
funding | optional | Funding Transaction Params | |
identifier_type | required* | string | This is only required in case of Mastercard. Type of Funding Transaction. Please check Identifier Types |
business_application_identifier | required* | string | This is only required in case of VISA. Type of VISA Funding Transaction. Please check BAI |
receiver | optional | Funding Transaction Receiver details | |
first_name | required* | string | First name of the receiver |
last_name | required* | string | Last name of the receiver |
country | required* | string(2) | Country code in ISO 3166 |
account_number | required* | string | Receiver account number. Mandatory for Mastercard. If Sender Reference Number is provided then it becomes optional for VISA |
account_number_type | required* | string | This is only required in case of Mastercard. Receiver account number type. Please check Receiver Account Types |
address | required* | string | Receiver address. Only required in case of VISA and Canadian cards |
state | required* | string | Receiver state. Only required in case of VISA and Canadian cards |
city | required* | string | Receiver city. Only required in case of VISA and Canadian cards |
sender | optional | Funding Transaction Sender details | |
name | required* | string | Sender name. Only required in case of VISA |
reference_number | required* | string | Sender Reference Number. Only required in case of VISA. This is option if Receiver Account Number is provided |
country | required* | string | Sender country. Only required in case of VISA. If not provided billing address is used |
address | required* | string | Sender address. Only required in case of VISA. If not provided billing address is used |
state | required* | string | Sender state. Only required in case of VISA and Canadian card. If not provided billing address is used |
city | required* | string | Sender city. Only required in case of VISA. If not provided billing address is used |
account_owner | optional | Account owner parameters related to account owner inquiry requests | |
first_name | optional | string(35) | Account owner first name |
middle_name | optional | string(35) | Account owner middle name |
last_name | optional | string(35) | Account owner last name |
dynamic_descriptor_params | optional | ||
merchant_name | optional | string(25) | Allows to dynamically override the charge descriptor |
merchant_city | optional | string(13) | Allows to dynamically override the merchant phone number |
sub_merchant_id | optional | string(15) | Allows to dynamically override the sub-merchant ID. |
merchant_country | optional | string(3) | Allows to dynamically override the merchant country. |
merchant_state | optional | string(3) | Allows to dynamically override the merchant subdivision code. |
merchant_zip_code | optional | string(10) | Allows to dynamically override the merchant zip/postal code. Required for VISA OCT transactions with Australian and Canadian card bins. |
merchant_address | optional | string(48) | Allows to dynamically override the merchant address. |
merchant_url | optional | string(60) | Allows to dynamically override the merchant URL |
merchant_phone | optional | string(16) | Allows to dynamically override the merchant phone number. |
merchant_service_city | optional | string(13) | Allows to dynamically override the merchant service city. |
merchant_service_country | optional | string(3) | Allows to dynamically override the merchant service country. |
merchant_service_state | optional | string(3) | Allows to dynamically override the merchant service subdivision code. |
merchant_service_zip_code | optional | string(10) | Allows to dynamically override the merchant service zip/postal code. |
merchant_service_phone | optional | string(16) | Allows to dynamically override the merchant service phone number. |
merchant_geo_coordinates | optional | string(20) | Allows to dynamically override the merchant geographic coordinates. |
merchant_service_geo_coordinates | optional | string(20) | Allows to dynamically override the merchant service geographic coordinates. |
required* = conditionally required
Successful Response
stdClass Object
(
[transaction_type] => authorize
[status] => approved
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[consumer_id] => 123456
[token] => ee946db8-d7db-4bb7-b608-b65b153e127d
[avs_response_code] => 5I
[avs_response_text] => Response provided by issuer processor; Address information not verified
[cvv_result_code] => M
[authorization_code] => 345678
[retrieval_reference_number] => 016813015184
[payment_account_reference] => 50019P9LBXOLHN9G7QMU5VN520YSY
[response_code] => 00
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:45.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
[scheme_transaction_identifier] => 019091214161031
[scheme_transaction_link_id] => TLINKIDENTIFIER4521412
[scheme_pan_indicator] => V
[scheme_pan_tail] =>
[scheme_max_settlement_date] => 2024-07-31
[scheme_authentication_data_quality] => true
[scheme_settlement_date] => 0117
[scheme_response_code] => 00
[reason_for_not_honoring_exemption] => 8A01
[sca_exemption_result] => 13
[account_owner] => {"first_name"=>"Travis", "middle_name"=>"Joe", "last_name"=>"Pastrana"}
)
<payment_response content=[
<transaction_type content=[authorize]>
<status content=[approved]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<consumer_id content=[123456]>
<token content=[ee946db8-d7db-4bb7-b608-b65b153e127d]>
<avs_response_code content=[5I]>
<avs_response_text content=[Response provided by issuer processor; Address information not verified]>
<cvv_result_code content=[M]>
<authorization_code content=[345678]>
<retrieval_reference_number content=[016813015184]>
<payment_account_reference content=[50019P9LBXOLHN9G7QMU5VN520YSY]>
<response_code content=[00]>
<timestamp content=[2025-01-16T10:23:45Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[true]>
<scheme_transaction_identifier content=[019091214161031]>
<scheme_transaction_link_id content=[TLINKIDENTIFIER4521412]>
<scheme_pan_indicator content=[V]>
<scheme_pan_tail content=[]>
<scheme_max_settlement_date content=[2024-07-31]>
<scheme_authentication_data_quality content=[true]>
<scheme_settlement_date content=[0117]>
<scheme_response_code content=[00]>
<reason_for_not_honoring_exemption content=[8A01]>
<sca_exemption_result content=[13]>
<account_owner content=[{"first_name"=>"Travis", "middle_name"=>"Joe", "last_name"=>"Pastrana"}]>
]>
{
transaction_type: "authorize",
status: "approved",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
consumer_id: "123456",
token: "ee946db8-d7db-4bb7-b608-b65b153e127d",
avs_response_code: "5I",
avs_response_text: "Response provided by issuer processor; Address information not verified",
cvv_result_code: "M",
authorization_code: "345678",
retrieval_reference_number: "016813015184",
payment_account_reference: "50019P9LBXOLHN9G7QMU5VN520YSY",
response_code: "00",
timestamp: "2025-01-16T10:23:45Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "true",
scheme_transaction_identifier: "019091214161031",
scheme_transaction_link_id: "TLINKIDENTIFIER4521412",
scheme_pan_indicator: "V",
scheme_pan_tail: "",
scheme_max_settlement_date: "2024-07-31",
scheme_authentication_data_quality: "true",
scheme_settlement_date: "0117",
scheme_response_code: "00",
reason_for_not_honoring_exemption: "8A01",
sca_exemption_result: "13",
account_owner: "{"first_name"=>"Travis", "middle_name"=>"Joe", "last_name"=>"Pastrana"}",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>authorize</transaction_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<consumer_id>123456</consumer_id>
<token>ee946db8-d7db-4bb7-b608-b65b153e127d</token>
<avs_response_code>5I</avs_response_code>
<avs_response_text>Response provided by issuer processor; Address information not verified</avs_response_text>
<cvv_result_code>M</cvv_result_code>
<authorization_code>345678</authorization_code>
<retrieval_reference_number>016813015184</retrieval_reference_number>
<payment_account_reference>50019P9LBXOLHN9G7QMU5VN520YSY</payment_account_reference>
<response_code>00</response_code>
<timestamp>2025-01-16T10:23:45Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
<scheme_transaction_identifier>019091214161031</scheme_transaction_identifier>
<scheme_transaction_link_id>TLINKIDENTIFIER4521412</scheme_transaction_link_id>
<scheme_pan_indicator>V</scheme_pan_indicator>
<payment_response>scheme_pan_tail</payment_response>
<scheme_max_settlement_date>2024-07-31</scheme_max_settlement_date>
<scheme_authentication_data_quality>true</scheme_authentication_data_quality>
<scheme_settlement_date>0117</scheme_settlement_date>
<scheme_response_code>00</scheme_response_code>
<reason_for_not_honoring_exemption>8A01</reason_for_not_honoring_exemption>
<sca_exemption_result>13</sca_exemption_result>
<account_owner>
<first_name>Travis</first_name>
<middle_name>Joe</middle_name>
<last_name>Pastrana</last_name>
</account_owner>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
consumer_id | string(10) | Consumer unique reference. See Consumers |
token | string(36) | Plain-text token value. See Tokenization |
gaming | 'true' | Signifies whether a gaming transaction is performed. Gaming transactions usually use MCC 7995, contact tech support for more details. |
moto | 'true' | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech support for more details. |
avs_response_code | string(255) | Generated by the card network on trying to match the billing address when performing the address verification. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
avs_response_text | string(255) | Gives the human response text for the AVS response code above. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
cvv_result_code | string(1) | Card Verification Value response code. Optional, returned only if acquirer supports it |
authorization_code | string(6) | Generated by the card network when an authorisation has occurred, used to identify that auth. Consists of 6 alphanumeric chars |
retrieval_reference_number | string(255) | A reference number used for tracking all messages related to a given cardholder transaction returned by some acquirers. |
payment_account_reference | string(255) | Payment Account Reference value returned from the schemes. Links tokenized and PAN-based transactions. |
response_code | string(2) | Defines the result of a transaction with the acquirer, the status of a message or some action taken or required. Contact tech-support@emerchantpay.com for more details. |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
partial_approval | string(4) | Optional, set to ’true’ if partial approval happened. Partially approved amount is then in the amount field. Check Partial Approvals for details |
sent_to_acquirer | string(255) | "true" or "false" |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
scheme_transaction_identifier | string(32) | Id defined by card schemes. Corresponds to NETWORK DATA (field 63) for MasterCard or TRANS ID (field 62.2/125) for VISA. |
scheme_transaction_link_id | string(22) | The transaction unique identifier returned from the schemes. Corresponds to ADDITIONAL SERVICE DATA (field 65, MasterCard Transaction Link Id [TLID]). |
scheme_pan_indicator | string(1) | The account number indicator in scheme-tokenized transactions. See Account number indicator codes for details. |
scheme_pan_tail | string(4) | The tail of the PAN number tail associated with the token in scheme-tokenized transactions. Returned in conjunction with scheme_pan_indicator . |
scheme_max_settlement_date | string(10) | The final date an authorization could be captured which is returned from the card scheme. See Scheme Maximum Settlement Date for more details. |
scheme_authentication_data_quality | boolean | The Authentication Data Quality Indicator returned by the card scheme is used to indicate whether a transaction meets the authentication data quality requirements. The value can be either true or false . |
scheme_settlement_date | string(4) | MasterCard settlement date in MMDD format (e.g. 0117). Corresponds to NETWORK DATA (field 15). |
scheme_response_code | string(2) | The response code returned from the schemes. See Scheme response codes for details. |
recurring_advice_code | string(2) | Additional response code returned from the schemes. See Recurring advice details |
recurring_advice_text | string(255) | The text representation of the recurring advice code. |
reason_for_not_honoring_exemption | string | Reason for not honoring exemption. Check SCA Reason For Not Honoring Exemption Values. |
sca_exemption_result | string | SCA exemption result. Check SCA Exemption Result Values. |
Error Response
stdClass Object
(
[transaction_type] => authorize
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 340
[technical_message] => expiration_year is invalid
[message] => expiration_year is invalid
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:45.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => false
)
<payment_response content=[
<transaction_type content=[authorize]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<code content=[340]>
<technical_message content=[expiration_year is invalid]>
<message content=[expiration_year is invalid]>
<timestamp content=[2025-01-16T10:23:45Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[false]>
]>
{
transaction_type: "authorize",
status: "error",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
code: "340",
technical_message: "expiration_year is invalid",
message: "expiration_year is invalid",
timestamp: "2025-01-16T10:23:45Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "false",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>authorize</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>340</code>
<technical_message>expiration_year is invalid</technical_message>
<message>expiration_year is invalid</message>
<timestamp>2025-01-16T10:23:45Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
gaming | 'true' | Signifies whether a gaming transaction is performed. Gaming transactions usually use MCC 7995, contact tech support for more details. |
moto | 'true' | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech support for more details. |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
Capture
Capture settles a transaction which has been authorized before.
Do this when you are shipping goods, for example. A capture can only be used after an authorize on the same transaction and on the same terminal.
Therefore, the reference id of the authorized transaction is mandatory.
Transaction workflow:
- The merchant sends authorize transaction to the gateway.
- The gateway replies to it. One of returned values is the unique id of the transaction.
- The merchant sends capture transaction. Its reference id is unique id of authorize response.
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Capture');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReferenceId('43672')
->setAmount('100')
->setCurrency('USD');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.CaptureRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
CaptureRequest request = new CaptureRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setReferenceId("43672");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.capture(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"reference_id": "43672",
"amount": "100",
"currency": "USD",
"business_attributes": {
"event_start_date": "17-02-2025",
"event_end_date": "26-02-2025",
"event_organizer_id": "20192375",
"event_id": "1912"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>capture</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<reference_id>43672</reference_id>
<amount>100</amount>
<currency>USD</currency>
<business_attributes>
<event_start_date>17-02-2025</event_start_date>
<event_end_date>26-02-2025</event_end_date>
<event_organizer_id>20192375</event_organizer_id>
<event_id>1912</event_id>
</business_attributes>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: capture |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
reference_id | required | string(32) | Unique id returned by corresponding transaction |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
business_attributes | required* | Check business attributes section. | |
event_start_date | required* | dd-mm-yyyy | The date when event starts in format dd-mm-yyyy |
event_end_date | required* | dd-mm-yyyy | The date when event ends in format dd-mm-yyyy |
event_organizer_id | required* | string | |
event_id | required* | string | |
date_of_order | required* | dd-mm-yyyy | The date when order was placed in format dd-mm-yyyy |
delivery_date | required* | dd-mm-yyyy | Date of the expected delivery in format dd-mm-yyyy |
name_of_the_supplier | required* | string |
required* = conditionally required
Successful Response
stdClass Object
(
[transaction_type] => capture
[status] => approved
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[authorization_code] => 345678
[response_code] => 00
[technical_message] => Transaction successful!
[message] => Transaction successful!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:45.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[capture]>
<status content=[approved]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<authorization_code content=[345678]>
<response_code content=[00]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<timestamp content=[2025-01-16T10:23:45Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "capture",
status: "approved",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
authorization_code: "345678",
response_code: "00",
technical_message: "Transaction successful!",
message: "Transaction successful!",
timestamp: "2025-01-16T10:23:45Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>capture</transaction_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<authorization_code>345678</authorization_code>
<response_code>00</response_code>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:45Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
authorization_code | string(6) | Generated by the card network when an authorisation has occurred, used to identify that auth. Consists of 6 alphanumeric chars |
response_code | string(2) | Defines the result of a transaction with the acquirer, the status of a message or some action taken or required. Contact tech-support@emerchantpay.com for more details. |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => capture
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 430
[technical_message] => Reference transaction has already been captured, and acquirer does not support partial/multiple capture
[message] => Transaction declined.
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:45.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => false
)
<payment_response content=[
<transaction_type content=[capture]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<code content=[430]>
<technical_message content=[Reference transaction has already been captured, and acquirer does not support partial/multiple capture]>
<message content=[Transaction declined.]>
<timestamp content=[2025-01-16T10:23:45Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[false]>
]>
{
transaction_type: "capture",
status: "error",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
code: "430",
technical_message: "Reference transaction has already been captured, and acquirer does not support partial/multiple capture",
message: "Transaction declined.",
timestamp: "2025-01-16T10:23:45Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "false",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>capture</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>430</code>
<technical_message>Reference transaction has already been captured, and acquirer does not support partial/multiple capture</technical_message>
<message>Transaction declined.</message>
<timestamp>2025-01-16T10:23:45Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Sale
Sale transactions combine authorize and capture into one step.
Using a sale transaction, the amount is immediately billed to the customer’s credit card. It can be reversed via a void transaction on the same day of the transaction. Use sale transactions, if you are e.g. selling non-tangible goods or services.
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Sale');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('4200000000000000')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
// Account Owner
->setAccountFirstName('Travis')
->setAccountMiddleName('Joe')
->setAccountLastName('Pastrana');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.SaleRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
SaleRequest request = new SaleRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4200000000000000");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
// Account Owner
request.setAccountFirstname("Travis");
request.setAccountMiddlename("Joe");
request.setAccountLastname("Pastrana");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.sale(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "4200000000000000",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"business_attributes": {
"event_start_date": "17-02-2025",
"event_end_date": "26-02-2025",
"event_organizer_id": "20192375",
"event_id": "1912"
},
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"account_owner": {
"first_name": "Travis",
"middle_name": "Joe",
"last_name": "Pastrana"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>sale</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4200000000000000</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<business_attributes>
<event_start_date>17-02-2025</event_start_date>
<event_end_date>26-02-2025</event_end_date>
<event_organizer_id>20192375</event_organizer_id>
<event_id>1912</event_id>
</business_attributes>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<account_owner>
<first_name>Travis</first_name>
<middle_name>Joe</middle_name>
<last_name>Pastrana</last_name>
</account_owner>
</payment_transaction>'
Funding Transaction Example
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<payment_transaction>transaction_type</payment_transaction>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4200000000000000</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<business_attributes>
<event_start_date>17-02-2025</event_start_date>
<event_end_date>26-02-2025</event_end_date>
<event_organizer_id>20192375</event_organizer_id>
<event_id>1912</event_id>
</business_attributes>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<account_owner>
<first_name>Travis</first_name>
<middle_name>Joe</middle_name>
<last_name>Pastrana</last_name>
</account_owner>
<funding>
<identifier_type>business_disbursement</identifier_type>
<receiver>
<first_name>Hamza</first_name>
<last_name>Arshad</last_name>
<country>AF</country>
<account_number>090078601</account_number>
<account_number_type>iban</account_number_type>
<address>Gulberg 21 street</address>
<state>CN</state>
<city>Lahore</city>
</receiver>
</funding>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: sale |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
gaming | optional | "true" | Signifies whether a gaming transaction is performed. Gaming transactions usually use MCC 7995. Contact tech-support@emerchantpay.com for more details |
moto | optional | "true" | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech-support@emerchantpay.com for more details |
crypto | optional | "true" | Signifies whether a purchase of crypto-currency transaction is performed. Must be populated when purchasing crypto-currency with a VISA card. Must be populated when purchasing crypto-currency with a MASTER or INTL MAESTRO card and MCC is one of 6051, 6211. Contact tech-support@emerchantpay.com for more details |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
amount | required | integer >= 0 | Transaction amount in minor currency unit, see Currency and Amount Handling for details. In certain cases, it is possible to submit a transaction with a zero-value amount to act as an account verification transaction - Contact tech-support@emerchantpay.com for more details regarding this scenario. |
currency | required | string(3) | Currency code in ISO 4217 |
card_holder | required | string(255) | Full name of customer as printed on credit card (first name and last name at least) |
card_number | required | 13 to 16 digits | Complete cc number of customer |
cvv | required* | 3 to 4 digits | cvv of cc, requirement is based on terminal configuration |
expiration_month | required | MM | Expiration month as printed on credit card |
expiration_year | required | YYYY | Expiration year as printed on credit card |
token | optional | string(36) | See Tokenization for more details. If present, the cardholder parameters can be omitted. Cannot be set together with remember_card |
remember_card | optional | "true" | See Tokenize. Tokenizes cardholder parameters. Cannot be set together with token |
consumer_id | optional | string(10) | See Consumers and Tokenization. Combine with remember_card to tokenize or with token to use token |
scheme_tokenized | required* | "true" | Required when the card_number is DPAN instead of Funding Primary Account Number, see Tokenized e-commerce for details |
recurring_type | optional | string(255) | Specifies recurring type of the transaction, can be 'initial', 'managed' or 'subsequent'. |
reference_id | optional | string(32) | Unique id returned by corresponding transaction |
installment_plan_id | optional | string | The ID of the chosen installment plan. Check Installments for more details. |
installment_plan_reference | optional | string | The installment plan reference identifier returned by the schemes. |
credential_on_file | required* | See Credential On File (COF) for more details | |
initial_customer_initiated | required* | string(18) | Initial transaction initiated by customer. Required for external tokenization, and optional for gateway-based tokenization |
subsequent_customer_initiated | required* | string(18) | Subsequent transaction initiated by customer. Required for external tokenization, and optional for gateway-based tokenization |
merchant_unscheduled | optional | string(20) | Transaction is initiated by the merchant |
credential_on_file_transaction_identifier | optional | string(15..32) | See Credential On File (COF) for more details |
credential_on_file_settlement_date | optional | string(4) | See Credential On File (COF) for more details |
customer_email | required* | e-mail address | Must contain valid e-mail of customer |
customer_phone | required* | string(32) | Must contain valid phone number of customer |
birth_date | required* | dd-mm-yyyy | Required when MCC is a Financial Services one (e.g. MCC 6012) and either card brand is Visa or Mastercard/Maestro with UK-based merchant, UK-based bin (domestic), and DEBIT card type |
document_id | required* | string(255) | Document ID value. |
fx_rate_id | optional | integer | See Get rates for FX Service. Offers the option to use a specific FX rate to convert the transaction processing amount. Used FX rate should have the same source currency as the processing currency. Contact tech-support@emerchantpay.com for more details |
business_attributes | required* | Check business attributes section. | |
event_start_date | required* | dd-mm-yyyy | The date when event starts in format dd-mm-yyyy |
event_end_date | required* | dd-mm-yyyy | The date when event ends in format dd-mm-yyyy |
event_organizer_id | required* | string | |
event_id | required* | string | |
date_of_order | required* | dd-mm-yyyy | The date when order was placed in format dd-mm-yyyy |
delivery_date | required* | dd-mm-yyyy | Date of the expected delivery in format dd-mm-yyyy |
name_of_the_supplier | required* | string | |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required* | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
neighborhood | optional | string(255) | Neighborhood |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
sca_params | optional | SCA params | |
exemption | optional | string | The exemption that the transaction should take advantage of. Note that the requested exemption may not be accepted due to internal risk validations. Check SCA exemption values. |
visa_merchant_id | required5 | string(8) | VMID assigned by Visa if participating in Trusted merchant program. |
funding | optional | Funding Transaction Params | |
identifier_type | required* | string | This is only required in case of Mastercard. Type of Funding Transaction. Please check Identifier Types |
business_application_identifier | required* | string | This is only required in case of VISA. Type of VISA Funding Transaction. Please check BAI |
receiver | optional | Funding Transaction Receiver details | |
first_name | required* | string | First name of the receiver |
last_name | required* | string | Last name of the receiver |
country | required* | string(2) | Country code in ISO 3166 |
account_number | required* | string | Receiver account number. Mandatory for Mastercard. If Sender Reference Number is provided then it becomes optional for VISA |
account_number_type | required* | string | This is only required in case of Mastercard. Receiver account number type. Please check Receiver Account Types |
address | required* | string | Receiver address. Only required in case of VISA and Canadian cards |
state | required* | string | Receiver state. Only required in case of VISA and Canadian cards |
city | required* | string | Receiver city. Only required in case of VISA and Canadian cards |
sender | optional | Funding Transaction Sender details | |
name | required* | string | Sender name. Only required in case of VISA |
reference_number | required* | string | Sender Reference Number. Only required in case of VISA. This is option if Receiver Account Number is provided |
country | required* | string | Sender country. Only required in case of VISA. If not provided billing address is used |
address | required* | string | Sender address. Only required in case of VISA. If not provided billing address is used |
state | required* | string | Sender state. Only required in case of VISA and Canadian card. If not provided billing address is used |
city | required* | string | Sender city. Only required in case of VISA. If not provided billing address is used |
account_owner | optional | Account owner parameters related to account owner inquiry requests | |
first_name | optional | string(35) | Account owner first name |
middle_name | optional | string(35) | Account owner middle name |
last_name | optional | string(35) | Account owner last name |
dynamic_descriptor_params | optional | ||
merchant_name | optional | string(25) | Allows to dynamically override the charge descriptor |
merchant_city | optional | string(13) | Allows to dynamically override the merchant phone number |
sub_merchant_id | optional | string(15) | Allows to dynamically override the sub-merchant ID. |
merchant_country | optional | string(3) | Allows to dynamically override the merchant country. |
merchant_state | optional | string(3) | Allows to dynamically override the merchant subdivision code. |
merchant_zip_code | optional | string(10) | Allows to dynamically override the merchant zip/postal code. Required for VISA OCT transactions with Australian and Canadian card bins. |
merchant_address | optional | string(48) | Allows to dynamically override the merchant address. |
merchant_url | optional | string(60) | Allows to dynamically override the merchant URL |
merchant_phone | optional | string(16) | Allows to dynamically override the merchant phone number. |
merchant_service_city | optional | string(13) | Allows to dynamically override the merchant service city. |
merchant_service_country | optional | string(3) | Allows to dynamically override the merchant service country. |
merchant_service_state | optional | string(3) | Allows to dynamically override the merchant service subdivision code. |
merchant_service_zip_code | optional | string(10) | Allows to dynamically override the merchant service zip/postal code. |
merchant_service_phone | optional | string(16) | Allows to dynamically override the merchant service phone number. |
merchant_geo_coordinates | optional | string(20) | Allows to dynamically override the merchant geographic coordinates. |
merchant_service_geo_coordinates | optional | string(20) | Allows to dynamically override the merchant service geographic coordinates. |
required* = conditionally required
Successful Response
stdClass Object
(
[transaction_type] => sale
[status] => approved
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[consumer_id] => 123456
[token] => ee946db8-d7db-4bb7-b608-b65b153e127d
[avs_response_code] => 5I
[avs_response_text] => Response provided by issuer processor; Address information not verified
[cvv_result_code] => M
[authorization_code] => 345678
[retrieval_reference_number] => 016813015184
[payment_account_reference] => 50019P9LBXOLHN9G7QMU5VN520YSY
[response_code] => 00
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:45.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
[scheme_transaction_identifier] => 019091214161031
[scheme_transaction_link_id] => TLINKIDENTIFIER4521412
[scheme_pan_indicator] => V
[scheme_pan_tail] =>
[scheme_max_settlement_date] => 2024-07-31
[scheme_authentication_data_quality] => true
[scheme_settlement_date] => 0117
[scheme_response_code] => 00
[reason_for_not_honoring_exemption] => 8A01
[sca_exemption_result] => 13
[account_owner] => {"first_name"=>"Travis", "middle_name"=>"Joe", "last_name"=>"Pastrana"}
)
<payment_response content=[
<transaction_type content=[sale]>
<status content=[approved]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<consumer_id content=[123456]>
<token content=[ee946db8-d7db-4bb7-b608-b65b153e127d]>
<avs_response_code content=[5I]>
<avs_response_text content=[Response provided by issuer processor; Address information not verified]>
<cvv_result_code content=[M]>
<authorization_code content=[345678]>
<retrieval_reference_number content=[016813015184]>
<payment_account_reference content=[50019P9LBXOLHN9G7QMU5VN520YSY]>
<response_code content=[00]>
<timestamp content=[2025-01-16T10:23:45Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[true]>
<scheme_transaction_identifier content=[019091214161031]>
<scheme_transaction_link_id content=[TLINKIDENTIFIER4521412]>
<scheme_pan_indicator content=[V]>
<scheme_pan_tail content=[]>
<scheme_max_settlement_date content=[2024-07-31]>
<scheme_authentication_data_quality content=[true]>
<scheme_settlement_date content=[0117]>
<scheme_response_code content=[00]>
<reason_for_not_honoring_exemption content=[8A01]>
<sca_exemption_result content=[13]>
<account_owner content=[{"first_name"=>"Travis", "middle_name"=>"Joe", "last_name"=>"Pastrana"}]>
]>
{
transaction_type: "sale",
status: "approved",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
consumer_id: "123456",
token: "ee946db8-d7db-4bb7-b608-b65b153e127d",
avs_response_code: "5I",
avs_response_text: "Response provided by issuer processor; Address information not verified",
cvv_result_code: "M",
authorization_code: "345678",
retrieval_reference_number: "016813015184",
payment_account_reference: "50019P9LBXOLHN9G7QMU5VN520YSY",
response_code: "00",
timestamp: "2025-01-16T10:23:45Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "true",
scheme_transaction_identifier: "019091214161031",
scheme_transaction_link_id: "TLINKIDENTIFIER4521412",
scheme_pan_indicator: "V",
scheme_pan_tail: "",
scheme_max_settlement_date: "2024-07-31",
scheme_authentication_data_quality: "true",
scheme_settlement_date: "0117",
scheme_response_code: "00",
reason_for_not_honoring_exemption: "8A01",
sca_exemption_result: "13",
account_owner: "{"first_name"=>"Travis", "middle_name"=>"Joe", "last_name"=>"Pastrana"}",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>sale</transaction_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<consumer_id>123456</consumer_id>
<token>ee946db8-d7db-4bb7-b608-b65b153e127d</token>
<avs_response_code>5I</avs_response_code>
<avs_response_text>Response provided by issuer processor; Address information not verified</avs_response_text>
<cvv_result_code>M</cvv_result_code>
<authorization_code>345678</authorization_code>
<retrieval_reference_number>016813015184</retrieval_reference_number>
<payment_account_reference>50019P9LBXOLHN9G7QMU5VN520YSY</payment_account_reference>
<response_code>00</response_code>
<timestamp>2025-01-16T10:23:45Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
<scheme_transaction_identifier>019091214161031</scheme_transaction_identifier>
<scheme_transaction_link_id>TLINKIDENTIFIER4521412</scheme_transaction_link_id>
<scheme_pan_indicator>V</scheme_pan_indicator>
<payment_response>scheme_pan_tail</payment_response>
<scheme_max_settlement_date>2024-07-31</scheme_max_settlement_date>
<scheme_authentication_data_quality>true</scheme_authentication_data_quality>
<scheme_settlement_date>0117</scheme_settlement_date>
<scheme_response_code>00</scheme_response_code>
<reason_for_not_honoring_exemption>8A01</reason_for_not_honoring_exemption>
<sca_exemption_result>13</sca_exemption_result>
<account_owner>
<first_name>Travis</first_name>
<middle_name>Joe</middle_name>
<last_name>Pastrana</last_name>
</account_owner>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
consumer_id | string(10) | Consumer unique reference. See Consumers |
token | string(36) | Plain-text token value. See Tokenization |
gaming | 'true' | Signifies whether a gaming transaction is performed. Gaming transactions usually use MCC 7995, contact tech support for more details. |
moto | 'true' | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech support for more details. |
avs_response_code | string(255) | Generated by the card network on trying to match the billing address when performing the address verification. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
avs_response_text | string(255) | Gives the human response text for the AVS response code above. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
cvv_result_code | string(1) | Card Verification Value response code. Optional, returned only if acquirer supports it |
authorization_code | string(6) | Generated by the card network when an authorisation has occurred, used to identify that auth. Consists of 6 alphanumeric chars |
retrieval_reference_number | string(255) | A reference number used for tracking all messages related to a given cardholder transaction returned by some acquirers. |
payment_account_reference | string(255) | Payment Account Reference value returned from the schemes. Links tokenized and PAN-based transactions. |
response_code | string(2) | Defines the result of a transaction with the acquirer, the status of a message or some action taken or required. Contact tech-support@emerchantpay.com for more details. |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
partial_approval | string(4) | Optional, set to ’true’ if partial approval happened. Partially approved amount is then in the amount field. Check Partial Approvals for details |
sent_to_acquirer | string(255) | "true" or "false" |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
scheme_transaction_identifier | string(32) | Id defined by card schemes. Corresponds to NETWORK DATA (field 63) for MasterCard or TRANS ID (field 62.2/125) for VISA. |
scheme_transaction_link_id | string(22) | The transaction unique identifier returned from the schemes. Corresponds to ADDITIONAL SERVICE DATA (field 65, MasterCard Transaction Link Id [TLID]). |
scheme_pan_indicator | string(1) | The account number indicator in scheme-tokenized transactions. See Account number indicator codes for details. |
scheme_pan_tail | string(4) | The tail of the PAN number tail associated with the token in scheme-tokenized transactions. Returned in conjunction with scheme_pan_indicator . |
scheme_max_settlement_date | string(10) | The final date an authorization could be captured which is returned from the card scheme. See Scheme Maximum Settlement Date for more details. |
scheme_authentication_data_quality | boolean | The Authentication Data Quality Indicator returned by the card scheme is used to indicate whether a transaction meets the authentication data quality requirements. The value can be either true or false . |
scheme_settlement_date | string(4) | MasterCard settlement date in MMDD format (e.g. 0117). Corresponds to NETWORK DATA (field 15). |
scheme_response_code | string(2) | The response code returned from the schemes. See Scheme response codes for details. |
recurring_advice_code | string(2) | Additional response code returned from the schemes. See Recurring advice details |
recurring_advice_text | string(255) | The text representation of the recurring advice code. |
reason_for_not_honoring_exemption | string | Reason for not honoring exemption. Check SCA Reason For Not Honoring Exemption Values. |
sca_exemption_result | string | SCA exemption result. Check SCA Exemption Result Values. |
Error Response
stdClass Object
(
[transaction_type] => sale
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[response_code] => 57
[code] => 340
[technical_message] => billing_address[zip_code] is invalid!
[message] => billing_address[zip_code] is invalid!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:45.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => false
)
<payment_response content=[
<transaction_type content=[sale]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<response_code content=[57]>
<code content=[340]>
<technical_message content=[billing_address[zip_code] is invalid!]>
<message content=[billing_address[zip_code] is invalid!]>
<timestamp content=[2025-01-16T10:23:45Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[false]>
]>
{
transaction_type: "sale",
status: "error",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
response_code: "57",
code: "340",
technical_message: "billing_address[zip_code] is invalid!",
message: "billing_address[zip_code] is invalid!",
timestamp: "2025-01-16T10:23:45Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "false",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>sale</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<response_code>57</response_code>
<code>340</code>
<technical_message>billing_address[zip_code] is invalid!</technical_message>
<message>billing_address[zip_code] is invalid!</message>
<timestamp>2025-01-16T10:23:45Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
gaming | 'true' | Signifies whether a gaming transaction is performed. Gaming transactions usually use MCC 7995, contact tech support for more details. |
moto | 'true' | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech support for more details. |
response_code | string(2) | Defines the result of a transaction with the acquirer, the status of a message or some action taken or required. Contact tech-support@emerchantpay.com for more details. |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
Argencard
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Argencard');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setAmount('100')
->setCurrency('USD')
->setConsumerReference('barney_rumble')
->setNationalId('8812128812')
->setBirthDate('30-12-1992')
->setCustomerEmail('barney@example.com')
// Billing Address
->setBillingFirstName('Barney')
->setBillingLastName('Rubble')
->setBillingAddress1('14, Nerazdelni str')
->setBillingZipCode('1407')
->setBillingCity('Buenos Aires')
->setBillingNeighborhood('Recoleta')
->setBillingCountry('AR')
// Risk Params
->setRiskUserId('123456');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>argencard</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<amount>100</amount>
<currency>USD</currency>
<consumer_reference>barney_rumble</consumer_reference>
<national_id>8812128812</national_id>
<birth_date>30-12-1992</birth_date>
<customer_email>barney@example.com</customer_email>
<billing_address>
<first_name>Barney</first_name>
<last_name>Rubble</last_name>
<address1>14, Nerazdelni str</address1>
<zip_code>1407</zip_code>
<city>Buenos Aires</city>
<neighborhood>Recoleta</neighborhood>
<country>AR</country>
</billing_address>
<risk_params>
<user_id>123456</user_id>
</risk_params>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: argencard |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
consumer_reference | required | string(20) | Consumer reference is a unique consumer identifier |
national_id | required | string(20) | National Identifier number of the customer |
birth_date | optional | dd-mm-yyyy | Required for Visa only when MCC is a Financial Services one (e.g. MCC 6012) |
customer_email | required | e-mail address | Must contain valid e-mail of customer |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
neighborhood | optional | string(255) | Neighborhood |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported countries:
Country |
---|
AR |
Successful Response
stdClass Object
(
[transaction_type] => argencard
[status] => pending_async
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[technical_message] => Transaction successful!
[message] => Transaction successful!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:46.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>argencard</transaction_type>
<status>pending_async</status>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:46Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => argencard
[status] => error
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 110
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:46.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>argencard</transaction_type>
<status>error</status>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:46Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Aura
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Aura');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setAmount('100')
->setCurrency('USD')
->setConsumerReference('barney_rumble')
->setNationalId('8812128812')
->setBirthDate('30-12-1992')
->setCustomerEmail('barney@example.com')
// Billing Address
->setBillingFirstName('Barney')
->setBillingLastName('Rubble')
->setBillingAddress1('14, Nerazdelni str')
->setBillingZipCode('1407')
->setBillingCity('Salvador')
->setBillingNeighborhood('Historic Center of Salvador')
->setBillingCountry('BR')
// Risk Params
->setRiskUserId('123456');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>aura</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<amount>100</amount>
<currency>USD</currency>
<consumer_reference>barney_rumble</consumer_reference>
<national_id>8812128812</national_id>
<birth_date>30-12-1992</birth_date>
<customer_email>barney@example.com</customer_email>
<billing_address>
<first_name>Barney</first_name>
<last_name>Rubble</last_name>
<address1>14, Nerazdelni str</address1>
<zip_code>1407</zip_code>
<city>Salvador</city>
<neighborhood>Historic Center of Salvador</neighborhood>
<country>BR</country>
</billing_address>
<risk_params>
<user_id>123456</user_id>
</risk_params>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: aura |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
consumer_reference | required | string(20) | Consumer reference is a unique consumer identifier |
national_id | required | string(20) | National Identifier number of the customer |
birth_date | optional | dd-mm-yyyy | Required for Visa only when MCC is a Financial Services one (e.g. MCC 6012) |
customer_email | required | e-mail address | Must contain valid e-mail of customer |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
neighborhood | optional | string(255) | Neighborhood |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported countries:
Country |
---|
BR |
Successful Response
stdClass Object
(
[transaction_type] => aura
[status] => pending_async
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[technical_message] => Transaction successful!
[message] => Transaction successful!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:46.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>aura</transaction_type>
<status>pending_async</status>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:46Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => aura
[status] => error
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 110
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:46.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>aura</transaction_type>
<status>error</status>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:46Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Bancontact
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>bcmc</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<amount>100</amount>
<currency>EUR</currency>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>12114</zip_code>
<city>Brussels</city>
<neighborhood>City Center</neighborhood>
<country>BE</country>
</billing_address>
</payment_transaction>'
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Alternatives\PPRO');
$request = $genesis->request();
$request
->setPaymentType('bcmc')
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setAmount('100')
->setCurrency('EUR')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('12114')
->setBillingCity('Brussels')
->setBillingNeighborhood('City Center')
->setBillingCountry('BE');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.apm.PProRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
PProRequest request = new PProRequest();
request.setPaymentType("bcmc");
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setReturnSuccessUrl(new URL("http://www.example.com/success"));
request.setReturnFailureUrl(new URL("http://www.example.com/failure"));
request.setAmount(new BigDecimal(100));
request.setCurrency("EUR");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("12114");
request.setBillingCity("Brussels");
request.setBillingNeighborhood("City Center");
request.setBillingCountry("BE");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.ppro(
{
"payment_type": "bcmc",
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"return_success_url": "http://www.example.com/success",
"return_failure_url": "http://www.example.com/failure",
"amount": "100",
"currency": "EUR",
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "12114",
"city": "Brussels",
"neighborhood": "City Center",
"country": "BE"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>ppro</transaction_type>
<payment_type>bcmc</payment_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<amount>100</amount>
<currency>EUR</currency>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>12114</zip_code>
<city>Brussels</city>
<neighborhood>City Center</neighborhood>
<country>BE</country>
</billing_address>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | ppro or bcmc. Contact tech support at tech-support@emerchantpay.com for more details. |
payment_type | required* | bcmc | Bancontact Mr. Cash. Contact tech support for more details |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
neighborhood | optional | string(255) | Neighborhood |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported currencies and countries:
Currency code | Country code |
---|---|
EUR | BE |
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>bcmc</transaction_type>
<status>pending_async</status>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<transaction_id>119643250547501c79d8295</transaction_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<mode>live</mode>
<timestamp>2025-01-16T10:23:46Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>EUR</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response
stdClass Object
(
[transaction_type] => ppro
[status] => pending_async
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[transaction_id] => 119643250547501c79d8295
[technical_message] => Transaction successful!
[message] => Transaction successful!
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[mode] => live
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:46.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => EUR
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[ppro]>
<status content=[pending_async]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<transaction_id content=[119643250547501c79d8295]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<redirect_url content=[https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61]>
<mode content=[live]>
<timestamp content=[2025-01-16T10:23:46Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[EUR]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "ppro",
status: "pending_async",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
transaction_id: "119643250547501c79d8295",
technical_message: "Transaction successful!",
message: "Transaction successful!",
redirect_url: "https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61",
mode: "live",
timestamp: "2025-01-16T10:23:46Z",
descriptor: "Descriptor one",
amount: "100",
currency: "EUR",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>ppro</transaction_type>
<status>pending_async</status>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<transaction_id>119643250547501c79d8295</transaction_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<mode>live</mode>
<timestamp>2025-01-16T10:23:46Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>EUR</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
transaction_id | string(255) | Unique transaction id defined by merchant |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>bcmc</transaction_type>
<status>error</status>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<transaction_id>119643250547501c79d8295</transaction_id>
<code>110</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:46Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>EUR</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response
stdClass Object
(
[transaction_type] => ppro
[status] => error
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[transaction_id] => 119643250547501c79d8295
[code] => 110
[technical_message] =>
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:46.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => EUR
[sent_to_acquirer] => false
)
<payment_response content=[
<transaction_type content=[ppro]>
<status content=[error]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<transaction_id content=[119643250547501c79d8295]>
<code content=[110]>
<technical_message content=[]>
<message content=[Something went wrong, please contact support!]>
<timestamp content=[2025-01-16T10:23:46Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[EUR]>
<sent_to_acquirer content=[false]>
]>
{
transaction_type: "ppro",
status: "error",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
transaction_id: "119643250547501c79d8295",
code: "110",
technical_message: "",
message: "Something went wrong, please contact support!",
timestamp: "2025-01-16T10:23:46Z",
descriptor: "Descriptor one",
amount: "100",
currency: "EUR",
sent_to_acquirer: "false",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>ppro</transaction_type>
<status>error</status>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<transaction_id>119643250547501c79d8295</transaction_id>
<code>110</code>
<payment_response>technical_message</payment_response>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:46Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>EUR</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
transaction_id | string(255) | Unique transaction id defined by merchant |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Cabal
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Cabal');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setAmount('100')
->setCurrency('USD')
->setConsumerReference('braney_rubble')
->setNationalId('8812128812')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>cabal</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<amount>100</amount>
<currency>USD</currency>
<consumer_reference>braney_rubble</consumer_reference>
<national_id>8812128812</national_id>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: cabal |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
consumer_reference | required | string(20) | Consumer reference is a unique consumer identifier |
national_id | required | string(20) | National Identifier number of the customer |
birth_date | optional | dd-mm-yyyy | Required for Visa only when MCC is a Financial Services one (e.g. MCC 6012) |
customer_email | required | e-mail address | Must contain valid e-mail of customer |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
neighborhood | optional | string(255) | Neighborhood |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported countries
Country Name | Country Code |
---|---|
Argentina | AR |
Successful Response
stdClass Object
(
[status] => pending_async
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[transaction_id] => 119643250547501c79d8295
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61d0
[mode] => live
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:46.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<status>pending_async</status>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<transaction_id>119643250547501c79d8295</transaction_id>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61d0</redirect_url>
<mode>live</mode>
<timestamp>2025-01-16T10:23:46Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
status | string(255) | Status of the transaction, see states |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
transaction_id | string(255) | Unique transaction id defined by merchant |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[status] => error
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[transaction_id] => 119643250547501c79d8295
[code] => 110
[message] => Something went wrong, please contact support!
[mode] => live
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:46.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => false
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<status>error</status>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<transaction_id>119643250547501c79d8295</transaction_id>
<code>110</code>
<message>Something went wrong, please contact support!</message>
<mode>live</mode>
<timestamp>2025-01-16T10:23:46Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
status | string(255) | Status of the transaction, see states |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
transaction_id | string(255) | Unique transaction id defined by merchant |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Cencosud
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Cencosud');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setAmount('100')
->setCurrency('USD')
->setConsumerReference('barney_rumble')
->setNationalId('8812128812')
->setBirthDate('30-12-1992')
->setCustomerEmail('barney@example.com')
// Billing Address
->setBillingFirstName('Barney')
->setBillingLastName('Rubble')
->setBillingAddress1('14, Nerazdelni str')
->setBillingZipCode('1407')
->setBillingCity('Buenos Aires')
->setBillingNeighborhood('Recoleta')
->setBillingCountry('AR')
// Risk Params
->setRiskUserId('123456');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>cencosud</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<amount>100</amount>
<currency>USD</currency>
<consumer_reference>barney_rumble</consumer_reference>
<national_id>8812128812</national_id>
<birth_date>30-12-1992</birth_date>
<customer_email>barney@example.com</customer_email>
<billing_address>
<first_name>Barney</first_name>
<last_name>Rubble</last_name>
<address1>14, Nerazdelni str</address1>
<zip_code>1407</zip_code>
<city>Buenos Aires</city>
<neighborhood>Recoleta</neighborhood>
<country>AR</country>
</billing_address>
<risk_params>
<user_id>123456</user_id>
</risk_params>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: cencosud |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
consumer_reference | required | string(20) | Consumer reference is a unique consumer identifier |
national_id | required | string(20) | National Identifier number of the customer |
birth_date | optional | dd-mm-yyyy | Required for Visa only when MCC is a Financial Services one (e.g. MCC 6012) |
customer_email | required | e-mail address | Must contain valid e-mail of customer |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
neighborhood | optional | string(255) | Neighborhood |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported countries:
Country |
---|
AR |
Successful Response
stdClass Object
(
[transaction_type] => cencosud
[status] => pending_async
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[technical_message] => Transaction successful!
[message] => Transaction successful!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:46.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>cencosud</transaction_type>
<status>pending_async</status>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:46Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => cencosud
[status] => error
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 110
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:46.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>cencosud</transaction_type>
<status>error</status>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:46Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Credit (CFT)
Credits (also known as Credit Fund Transfer a.k.a. CFT) can be done with an initial reference transaction.
This transaction type allows you to transfer funds to a previously charged card. The amount can be higher than the charged reference. Credits can only be done on former sale, sale3d, init recurring sale, init recurring sale3d, recurring sale or capture transaction. Therefore, the reference_id for the corresponding transaction is mandatory.
Both Visa and Mastercard/Maestro credits are authorized real-time.
Note that for exceptional cases with some countries Visa OCTS will not be authorized through the schemes but batched for offline settlement on the same day. This means that the authorization code and issuer response code will not be available only for them.
Note that VISA OCT transactions with Australian or Canadian card bins will require the merchant zip code to be set, either through the dynamic descriptor parameter or through the merchant configuration.
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Credit');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setReferenceId('43672')
->setAmount('100')
// Account Owner
->setAccountFirstName('Travis')
->setAccountMiddleName('Joe')
->setAccountLastName('Pastrana');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.CreditRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
CreditRequest request = new CreditRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setReferenceId("43672");
request.setAmount(new BigDecimal(100));
// Account Owner
request.setAccountFirstname("Travis");
request.setAccountMiddlename("Joe");
request.setAccountLastname("Pastrana");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.credit(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"reference_id": "43672",
"amount": "100",
"account_owner": {
"first_name": "Travis",
"middle_name": "Joe",
"last_name": "Pastrana"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>credit</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<reference_id>43672</reference_id>
<amount>100</amount>
<account_owner>
<first_name>Travis</first_name>
<middle_name>Joe</middle_name>
<last_name>Pastrana</last_name>
</account_owner>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: credit |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
crypto | optional | "true" | Signifies whether a crypto-currency transaction is performed. Must be populated when indicating crypto for VISA and MCC 6051. This is only applied to VISA OCT transactions. Contact Tech Support for more details. |
reference_id | required | string(32) | Unique id returned by corresponding transaction |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
source_of_funds | optional | string | Specify the source of funds with one of credit , debit , prepaid , cash , other_debit_account , other_credit_account . |
purpose_of_payment | required* | string (12) | Purpose of Payment code, required for Visa OCTs with recipients in Argentina, Bangladesh, Egypt, India, Chile and Colombia. |
customer_identification | required* | See Customer Identification Parameters for more details. | |
owner | required* | string(255) | The owner of the document ID |
type | required* | string(255) | The type of the document ID |
subtype | required* | string(255) | The subtype of the document ID |
document_id | required* | string(255) | Document ID value. |
issuing_country | required* | string(2) | The issuing country of the document ID |
account_owner | optional | Account owner parameters related to account owner inquiry requests | |
first_name | optional | string(35) | Account owner first name |
middle_name | optional | string(35) | Account owner middle name |
last_name | optional | string(35) | Account owner last name |
required* = conditionally required
Successful Response
stdClass Object
(
[transaction_type] => credit
[status] => approved
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[authorization_code] => 345678
[retrieval_reference_number] => 016813015184
[response_code] => 00
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:46.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[scheme_response_code] => 00
[account_owner] => {"first_name"=>"Travis", "middle_name"=>"Joe", "last_name"=>"Pastrana"}
)
<payment_response content=[
<transaction_type content=[credit]>
<status content=[approved]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<authorization_code content=[345678]>
<retrieval_reference_number content=[016813015184]>
<response_code content=[00]>
<timestamp content=[2025-01-16T10:23:46Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<scheme_response_code content=[00]>
<account_owner content=[{"first_name"=>"Travis", "middle_name"=>"Joe", "last_name"=>"Pastrana"}]>
]>
{
transaction_type: "credit",
status: "approved",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
authorization_code: "345678",
retrieval_reference_number: "016813015184",
response_code: "00",
timestamp: "2025-01-16T10:23:46Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
scheme_response_code: "00",
account_owner: "{"first_name"=>"Travis", "middle_name"=>"Joe", "last_name"=>"Pastrana"}",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>credit</transaction_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<authorization_code>345678</authorization_code>
<retrieval_reference_number>016813015184</retrieval_reference_number>
<response_code>00</response_code>
<timestamp>2025-01-16T10:23:46Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<scheme_response_code>00</scheme_response_code>
<account_owner>
<first_name>Travis</first_name>
<middle_name>Joe</middle_name>
<last_name>Pastrana</last_name>
</account_owner>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
authorization_code | string(6) | Generated by the card network when an authorisation has occurred, used to identify that auth. Consists of 6 alphanumeric chars |
retrieval_reference_number | string(255) | A reference number used for tracking all messages related to a given cardholder transaction returned by some acquirers. |
response_code | string(2) | Defines the result of a transaction with the acquirer, the status of a message or some action taken or required. Contact tech-support@emerchantpay.com for more details. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
scheme_response_code | string(2) | The response code returned from the schemes. See Scheme response codes for details. |
recurring_advice_code | string(2) | Additional response code returned from the schemes. See Recurring advice details |
recurring_advice_text | string(255) | The text representation of the recurring advice code. |
Error Response
stdClass Object
(
[transaction_type] => credit
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[response_code] => 57
[code] => 410
[technical_message] => No approved reference transaction found
[message] => No approved reference transaction found
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:46.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
)
<payment_response content=[
<transaction_type content=[credit]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<response_code content=[57]>
<code content=[410]>
<technical_message content=[No approved reference transaction found]>
<message content=[No approved reference transaction found]>
<timestamp content=[2025-01-16T10:23:46Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
]>
{
transaction_type: "credit",
status: "error",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
response_code: "57",
code: "410",
technical_message: "No approved reference transaction found",
message: "No approved reference transaction found",
timestamp: "2025-01-16T10:23:46Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>credit</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<response_code>57</response_code>
<code>410</code>
<technical_message>No approved reference transaction found</technical_message>
<message>No approved reference transaction found</message>
<timestamp>2025-01-16T10:23:46Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
Elo
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Elo');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setAmount('100')
->setCurrency('USD')
->setConsumerReference('barney_rumble')
->setNationalId('8812128812')
->setBirthDate('30-12-1992')
->setCustomerEmail('barney@example.com')
// Billing Address
->setBillingFirstName('Barney')
->setBillingLastName('Rubble')
->setBillingAddress1('14, Nerazdelni str')
->setBillingZipCode('1407')
->setBillingCity('Salvador')
->setBillingNeighborhood('Historic Center of Salvador')
->setBillingCountry('BR')
// Risk Params
->setRiskUserId('123456');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>elo</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<amount>100</amount>
<currency>USD</currency>
<consumer_reference>barney_rumble</consumer_reference>
<national_id>8812128812</national_id>
<birth_date>30-12-1992</birth_date>
<customer_email>barney@example.com</customer_email>
<billing_address>
<first_name>Barney</first_name>
<last_name>Rubble</last_name>
<address1>14, Nerazdelni str</address1>
<zip_code>1407</zip_code>
<city>Salvador</city>
<neighborhood>Historic Center of Salvador</neighborhood>
<country>BR</country>
</billing_address>
<risk_params>
<user_id>123456</user_id>
</risk_params>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: elo |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
consumer_reference | required | string(20) | Consumer reference is a unique consumer identifier |
national_id | required | string(20) | National Identifier number of the customer |
birth_date | optional | dd-mm-yyyy | Required for Visa only when MCC is a Financial Services one (e.g. MCC 6012) |
customer_email | required | e-mail address | Must contain valid e-mail of customer |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
neighborhood | optional | string(255) | Neighborhood |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported countries:
Country |
---|
BR |
Successful Response
stdClass Object
(
[transaction_type] => elo
[status] => pending_async
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[technical_message] => Transaction successful!
[message] => Transaction successful!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:46.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>elo</transaction_type>
<status>pending_async</status>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:46Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => elo
[status] => error
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 110
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:46.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>elo</transaction_type>
<status>error</status>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:46Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Naranja
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Naranja');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setAmount('100')
->setCurrency('USD')
->setConsumerReference('barney_rumble')
->setNationalId('8812128812')
->setBirthDate('30-12-1992')
->setCustomerEmail('barney@example.com')
// Billing Address
->setBillingFirstName('Barney')
->setBillingLastName('Rubble')
->setBillingAddress1('14, Nerazdelni str')
->setBillingZipCode('1407')
->setBillingCity('Buenos Aires')
->setBillingCountry('AR')
// Risk Params
->setRiskUserId('123456');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>naranja</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<amount>100</amount>
<currency>USD</currency>
<consumer_reference>barney_rumble</consumer_reference>
<national_id>8812128812</national_id>
<birth_date>30-12-1992</birth_date>
<customer_email>barney@example.com</customer_email>
<billing_address>
<first_name>Barney</first_name>
<last_name>Rubble</last_name>
<address1>14, Nerazdelni str</address1>
<zip_code>1407</zip_code>
<city>Buenos Aires</city>
<country>AR</country>
</billing_address>
<risk_params>
<user_id>123456</user_id>
</risk_params>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: naranja |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
consumer_reference | required | string(20) | Consumer reference is a unique consumer identifier |
national_id | required | string(20) | National Identifier number of the customer |
birth_date | optional | dd-mm-yyyy | Required for Visa only when MCC is a Financial Services one (e.g. MCC 6012) |
customer_email | required | e-mail address | Must contain valid e-mail of customer |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported countries:
Country |
---|
AR |
Successful Response
stdClass Object
(
[transaction_type] => naranja
[status] => pending_async
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[technical_message] => Transaction successful!
[message] => Transaction successful!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:47.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>naranja</transaction_type>
<status>pending_async</status>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:47Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => naranja
[status] => error
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 110
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:47.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>naranja</transaction_type>
<status>error</status>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:47Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Nativa
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Nativa');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setAmount('100')
->setCurrency('USD')
->setConsumerReference('barney_rumble')
->setNationalId('8812128812')
->setBirthDate('30-12-1992')
->setCustomerEmail('barney@example.com')
// Billing Address
->setBillingFirstName('Barney')
->setBillingLastName('Rubble')
->setBillingAddress1('14, Nerazdelni str')
->setBillingZipCode('1407')
->setBillingCity('Buenos Aires')
->setBillingCountry('AR')
// Risk Params
->setRiskUserId('123456');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>nativa</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<amount>100</amount>
<currency>USD</currency>
<consumer_reference>barney_rumble</consumer_reference>
<national_id>8812128812</national_id>
<birth_date>30-12-1992</birth_date>
<customer_email>barney@example.com</customer_email>
<billing_address>
<first_name>Barney</first_name>
<last_name>Rubble</last_name>
<address1>14, Nerazdelni str</address1>
<zip_code>1407</zip_code>
<city>Buenos Aires</city>
<country>AR</country>
</billing_address>
<risk_params>
<user_id>123456</user_id>
</risk_params>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: nativa |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
consumer_reference | required | string(20) | Consumer reference is a unique consumer identifier |
national_id | required | string(20) | National Identifier number of the customer |
birth_date | optional | dd-mm-yyyy | Required for Visa only when MCC is a Financial Services one (e.g. MCC 6012) |
customer_email | required | e-mail address | Must contain valid e-mail of customer |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported countries:
Country |
---|
AR |
Successful Response
stdClass Object
(
[transaction_type] => nativa
[status] => pending_async
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[technical_message] => Transaction successful!
[message] => Transaction successful!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:47.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>nativa</transaction_type>
<status>pending_async</status>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:47Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => nativa
[status] => error
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 110
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:47.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>nativa</transaction_type>
<status>error</status>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:47Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Tarjeta Shopping
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\TarjetaShopping');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setAmount('100')
->setCurrency('USD')
->setConsumerReference('barney_rubble')
->setNationalId('8812128812')
->setBirthDate('30-12-1992')
->setCustomerEmail('travis@example.com')
// Billing Address
->setBillingFirstName('Barney')
->setBillingLastName('Rubble')
->setBillingAddress1('14, Nerazdelni str')
->setBillingZipCode('1407')
->setBillingCity('Rosario')
->setBillingCountry('AR')
// Risk Params
->setRiskUserId('123456');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>tarjeta_shopping</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<amount>100</amount>
<currency>USD</currency>
<consumer_reference>barney_rubble</consumer_reference>
<national_id>8812128812</national_id>
<birth_date>30-12-1992</birth_date>
<customer_email>travis@example.com</customer_email>
<billing_address>
<first_name>Barney</first_name>
<last_name>Rubble</last_name>
<address1>14, Nerazdelni str</address1>
<zip_code>1407</zip_code>
<city>Rosario</city>
<country>AR</country>
</billing_address>
<risk_params>
<user_id>123456</user_id>
</risk_params>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: tarjeta_shopping |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
consumer_reference | required | string(20) | Consumer reference is a unique consumer identifier |
national_id | required | string(20) | National Identifier number of the customer |
birth_date | optional | string(20) | Birth date of the customer |
customer_email | required | e-mail address | Must contain valid e-mail of customer |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported countries:
Country |
---|
AR |
Successful Response
stdClass Object
(
[transaction_type] => tarjeta_shopping
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:47.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>tarjeta_shopping</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<timestamp>2025-01-16T10:23:47Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => tarjeta_shopping
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 110
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:47.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>tarjeta_shopping</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:47Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Non-financial Transactions
Account Verification v2
Account Verification transaction can be used to verify the account's existence for a given cardholder without any financial impact. To create an Account Verification transaction, you have to submit a Sale, Sale(3D), Authorize or Authorize(3d) transaction with zero amount.
Example Of Sale(3d) Transaction As Account Verification
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Sale3D');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('0')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('4200000000000000')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.Sale3DRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
Sale3DRequest request = new Sale3DRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(0));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4200000000000000");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.sale3d(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": 0,
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "4200000000000000",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"business_attributes": {
"event_start_date": "17-02-2025",
"event_end_date": "26-02-2025",
"event_organizer_id": "20192375",
"event_id": "1912"
},
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>sale3d</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>0</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4200000000000000</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<business_attributes>
<event_start_date>17-02-2025</event_start_date>
<event_end_date>26-02-2025</event_end_date>
<event_organizer_id>20192375</event_organizer_id>
<event_id>1912</event_id>
</business_attributes>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
</payment_transaction>'
Example Of Authorize(3d) Transaction As Account Verification
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Authorize3D');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('0')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('4200000000000000')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.Authorize3DRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
Authorize3DRequest request = new Authorize3DRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(0));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4200000000000000");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.authorize3d(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": 0,
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "4200000000000000",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"business_attributes": {
"event_start_date": "17-02-2025",
"event_end_date": "26-02-2025",
"event_organizer_id": "20192375",
"event_id": "1912"
},
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>authorize3d</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>0</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4200000000000000</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<business_attributes>
<event_start_date>17-02-2025</event_start_date>
<event_end_date>26-02-2025</event_end_date>
<event_organizer_id>20192375</event_organizer_id>
<event_id>1912</event_id>
</business_attributes>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: sale, sale(3d), authorize or authorize(3d) |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
gaming | optional | "true" | Signifies whether a gaming transaction is performed. Gaming transactions usually use MCC 7995. Contact tech-support@emerchantpay.com for more details |
moto | optional | "true" | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech-support@emerchantpay.com for more details |
crypto | optional | "true" | Signifies whether a purchase of crypto-currency transaction is performed. Must be populated when purchasing crypto-currency with a VISA card. Must be populated when purchasing crypto-currency with a MASTER or INTL MAESTRO card and MCC is one of 6051, 6211. Contact tech-support@emerchantpay.com for more details |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
amount | required | integer = 0 | Transaction amount in minor currency unit, see Currency and Amount Handling for details. By submitting zero value amount you can verify the account's existence for a given cardholder without any financial impact. |
currency | required | string(3) | Currency code in ISO 4217 |
card_holder | required | string(255) | Full name of customer as printed on credit card (first name and last name at least) |
card_number | required | 13 to 16 digits | Complete cc number of customer |
cvv | required* | 3 to 4 digits | cvv of cc, requirement is based on terminal configuration |
expiration_month | required | MM | Expiration month as printed on credit card |
expiration_year | required | YYYY | Expiration year as printed on credit card |
token | optional | string(36) | See Tokenization for more details. If present, the cardholder parameters can be omitted. Cannot be set together with remember_card |
remember_card | optional | "true" | See Tokenize. Tokenizes cardholder parameters. Cannot be set together with token |
consumer_id | optional | string(10) | See Consumers and Tokenization. Combine with remember_card to tokenize or with token to use token |
scheme_tokenized | required* | "true" | Required when the card_number is DPAN instead of Funding Primary Account Number, see Tokenized e-commerce for details |
recurring_type | optional | string(255) | Specifies recurring type of the transaction, can be 'initial', 'managed' or 'subsequent'. |
reference_id | optional | string(32) | Unique id returned by corresponding transaction |
credential_on_file | required* | See Credential On File (COF) for more details | |
initial_customer_initiated | required* | string(18) | Initial transaction initiated by customer. Required for external tokenization, and optional for gateway-based tokenization |
subsequent_customer_initiated | required* | string(18) | Subsequent transaction initiated by customer. Required for external tokenization, and optional for gateway-based tokenization |
merchant_unscheduled | optional | string(20) | Transaction is initiated by the merchant |
credential_on_file_transaction_identifier | optional | string(15..32) | See Credential On File (COF) for more details |
credential_on_file_settlement_date | optional | string(4) | See Credential On File (COF) for more details |
customer_email | required* | e-mail address | Must contain valid e-mail of customer |
customer_phone | required* | string(32) | Must contain valid phone number of customer |
birth_date | required* | dd-mm-yyyy | Required when MCC is a Financial Services one (e.g. MCC 6012) and either card brand is Visa or Mastercard/Maestro with UK-based merchant, UK-based bin (domestic), and DEBIT card type |
document_id | required* | string(255) | Document ID value. |
fx_rate_id | optional | integer | See Get rates for FX Service. Offers the option to use a specific FX rate to convert the transaction processing amount. Used FX rate should have the same source currency as the processing currency. Contact tech-support@emerchantpay.com for more details |
business_attributes | required* | Check business attributes section. | |
event_start_date | required* | dd-mm-yyyy | The date when event starts in format dd-mm-yyyy |
event_end_date | required* | dd-mm-yyyy | The date when event ends in format dd-mm-yyyy |
event_organizer_id | required* | string | |
event_id | required* | string | |
date_of_order | required* | dd-mm-yyyy | The date when order was placed in format dd-mm-yyyy |
delivery_date | required* | dd-mm-yyyy | Date of the expected delivery in format dd-mm-yyyy |
name_of_the_supplier | required* | string | |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required* | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
sca_params | optional | SCA params | |
exemption | optional | string | The exemption that the transaction should take advantage of. Note that the requested exemption may not be accepted due to internal risk validations. Check SCA exemption values. |
visa_merchant_id | required5 | string(8) | VMID assigned by Visa if participating in Trusted merchant program. |
dynamic_descriptor_params | optional | ||
merchant_name | optional | string(25) | Allows to dynamically override the charge descriptor |
merchant_city | optional | string(13) | Allows to dynamically override the merchant phone number |
sub_merchant_id | optional | string(15) | Allows to dynamically override the sub-merchant ID. |
merchant_country | optional | string(3) | Allows to dynamically override the merchant country. |
merchant_state | optional | string(3) | Allows to dynamically override the merchant subdivision code. |
merchant_zip_code | optional | string(10) | Allows to dynamically override the merchant zip/postal code. Required for VISA OCT transactions with Australian and Canadian card bins. |
merchant_address | optional | string(48) | Allows to dynamically override the merchant address. |
merchant_url | optional | string(60) | Allows to dynamically override the merchant URL |
merchant_phone | optional | string(16) | Allows to dynamically override the merchant phone number. |
merchant_service_city | optional | string(13) | Allows to dynamically override the merchant service city. |
merchant_service_country | optional | string(3) | Allows to dynamically override the merchant service country. |
merchant_service_state | optional | string(3) | Allows to dynamically override the merchant service subdivision code. |
merchant_service_zip_code | optional | string(10) | Allows to dynamically override the merchant service zip/postal code. |
merchant_service_phone | optional | string(16) | Allows to dynamically override the merchant service phone number. |
merchant_geo_coordinates | optional | string(20) | Allows to dynamically override the merchant geographic coordinates. |
merchant_service_geo_coordinates | optional | string(20) | Allows to dynamically override the merchant service geographic coordinates. |
required* = conditionally required
Successful Response
stdClass Object
(
[transaction_type] => sale3d
[status] => approved
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[cvv_result_code] => P
[authorization_code] => 271621
[retrieval_reference_number] => 311709000149
[response_code] => 83
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:47.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 0
[currency] => USD
[scheme_transaction_identifier] => 427105912289261
[scheme_response_code] => 00
)
<payment_response content=[
<transaction_type content=[sale3d]>
<status content=[approved]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<cvv_result_code content=[P]>
<authorization_code content=[271621]>
<retrieval_reference_number content=[311709000149]>
<response_code content=[83]>
<timestamp content=[2025-01-16T10:23:47Z]>
<descriptor content=[Descriptor one]>
<amount content=[0]>
<currency content=[USD]>
<scheme_transaction_identifier content=[427105912289261]>
<scheme_response_code content=[00]>
]>
{
transaction_type: "sale3d",
status: "approved",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
cvv_result_code: "P",
authorization_code: "271621",
retrieval_reference_number: "311709000149",
response_code: "83",
timestamp: "2025-01-16T10:23:47Z",
descriptor: "Descriptor one",
amount: "0",
currency: "USD",
scheme_transaction_identifier: "427105912289261",
scheme_response_code: "00",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>sale3d</transaction_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<cvv_result_code>P</cvv_result_code>
<authorization_code>271621</authorization_code>
<retrieval_reference_number>311709000149</retrieval_reference_number>
<response_code>83</response_code>
<timestamp>2025-01-16T10:23:47Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>0</amount>
<currency>USD</currency>
<scheme_transaction_identifier>427105912289261</scheme_transaction_identifier>
<scheme_response_code>00</scheme_response_code>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
consumer_id | string(10) | Consumer unique reference. See Consumers |
token | string(36) | Plain-text token value. See Tokenization |
gaming | 'true' | Signifies whether a gaming transaction is performed. Gaming transactions usually use MCC 7995, contact tech support for more details. |
moto | 'true' | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech support for more details. |
avs_response_code | string(255) | Generated by the card network on trying to match the billing address when performing the address verification. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
avs_response_text | string(255) | Gives the human response text for the AVS response code above. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
cvv_result_code | string(1) | Card Verification Value response code. Optional, returned only if acquirer supports it |
authorization_code | string(6) | Generated by the card network when an authorisation has occurred, used to identify that auth. Consists of 6 alphanumeric chars |
retrieval_reference_number | string(255) | A reference number used for tracking all messages related to a given cardholder transaction returned by some acquirers. |
response_code | string(2) | Defines the result of a transaction with the acquirer, the status of a message or some action taken or required. Contact tech-support@emerchantpay.com for more details. |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
partial_approval | string(4) | Optional, set to ’true’ if partial approval happened. Partially approved amount is then in the amount field. Check Partial Approvals for details |
sent_to_acquirer | string(255) | "true" or "false" |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
scheme_transaction_identifier | string(32) | Id defined by card schemes. Corresponds to NETWORK DATA (field 63) for MasterCard or TRANS ID (field 62.2/125) for VISA. |
scheme_settlement_date | string(4) | MasterCard settlement date in MMDD format (e.g. 0117). Corresponds to NETWORK DATA (field 15). |
scheme_response_code | string(2) | The response code returned from the schemes. See Scheme response codes for details. |
recurring_advice_code | string(2) | Additional response code returned from the schemes. See Recurring advice details |
recurring_advice_text | string(255) | The text representation of the recurring advice code. |
reason_for_not_honoring_exemption | string | Reason for not honoring exemption. Check SCA Reason For Not Honoring Exemption Values. |
sca_exemption_result | string | SCA exemption result. Check SCA Exemption Result Values. |
Error Response
stdClass Object
(
[transaction_type] => sale3d
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 340
[technical_message] => billing_address[zip_code] is invalid!
[message] => billing_address[zip_code] is invalid!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:47.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 0
[currency] => USD
)
<payment_response content=[
<transaction_type content=[sale3d]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<code content=[340]>
<technical_message content=[billing_address[zip_code] is invalid!]>
<message content=[billing_address[zip_code] is invalid!]>
<timestamp content=[2025-01-16T10:23:47Z]>
<descriptor content=[Descriptor one]>
<amount content=[0]>
<currency content=[USD]>
]>
{
transaction_type: "sale3d",
status: "error",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
code: "340",
technical_message: "billing_address[zip_code] is invalid!",
message: "billing_address[zip_code] is invalid!",
timestamp: "2025-01-16T10:23:47Z",
descriptor: "Descriptor one",
amount: "0",
currency: "USD",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>sale3d</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>340</code>
<technical_message>billing_address[zip_code] is invalid!</technical_message>
<message>billing_address[zip_code] is invalid!</message>
<timestamp>2025-01-16T10:23:47Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>0</amount>
<currency>USD</currency>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
gaming | 'true' | Signifies whether a gaming transaction is performed. Gaming transactions usually use MCC 7995, contact tech support for more details. |
moto | 'true' | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech support for more details. |
response_code | string(2) | Defines the result of a transaction with the acquirer, the status of a message or some action taken or required. Contact tech-support@emerchantpay.com for more details. |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
Account Verification
Account Verification transactions are implemented using the so-called zero-value auths.
Using an account verification transaction, the account existence for a given cardholder can be verified without any financial impact.
Note the account verification can also carry on an AVS request, thus you can also get the AVS response code and text by the schemes along with it. Refer to section AVS Status Codes for more information.
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('NonFinancial\AccountVerification');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setCardHolder('Travis Pastrana')
->setCardNumber('4200000000000000')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.nonfinancial.AccountVerificationRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
AccountVerificationRequest request = new AccountVerificationRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4200000000000000");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.account_verification(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"card_holder": "Travis Pastrana",
"card_number": "4200000000000000",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>account_verification</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<card_holder>Travis Pastrana</card_holder>
<card_number>4200000000000000</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
</payment_transaction>'
Example When Issuer Supports Oct For This Pan:
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('NonFinancial\AccountVerification');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setIssuerOctEnabled('true')
->setRemoteIp('245.253.2.12')
->setCardHolder('Travis Pastrana')
->setCardNumber('4200000000000000')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.nonfinancial.AccountVerificationRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
AccountVerificationRequest request = new AccountVerificationRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setIssuerOctEnabled("true");
request.setRemoteIp("245.253.2.12");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4200000000000000");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.account_verification(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"issuer_oct_enabled": true,
"remote_ip": "245.253.2.12",
"card_holder": "Travis Pastrana",
"card_number": "4200000000000000",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>account_verification</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<issuer_oct_enabled>true</issuer_oct_enabled>
<remote_ip>245.253.2.12</remote_ip>
<card_holder>Travis Pastrana</card_holder>
<card_number>4200000000000000</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: account_verification |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
moto | optional | "true" | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech-support@emerchantpay.com for more details |
issuer_oct_enabled | optional | true | Supported only by Visa. When submitted, Visa checks if the given PAN supports OCTs at the issuer. When not submitted, it is interpreted as a normal account verification. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
card_holder | required | string(255) | Full name of customer as printed on credit card (first name and last name at least) |
card_number | required | 13 to 16 digits | Complete cc number of customer |
cvv | required* | 3 to 4 digits | cvv of cc, requirement is based on terminal configuration |
expiration_month | required | MM | Expiration month as printed on credit card |
expiration_year | required | YYYY | Expiration year as printed on credit card |
token | optional | string(36) | See Tokenization for more details. If present, the cardholder parameters can be omitted. Cannot be set together with remember_card |
remember_card | optional | "true" | See Tokenize. Tokenizes cardholder parameters. Cannot be set together with token |
consumer_id | optional | string(10) | See Consumers and Tokenization. Combine with remember_card to tokenize or with token to use token |
credential_on_file | required* | See Credential On File (COF) for more details | |
initial_customer_initiated | required* | string(18) | Initial transaction initiated by customer. Required for external tokenization, and optional for gateway-based tokenization |
subsequent_customer_initiated | required* | string(18) | Subsequent transaction initiated by customer. Required for external tokenization, and optional for gateway-based tokenization |
merchant_unscheduled | optional | string(20) | Transaction is initiated by the merchant |
customer_email | required* | e-mail address | Must contain valid e-mail of customer |
customer_phone | required* | string(32) | Must contain valid phone number of customer |
document_id | required* | string(255) | Document ID value. |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required* | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Successful Response
stdClass Object
(
[transaction_type] => account_verification
[status] => approved
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[consumer_id] => 123456
[token] => ee946db8-d7db-4bb7-b608-b65b153e127d
[avs_response_code] => 5I
[avs_response_text] => Response provided by issuer processor; Address information not verified
[authorization_code] => 345678
[response_code] => 00
[technical_message] => Transaction successful!
[message] => Transaction successful!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:47.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[sent_to_acquirer] => true
[scheme_transaction_identifier] => 019091214161031
[scheme_settlement_date] => 0117
[scheme_response_code] => 00
)
<payment_response content=[
<transaction_type content=[account_verification]>
<status content=[approved]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<consumer_id content=[123456]>
<token content=[ee946db8-d7db-4bb7-b608-b65b153e127d]>
<avs_response_code content=[5I]>
<avs_response_text content=[Response provided by issuer processor; Address information not verified]>
<authorization_code content=[345678]>
<response_code content=[00]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<timestamp content=[2025-01-16T10:23:47Z]>
<descriptor content=[Descriptor one]>
<sent_to_acquirer content=[true]>
<scheme_transaction_identifier content=[019091214161031]>
<scheme_settlement_date content=[0117]>
<scheme_response_code content=[00]>
]>
{
transaction_type: "account_verification",
status: "approved",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
consumer_id: "123456",
token: "ee946db8-d7db-4bb7-b608-b65b153e127d",
avs_response_code: "5I",
avs_response_text: "Response provided by issuer processor; Address information not verified",
authorization_code: "345678",
response_code: "00",
technical_message: "Transaction successful!",
message: "Transaction successful!",
timestamp: "2025-01-16T10:23:47Z",
descriptor: "Descriptor one",
sent_to_acquirer: "true",
scheme_transaction_identifier: "019091214161031",
scheme_settlement_date: "0117",
scheme_response_code: "00",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>account_verification</transaction_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<consumer_id>123456</consumer_id>
<token>ee946db8-d7db-4bb7-b608-b65b153e127d</token>
<avs_response_code>5I</avs_response_code>
<avs_response_text>Response provided by issuer processor; Address information not verified</avs_response_text>
<authorization_code>345678</authorization_code>
<response_code>00</response_code>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:47Z</timestamp>
<descriptor>Descriptor one</descriptor>
<sent_to_acquirer>true</sent_to_acquirer>
<scheme_transaction_identifier>019091214161031</scheme_transaction_identifier>
<scheme_settlement_date>0117</scheme_settlement_date>
<scheme_response_code>00</scheme_response_code>
</payment_response>
Example When Issuer Supports Oct For This Pan:
Successful Response
stdClass Object
(
[transaction_type] => account_verification
[status] => approved
[issuer_oct_enabled] => true
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[consumer_id] => 123456
[token] => ee946db8-d7db-4bb7-b608-b65b153e127d
[avs_response_code] => 5I
[avs_response_text] => Response provided by issuer processor; Address information not verified
[authorization_code] => 345678
[response_code] => 00
[technical_message] => Transaction successful!
[message] => Transaction successful!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:47.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[sent_to_acquirer] => true
[scheme_transaction_identifier] => 019091214161031
[scheme_settlement_date] => 0117
[scheme_response_code] => 00
)
<payment_response content=[
<transaction_type content=[account_verification]>
<status content=[approved]>
<issuer_oct_enabled content=[true]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<consumer_id content=[123456]>
<token content=[ee946db8-d7db-4bb7-b608-b65b153e127d]>
<avs_response_code content=[5I]>
<avs_response_text content=[Response provided by issuer processor; Address information not verified]>
<authorization_code content=[345678]>
<response_code content=[00]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<timestamp content=[2025-01-16T10:23:47Z]>
<descriptor content=[Descriptor one]>
<sent_to_acquirer content=[true]>
<scheme_transaction_identifier content=[019091214161031]>
<scheme_settlement_date content=[0117]>
<scheme_response_code content=[00]>
]>
{
transaction_type: "account_verification",
status: "approved",
issuer_oct_enabled: "true",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
consumer_id: "123456",
token: "ee946db8-d7db-4bb7-b608-b65b153e127d",
avs_response_code: "5I",
avs_response_text: "Response provided by issuer processor; Address information not verified",
authorization_code: "345678",
response_code: "00",
technical_message: "Transaction successful!",
message: "Transaction successful!",
timestamp: "2025-01-16T10:23:47Z",
descriptor: "Descriptor one",
sent_to_acquirer: "true",
scheme_transaction_identifier: "019091214161031",
scheme_settlement_date: "0117",
scheme_response_code: "00",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>account_verification</transaction_type>
<status>approved</status>
<issuer_oct_enabled>true</issuer_oct_enabled>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<consumer_id>123456</consumer_id>
<token>ee946db8-d7db-4bb7-b608-b65b153e127d</token>
<avs_response_code>5I</avs_response_code>
<avs_response_text>Response provided by issuer processor; Address information not verified</avs_response_text>
<authorization_code>345678</authorization_code>
<response_code>00</response_code>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:47Z</timestamp>
<descriptor>Descriptor one</descriptor>
<sent_to_acquirer>true</sent_to_acquirer>
<scheme_transaction_identifier>019091214161031</scheme_transaction_identifier>
<scheme_settlement_date>0117</scheme_settlement_date>
<scheme_response_code>00</scheme_response_code>
</payment_response>
Example When Issuer Does Not Support Oct For This Pan:
Successful Response
stdClass Object
(
[transaction_type] => account_verification
[status] => declined
[issuer_oct_enabled] => false
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[consumer_id] => 123456
[token] => ee946db8-d7db-4bb7-b608-b65b153e127d
[avs_response_code] => 5I
[avs_response_text] => Response provided by issuer processor; Address information not verified
[authorization_code] => 345678
[response_code] => 00
[technical_message] => Transaction successful!
[message] => Transaction successful!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:47.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[sent_to_acquirer] => true
[scheme_transaction_identifier] => 019091214161031
[scheme_settlement_date] => 0117
[scheme_response_code] => 00
)
<payment_response content=[
<transaction_type content=[account_verification]>
<status content=[declined]>
<issuer_oct_enabled content=[false]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<consumer_id content=[123456]>
<token content=[ee946db8-d7db-4bb7-b608-b65b153e127d]>
<avs_response_code content=[5I]>
<avs_response_text content=[Response provided by issuer processor; Address information not verified]>
<authorization_code content=[345678]>
<response_code content=[00]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<timestamp content=[2025-01-16T10:23:47Z]>
<descriptor content=[Descriptor one]>
<sent_to_acquirer content=[true]>
<scheme_transaction_identifier content=[019091214161031]>
<scheme_settlement_date content=[0117]>
<scheme_response_code content=[00]>
]>
{
transaction_type: "account_verification",
status: "declined",
issuer_oct_enabled: "false",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
consumer_id: "123456",
token: "ee946db8-d7db-4bb7-b608-b65b153e127d",
avs_response_code: "5I",
avs_response_text: "Response provided by issuer processor; Address information not verified",
authorization_code: "345678",
response_code: "00",
technical_message: "Transaction successful!",
message: "Transaction successful!",
timestamp: "2025-01-16T10:23:47Z",
descriptor: "Descriptor one",
sent_to_acquirer: "true",
scheme_transaction_identifier: "019091214161031",
scheme_settlement_date: "0117",
scheme_response_code: "00",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>account_verification</transaction_type>
<status>declined</status>
<issuer_oct_enabled>false</issuer_oct_enabled>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<consumer_id>123456</consumer_id>
<token>ee946db8-d7db-4bb7-b608-b65b153e127d</token>
<avs_response_code>5I</avs_response_code>
<avs_response_text>Response provided by issuer processor; Address information not verified</avs_response_text>
<authorization_code>345678</authorization_code>
<response_code>00</response_code>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:47Z</timestamp>
<descriptor>Descriptor one</descriptor>
<sent_to_acquirer>true</sent_to_acquirer>
<scheme_transaction_identifier>019091214161031</scheme_transaction_identifier>
<scheme_settlement_date>0117</scheme_settlement_date>
<scheme_response_code>00</scheme_response_code>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
consumer_id | string(10) | Consumer unique reference. See Consumers |
token | string(36) | Plain-text token value. See Tokenization |
moto | 'true' | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech support for more details. |
issuer_oct_enabled | string | Present only if merchant has submitted issuer oct enabled flag in the request to check if issuer supports OCTs for the given PAN. True if the issuer supports OCTs for this PAN, false otherwise. |
avs_response_code | string(255) | Generated by the card network on trying to match the billing address when performing the address verification. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
avs_response_text | string(255) | Gives the human response text for the AVS response code above. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
authorization_code | string(6) | Generated by the card network when an authorisation has occurred, used to identify that auth. Consists of 6 alphanumeric chars |
response_code | string(2) | Defines the result of a transaction with the acquirer, the status of a message or some action taken or required. Contact tech-support@emerchantpay.com for more details. |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
sent_to_acquirer | string(255) | "true" or "false" |
scheme_transaction_identifier | string(32) | Id defined by card schemes. Corresponds to NETWORK DATA (field 63) for MasterCard or TRANS ID (field 62.2/125) for VISA. |
scheme_settlement_date | string(4) | MasterCard settlement date in MMDD format (e.g. 0117). Corresponds to NETWORK DATA (field 15). |
scheme_response_code | string(2) | The response code returned from the schemes. See Scheme response codes for details. |
recurring_advice_code | string(2) | Additional response code returned from the schemes. See Recurring advice details |
recurring_advice_text | string(255) | The text representation of the recurring advice code. |
Error Response
stdClass Object
(
[transaction_type] => account_verification
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 340
[technical_message] => expiration_year is invalid
[message] => expiration_year is invalid
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:47.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[sent_to_acquirer] => false
)
<payment_response content=[
<transaction_type content=[account_verification]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<code content=[340]>
<technical_message content=[expiration_year is invalid]>
<message content=[expiration_year is invalid]>
<timestamp content=[2025-01-16T10:23:47Z]>
<descriptor content=[Descriptor one]>
<sent_to_acquirer content=[false]>
]>
{
transaction_type: "account_verification",
status: "error",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
code: "340",
technical_message: "expiration_year is invalid",
message: "expiration_year is invalid",
timestamp: "2025-01-16T10:23:47Z",
descriptor: "Descriptor one",
sent_to_acquirer: "false",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>account_verification</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>340</code>
<technical_message>expiration_year is invalid</technical_message>
<message>expiration_year is invalid</message>
<timestamp>2025-01-16T10:23:47Z</timestamp>
<descriptor>Descriptor one</descriptor>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
gaming | 'true' | Signifies whether a gaming transaction is performed. Gaming transactions usually use MCC 7995, contact tech support for more details. |
moto | 'true' | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech support for more details. |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
3DS Card
To learn more about 3D Secure and supported authentication protocols, please, visit 3D-Secure Section.
Authorize 3D
Authorize3D transactions basically have the same request as standard authorize transactions.
Visa Synchronous 3 D Sv2 Fully Authenticated Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Authorize3D');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('4012000000060085')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
// MPI Synchronous 3DSv2
->setMpiEci('05')
->setMpiCavv('MDAwMDAwMDAwMDAxMTA2Njk5NFg=')
->setMpiProtocolVersion('2')
->setMpiProtocolSubVersion('2')
->setMpiDirectoryServerId('0fe96050-b6eb-013d-d770-0a58a9feac02')
->setMpiAcsTransactionId('0fe961e0-b6eb-013d-d770-0a58a9feac02')
->setMpiThreedsChallengeIndicator('preference')
// Sca Params
->setScaExemption('trusted_merchant')
->setScaVisaMerchantId('00000000')
->set#<Proc:0x00005586a1546280 includes::Transactions::3ds::V2::Examples::Requests.md.erb:43 (lambda)>('');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.Authorize3DRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
Authorize3DRequest request = new Authorize3DRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4012000000060085");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
// Mpi Synchronous V2
request.setMpiParams("{"eci"=>"05", "cavv"=>"MDAwMDAwMDAwMDAxMTA2Njk5NFg=", "protocol_version"=>"2", "protocol_sub_version"=>"2", "directory_server_id"=>"0fe96050-b6eb-013d-d770-0a58a9feac02", "acs_transaction_id"=>"0fe961e0-b6eb-013d-d770-0a58a9feac02", "threeds_challenge_indicator"=>"preference"}");
// Sca Params
request.setScaExemption("trusted_merchant");
request.setScaVisaMerchantId("00000000");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.authorize3d(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "4012000000060085",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"business_attributes": {
"event_start_date": "17-02-2025",
"event_end_date": "26-02-2025",
"event_organizer_id": "20192375",
"event_id": "1912"
},
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"mpi_params": {
"eci": "05",
"cavv": "MDAwMDAwMDAwMDAxMTA2Njk5NFg=",
"protocol_version": "2",
"protocol_sub_version": "2",
"directory_server_id": "0fe96050-b6eb-013d-d770-0a58a9feac02",
"acs_transaction_id": "0fe961e0-b6eb-013d-d770-0a58a9feac02",
"threeds_challenge_indicator": "preference"
},
"sca_params": {
"exemption": "trusted_merchant",
"visa_merchant_id": "00000000"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>authorize3d</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4012000000060085</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<business_attributes>
<event_start_date>17-02-2025</event_start_date>
<event_end_date>26-02-2025</event_end_date>
<event_organizer_id>20192375</event_organizer_id>
<event_id>1912</event_id>
</business_attributes>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<mpi_params>
<eci>05</eci>
<cavv>MDAwMDAwMDAwMDAxMTA2Njk5NFg=</cavv>
<protocol_version>2</protocol_version>
<protocol_sub_version>2</protocol_sub_version>
<directory_server_id>0fe96050-b6eb-013d-d770-0a58a9feac02</directory_server_id>
<acs_transaction_id>0fe961e0-b6eb-013d-d770-0a58a9feac02</acs_transaction_id>
<threeds_challenge_indicator>preference</threeds_challenge_indicator>
</mpi_params>
<sca_params>
<exemption>trusted_merchant</exemption>
<visa_merchant_id>00000000</visa_merchant_id>
</sca_params>
</payment_transaction>'
Master Synchronous 3 D Sv2 Fully Authenticated Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Authorize3D');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('5555555555559997')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
// MPI Synchronous 3DSv2
->setMpiEci('02')
->setMpiCavv('kQOImea0C/2ta1NZl4Hhwslmomqj')
->setMpiProtocolVersion('2')
->setMpiProtocolSubVersion('2')
->setMpiDirectoryServerId('0fef1b80-b6eb-013d-d770-0a58a9feac02')
->setMpiAcsTransactionId('0fef1c30-b6eb-013d-d770-0a58a9feac02')
->setMpiThreedsChallengeIndicator('preference')
->set#<Proc:0x00005586a190e278 includes::Transactions::3ds::V2::Examples::Requests.md.erb:85 (lambda)>('');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.Authorize3DRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
Authorize3DRequest request = new Authorize3DRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("5555555555559997");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
// Mpi Synchronous V2
request.setMpiParams("{"eci"=>"02", "cavv"=>"kQOImea0C/2ta1NZl4Hhwslmomqj", "protocol_version"=>"2", "protocol_sub_version"=>"2", "directory_server_id"=>"0fef1b80-b6eb-013d-d770-0a58a9feac02", "acs_transaction_id"=>"0fef1c30-b6eb-013d-d770-0a58a9feac02", "threeds_challenge_indicator"=>"preference"}");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.authorize3d(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "5555555555559997",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"business_attributes": {
"event_start_date": "17-02-2025",
"event_end_date": "26-02-2025",
"event_organizer_id": "20192375",
"event_id": "1912"
},
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"mpi_params": {
"eci": "02",
"cavv": "kQOImea0C/2ta1NZl4Hhwslmomqj",
"protocol_version": "2",
"protocol_sub_version": "2",
"directory_server_id": "0fef1b80-b6eb-013d-d770-0a58a9feac02",
"acs_transaction_id": "0fef1c30-b6eb-013d-d770-0a58a9feac02",
"threeds_challenge_indicator": "preference"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>authorize3d</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>5555555555559997</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<business_attributes>
<event_start_date>17-02-2025</event_start_date>
<event_end_date>26-02-2025</event_end_date>
<event_organizer_id>20192375</event_organizer_id>
<event_id>1912</event_id>
</business_attributes>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<mpi_params>
<eci>02</eci>
<cavv>kQOImea0C/2ta1NZl4Hhwslmomqj</cavv>
<protocol_version>2</protocol_version>
<protocol_sub_version>2</protocol_sub_version>
<directory_server_id>0fef1b80-b6eb-013d-d770-0a58a9feac02</directory_server_id>
<acs_transaction_id>0fef1c30-b6eb-013d-d770-0a58a9feac02</acs_transaction_id>
<threeds_challenge_indicator>preference</threeds_challenge_indicator>
</mpi_params>
</payment_transaction>'
Visa Synchronous 3 D Sv2 Attempted Authentication Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Authorize3D');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('4012000000060085')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
// MPI Synchronous 3DSv2
->setMpiEci('06')
->setMpiCavv('MDAwMDAwMDAwMDAxMTA2Njk5NFg=')
->setMpiProtocolVersion('2')
->setMpiProtocolSubVersion('2')
->setMpiDirectoryServerId('0ff46b90-b6eb-013d-d770-0a58a9feac02')
->setMpiAcsTransactionId('0ff46c20-b6eb-013d-d770-0a58a9feac02')
->setMpiThreedsChallengeIndicator('preference')
// Sca Params
->setScaExemption('trusted_merchant')
->setScaVisaMerchantId('00000000')
->set#<Proc:0x00005586a1bcbc90 includes::Transactions::3ds::V2::Examples::Requests.md.erb:43 (lambda)>('');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.Authorize3DRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
Authorize3DRequest request = new Authorize3DRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4012000000060085");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
// Mpi Synchronous V2
request.setMpiParams("{"eci"=>"06", "cavv"=>"MDAwMDAwMDAwMDAxMTA2Njk5NFg=", "protocol_version"=>"2", "protocol_sub_version"=>"2", "directory_server_id"=>"0ff46b90-b6eb-013d-d770-0a58a9feac02", "acs_transaction_id"=>"0ff46c20-b6eb-013d-d770-0a58a9feac02", "threeds_challenge_indicator"=>"preference"}");
// Sca Params
request.setScaExemption("trusted_merchant");
request.setScaVisaMerchantId("00000000");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.authorize3d(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "4012000000060085",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"business_attributes": {
"event_start_date": "17-02-2025",
"event_end_date": "26-02-2025",
"event_organizer_id": "20192375",
"event_id": "1912"
},
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"mpi_params": {
"eci": "06",
"cavv": "MDAwMDAwMDAwMDAxMTA2Njk5NFg=",
"protocol_version": "2",
"protocol_sub_version": "2",
"directory_server_id": "0ff46b90-b6eb-013d-d770-0a58a9feac02",
"acs_transaction_id": "0ff46c20-b6eb-013d-d770-0a58a9feac02",
"threeds_challenge_indicator": "preference"
},
"sca_params": {
"exemption": "trusted_merchant",
"visa_merchant_id": "00000000"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>authorize3d</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4012000000060085</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<business_attributes>
<event_start_date>17-02-2025</event_start_date>
<event_end_date>26-02-2025</event_end_date>
<event_organizer_id>20192375</event_organizer_id>
<event_id>1912</event_id>
</business_attributes>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<mpi_params>
<eci>06</eci>
<cavv>MDAwMDAwMDAwMDAxMTA2Njk5NFg=</cavv>
<protocol_version>2</protocol_version>
<protocol_sub_version>2</protocol_sub_version>
<directory_server_id>0ff46b90-b6eb-013d-d770-0a58a9feac02</directory_server_id>
<acs_transaction_id>0ff46c20-b6eb-013d-d770-0a58a9feac02</acs_transaction_id>
<threeds_challenge_indicator>preference</threeds_challenge_indicator>
</mpi_params>
<sca_params>
<exemption>trusted_merchant</exemption>
<visa_merchant_id>00000000</visa_merchant_id>
</sca_params>
</payment_transaction>'
Master Synchronous 3 D Sv2 Attempted Authentication Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Authorize3D');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('5555555555559997')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
// MPI Synchronous 3DSv2
->setMpiEci('01')
->setMpiCavv('kFOImea0C/2ta1NZl4Hhwslmomqj')
->setMpiProtocolVersion('2')
->setMpiProtocolSubVersion('2')
->setMpiDirectoryServerId('10021a10-b6eb-013d-d770-0a58a9feac02')
->setMpiAcsTransactionId('10021ab0-b6eb-013d-d770-0a58a9feac02')
->setMpiThreedsChallengeIndicator('preference')
->set#<Proc:0x00005586a1de8370 includes::Transactions::3ds::V2::Examples::Requests.md.erb:85 (lambda)>('');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.Authorize3DRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
Authorize3DRequest request = new Authorize3DRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("5555555555559997");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
// Mpi Synchronous V2
request.setMpiParams("{"eci"=>"01", "cavv"=>"kFOImea0C/2ta1NZl4Hhwslmomqj", "protocol_version"=>"2", "protocol_sub_version"=>"2", "directory_server_id"=>"10021a10-b6eb-013d-d770-0a58a9feac02", "acs_transaction_id"=>"10021ab0-b6eb-013d-d770-0a58a9feac02", "threeds_challenge_indicator"=>"preference"}");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.authorize3d(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "5555555555559997",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"business_attributes": {
"event_start_date": "17-02-2025",
"event_end_date": "26-02-2025",
"event_organizer_id": "20192375",
"event_id": "1912"
},
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"mpi_params": {
"eci": "01",
"cavv": "kFOImea0C/2ta1NZl4Hhwslmomqj",
"protocol_version": "2",
"protocol_sub_version": "2",
"directory_server_id": "10021a10-b6eb-013d-d770-0a58a9feac02",
"acs_transaction_id": "10021ab0-b6eb-013d-d770-0a58a9feac02",
"threeds_challenge_indicator": "preference"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>authorize3d</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>5555555555559997</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<business_attributes>
<event_start_date>17-02-2025</event_start_date>
<event_end_date>26-02-2025</event_end_date>
<event_organizer_id>20192375</event_organizer_id>
<event_id>1912</event_id>
</business_attributes>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<mpi_params>
<eci>01</eci>
<cavv>kFOImea0C/2ta1NZl4Hhwslmomqj</cavv>
<protocol_version>2</protocol_version>
<protocol_sub_version>2</protocol_sub_version>
<directory_server_id>10021a10-b6eb-013d-d770-0a58a9feac02</directory_server_id>
<acs_transaction_id>10021ab0-b6eb-013d-d770-0a58a9feac02</acs_transaction_id>
<threeds_challenge_indicator>preference</threeds_challenge_indicator>
</mpi_params>
</payment_transaction>'
Master Synchronous 3 D Sv2 Acquirer Exemption Accepted (Tra Already Performed) Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Authorize3D');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('5169750000001111')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
// MPI Synchronous 3DSv2
->setMpiEci('06')
->setMpiCavv('kNMAAAAA3S13awBkrWtTWZeBBCmy')
->setMpiProtocolVersion('2')
->setMpiProtocolSubVersion('2')
->setMpiDirectoryServerId('10098ae0-b6eb-013d-d770-0a58a9feac02')
->setMpiAcsTransactionId('10098b90-b6eb-013d-d770-0a58a9feac02')
->setMpiThreedsChallengeIndicator('preference')
// Sca Params
->setScaExemption('low_risk')
->set#<Proc:0x00005586a2385468 includes::Transactions::3ds::V2::Examples::Requests.md.erb:132 (lambda)>('');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.Authorize3DRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
Authorize3DRequest request = new Authorize3DRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("5169750000001111");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
// Mpi Synchronous V2
request.setMpiParams("{"eci"=>"06", "cavv"=>"kNMAAAAA3S13awBkrWtTWZeBBCmy", "protocol_version"=>"2", "protocol_sub_version"=>"2", "directory_server_id"=>"10098ae0-b6eb-013d-d770-0a58a9feac02", "acs_transaction_id"=>"10098b90-b6eb-013d-d770-0a58a9feac02", "threeds_challenge_indicator"=>"preference"}");
// Sca Params
request.setScaExemption("low_risk");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.authorize3d(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "5169750000001111",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"business_attributes": {
"event_start_date": "17-02-2025",
"event_end_date": "26-02-2025",
"event_organizer_id": "20192375",
"event_id": "1912"
},
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"mpi_params": {
"eci": "06",
"cavv": "kNMAAAAA3S13awBkrWtTWZeBBCmy",
"protocol_version": "2",
"protocol_sub_version": "2",
"directory_server_id": "10098ae0-b6eb-013d-d770-0a58a9feac02",
"acs_transaction_id": "10098b90-b6eb-013d-d770-0a58a9feac02",
"threeds_challenge_indicator": "preference"
},
"sca_params": {
"exemption": "low_risk"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>authorize3d</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>5169750000001111</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<business_attributes>
<event_start_date>17-02-2025</event_start_date>
<event_end_date>26-02-2025</event_end_date>
<event_organizer_id>20192375</event_organizer_id>
<event_id>1912</event_id>
</business_attributes>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<mpi_params>
<eci>06</eci>
<cavv>kNMAAAAA3S13awBkrWtTWZeBBCmy</cavv>
<protocol_version>2</protocol_version>
<protocol_sub_version>2</protocol_sub_version>
<directory_server_id>10098ae0-b6eb-013d-d770-0a58a9feac02</directory_server_id>
<acs_transaction_id>10098b90-b6eb-013d-d770-0a58a9feac02</acs_transaction_id>
<threeds_challenge_indicator>preference</threeds_challenge_indicator>
</mpi_params>
<sca_params>
<exemption>low_risk</exemption>
</sca_params>
</payment_transaction>'
Visa Synchronous 3 D Sv2 Acquirer Exemption Accepted (Tra Already Performed) Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Authorize3D');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('4378510000000004')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
// MPI Synchronous 3DSv2
->setMpiEci('07')
->setMpiCavv('ApkCAlgGQCECEBJWNgZAAAAAAAA=')
->setMpiProtocolVersion('2')
->setMpiProtocolSubVersion('2')
->setMpiDirectoryServerId('100e9c40-b6eb-013d-d770-0a58a9feac02')
->setMpiAcsTransactionId('100e9ce0-b6eb-013d-d770-0a58a9feac02')
->setMpiThreedsChallengeIndicator('preference')
// Sca Params
->setScaExemption('low_risk')
->set#<Proc:0x00005586a25c5f70 includes::Transactions::3ds::V2::Examples::Requests.md.erb:179 (lambda)>('');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.Authorize3DRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
Authorize3DRequest request = new Authorize3DRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4378510000000004");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
// Mpi Synchronous V2
request.setMpiParams("{"eci"=>"07", "cavv"=>"ApkCAlgGQCECEBJWNgZAAAAAAAA=", "protocol_version"=>"2", "protocol_sub_version"=>"2", "directory_server_id"=>"100e9c40-b6eb-013d-d770-0a58a9feac02", "acs_transaction_id"=>"100e9ce0-b6eb-013d-d770-0a58a9feac02", "threeds_challenge_indicator"=>"preference"}");
// Sca Params
request.setScaExemption("low_risk");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.authorize3d(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "4378510000000004",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"business_attributes": {
"event_start_date": "17-02-2025",
"event_end_date": "26-02-2025",
"event_organizer_id": "20192375",
"event_id": "1912"
},
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"mpi_params": {
"eci": "07",
"cavv": "ApkCAlgGQCECEBJWNgZAAAAAAAA=",
"protocol_version": "2",
"protocol_sub_version": "2",
"directory_server_id": "100e9c40-b6eb-013d-d770-0a58a9feac02",
"acs_transaction_id": "100e9ce0-b6eb-013d-d770-0a58a9feac02",
"threeds_challenge_indicator": "preference"
},
"sca_params": {
"exemption": "low_risk"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>authorize3d</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4378510000000004</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<business_attributes>
<event_start_date>17-02-2025</event_start_date>
<event_end_date>26-02-2025</event_end_date>
<event_organizer_id>20192375</event_organizer_id>
<event_id>1912</event_id>
</business_attributes>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<mpi_params>
<eci>07</eci>
<cavv>ApkCAlgGQCECEBJWNgZAAAAAAAA=</cavv>
<protocol_version>2</protocol_version>
<protocol_sub_version>2</protocol_sub_version>
<directory_server_id>100e9c40-b6eb-013d-d770-0a58a9feac02</directory_server_id>
<acs_transaction_id>100e9ce0-b6eb-013d-d770-0a58a9feac02</acs_transaction_id>
<threeds_challenge_indicator>preference</threeds_challenge_indicator>
</mpi_params>
<sca_params>
<exemption>low_risk</exemption>
</sca_params>
</payment_transaction>'
Asynchronous 3 D Sv2 Frictionless No 3ds Method Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Authorize3D');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('4012000000060085')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
->setNotificationUrl('https://www.example.com/notification')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
// Threeds V2 Params
->setThreedsThreedsMethod('{"callback_url"=>"https://www.example.com/threeds/threeds_method/callback"}')
->setThreedsControl('{"device_type"=>"browser", "challenge_window_size"=>"full_screen", "challenge_indicator"=>"preference"}')
->setThreedsPurchase('{"category"=>"service"}')
->setThreedsRecurring('{"expiration_date"=>"17-07-2025", "frequency"=>30}')
->setThreedsMerchantRisk('{"shipping_indicator"=>"verified_address", "delivery_timeframe"=>"electronic", "reorder_items_indicator"=>"reordered", "pre_order_purchase_indicator"=>"merchandise_available", "pre_order_date"=>"17-02-2025", "gift_card"=>"true", "gift_card_count"=>"2"}')
->setThreedsCardHolderAccount('{"creation_date"=>"17-01-2024", "update_indicator"=>"more_than_60days", "last_change_date"=>"17-10-2024", "password_change_indicator"=>"no_change", "password_change_date"=>"02-01-2025", "shipping_address_usage_indicator"=>"current_transaction", "shipping_address_date_first_used"=>"12-01-2025", "transactions_activity_last_24_hours"=>"2", "transactions_activity_previous_year"=>"10", "provision_attempts_last_24_hours"=>"1", "purchases_count_last_6_months"=>"5", "suspicious_activity_indicator"=>"no_suspicious_observed", "registration_indicator"=>"30_to_60_days", "registration_date"=>"17-01-2023"}')
->setThreedsBrowser('{"accept_header"=>"*/*", "java_enabled"=>"false", "language"=>"en-GB", "color_depth"=>"24", "screen_height"=>"900", "screen_width"=>"1440", "time_zone_offset"=>"-120", "user_agent"=>"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"}')
->setThreedsSdk('{"interface"=>"native", "ui_types"=>{"ui_type"=>"multi_select"}, "application_id"=>"fc1650c0-5778-0138-8205-2cbc32a32d65", "encrypted_data"=>"encrypted-data-here", "ephemeral_public_key_pair"=>"public-key-pair", "max_timeout"=>"10", "reference_number"=>"sdk-reference-number-here"}')
// Sca Params
->setScaExemption('low_risk')
->set#<Proc:0x00005586a289dd38 includes::Transactions::3ds::V2::Examples::Requests.md.erb:219 (lambda)>('');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.Authorize3DRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
Authorize3DRequest request = new Authorize3DRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4012000000060085");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
request.setNotificationUrl(new URL("https://www.example.com/notification"));
request.setReturnSuccessUrl(new URL("http://www.example.com/success"));
request.setReturnFailureUrl(new URL("http://www.example.com/failure"));
// Threeds V2 Params
request.setThreedsThreedsMethod("{"callback_url"=>"https://www.example.com/threeds/threeds_method/callback"}");
request.setThreedsControl("{"device_type"=>"browser", "challenge_window_size"=>"full_screen", "challenge_indicator"=>"preference"}");
request.setThreedsPurchase("{"category"=>"service"}");
request.setThreedsRecurring("{"expiration_date"=>"17-07-2025", "frequency"=>30}");
request.setThreedsMerchantRisk("{"shipping_indicator"=>"verified_address", "delivery_timeframe"=>"electronic", "reorder_items_indicator"=>"reordered", "pre_order_purchase_indicator"=>"merchandise_available", "pre_order_date"=>"17-02-2025", "gift_card"=>"true", "gift_card_count"=>"2"}");
request.setThreedsCardHolderAccount("{"creation_date"=>"17-01-2024", "update_indicator"=>"more_than_60days", "last_change_date"=>"17-10-2024", "password_change_indicator"=>"no_change", "password_change_date"=>"02-01-2025", "shipping_address_usage_indicator"=>"current_transaction", "shipping_address_date_first_used"=>"12-01-2025", "transactions_activity_last_24_hours"=>"2", "transactions_activity_previous_year"=>"10", "provision_attempts_last_24_hours"=>"1", "purchases_count_last_6_months"=>"5", "suspicious_activity_indicator"=>"no_suspicious_observed", "registration_indicator"=>"30_to_60_days", "registration_date"=>"17-01-2023"}");
request.setThreedsBrowser("{"accept_header"=>"*/*", "java_enabled"=>"false", "language"=>"en-GB", "color_depth"=>"24", "screen_height"=>"900", "screen_width"=>"1440", "time_zone_offset"=>"-120", "user_agent"=>"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"}");
request.setThreedsSdk("{"interface"=>"native", "ui_types"=>{"ui_type"=>"multi_select"}, "application_id"=>"fc1650c0-5778-0138-8205-2cbc32a32d65", "encrypted_data"=>"encrypted-data-here", "ephemeral_public_key_pair"=>"public-key-pair", "max_timeout"=>"10", "reference_number"=>"sdk-reference-number-here"}");
// Sca Params
request.setScaExemption("low_risk");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.authorize3d(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "4012000000060085",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"notification_url": "https://www.example.com/notification",
"return_success_url": "http://www.example.com/success",
"return_failure_url": "http://www.example.com/failure",
"threeds_v2_params": {
"threeds_method": {
"callback_url": "https://www.example.com/threeds/threeds_method/callback"
},
"control": {
"device_type": "browser",
"challenge_window_size": "full_screen",
"challenge_indicator": "preference"
},
"purchase": {
"category": "service"
},
"recurring": {
"expiration_date": "17-07-2025",
"frequency": 30
},
"merchant_risk": {
"shipping_indicator": "verified_address",
"delivery_timeframe": "electronic",
"reorder_items_indicator": "reordered",
"pre_order_purchase_indicator": "merchandise_available",
"pre_order_date": "17-02-2025",
"gift_card": "true",
"gift_card_count": "2"
},
"card_holder_account": {
"creation_date": "17-01-2024",
"update_indicator": "more_than_60days",
"last_change_date": "17-10-2024",
"password_change_indicator": "no_change",
"password_change_date": "02-01-2025",
"shipping_address_usage_indicator": "current_transaction",
"shipping_address_date_first_used": "12-01-2025",
"transactions_activity_last_24_hours": "2",
"transactions_activity_previous_year": "10",
"provision_attempts_last_24_hours": "1",
"purchases_count_last_6_months": "5",
"suspicious_activity_indicator": "no_suspicious_observed",
"registration_indicator": "30_to_60_days",
"registration_date": "17-01-2023"
},
"browser": {
"accept_header": "*/*",
"java_enabled": "false",
"language": "en-GB",
"color_depth": "24",
"screen_height": "900",
"screen_width": "1440",
"time_zone_offset": "-120",
"user_agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"
},
"sdk": {
"interface": "native",
"ui_types": {
"ui_type": "multi_select"
},
"application_id": "fc1650c0-5778-0138-8205-2cbc32a32d65",
"encrypted_data": "encrypted-data-here",
"ephemeral_public_key_pair": "public-key-pair",
"max_timeout": "10",
"reference_number": "sdk-reference-number-here"
}
},
"sca_params": {
"exemption": "low_risk"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>authorize3d</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4012000000060085</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<notification_url>https://www.example.com/notification</notification_url>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<threeds_v2_params>
<threeds_method>
<callback_url>https://www.example.com/threeds/threeds_method/callback</callback_url>
</threeds_method>
<control>
<device_type>browser</device_type>
<challenge_window_size>full_screen</challenge_window_size>
<challenge_indicator>preference</challenge_indicator>
</control>
<purchase>
<category>service</category>
</purchase>
<merchant_risk>
<shipping_indicator>verified_address</shipping_indicator>
<delivery_timeframe>electronic</delivery_timeframe>
<reorder_items_indicator>reordered</reorder_items_indicator>
<pre_order_purchase_indicator>merchandise_available</pre_order_purchase_indicator>
<pre_order_date>17-02-2025</pre_order_date>
<gift_card>true</gift_card>
<gift_card_count>2</gift_card_count>
</merchant_risk>
<card_holder_account>
<creation_date>17-01-2024</creation_date>
<update_indicator>more_than_60days</update_indicator>
<last_change_date>17-10-2024</last_change_date>
<password_change_indicator>no_change</password_change_indicator>
<password_change_date>02-01-2025</password_change_date>
<shipping_address_usage_indicator>current_transaction</shipping_address_usage_indicator>
<shipping_address_date_first_used>12-01-2025</shipping_address_date_first_used>
<transactions_activity_last_24_hours>2</transactions_activity_last_24_hours>
<transactions_activity_previous_year>10</transactions_activity_previous_year>
<provision_attempts_last_24_hours>1</provision_attempts_last_24_hours>
<purchases_count_last_6_months>5</purchases_count_last_6_months>
<suspicious_activity_indicator>no_suspicious_observed</suspicious_activity_indicator>
<registration_indicator>30_to_60_days</registration_indicator>
<registration_date>17-01-2023</registration_date>
</card_holder_account>
<browser>
<accept_header>*/*</accept_header>
<java_enabled>false</java_enabled>
<language>en-GB</language>
<color_depth>24</color_depth>
<screen_height>900</screen_height>
<screen_width>1440</screen_width>
<time_zone_offset>-120</time_zone_offset>
<user_agent>Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36</user_agent>
</browser>
<sdk>
<interface>native</interface>
<ui_types>
<ui_type>multi_select</ui_type>
</ui_types>
<application_id>fc1650c0-5778-0138-8205-2cbc32a32d65</application_id>
<encrypted_data>encrypted-data-here</encrypted_data>
<ephemeral_public_key_pair>public-key-pair</ephemeral_public_key_pair>
<max_timeout>10</max_timeout>
<reference_number>sdk-reference-number-here</reference_number>
</sdk>
</threeds_v2_params>
<sca_params>
<exemption>low_risk</exemption>
</sca_params>
</payment_transaction>'
Asynchronous 3 D Sv2 Frictionless With 3ds Method Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Authorize3D');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('4066330000000004')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
->setNotificationUrl('https://www.example.com/notification')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
// Threeds V2 Params
->setThreedsThreedsMethod('{"callback_url"=>"https://www.example.com/threeds/threeds_method/callback"}')
->setThreedsControl('{"device_type"=>"browser", "challenge_window_size"=>"full_screen", "challenge_indicator"=>"preference"}')
->setThreedsPurchase('{"category"=>"service"}')
->setThreedsRecurring('{"expiration_date"=>"17-07-2025", "frequency"=>30}')
->setThreedsMerchantRisk('{"shipping_indicator"=>"verified_address", "delivery_timeframe"=>"electronic", "reorder_items_indicator"=>"reordered", "pre_order_purchase_indicator"=>"merchandise_available", "pre_order_date"=>"17-02-2025", "gift_card"=>"true", "gift_card_count"=>"2"}')
->setThreedsCardHolderAccount('{"creation_date"=>"17-01-2024", "update_indicator"=>"more_than_60days", "last_change_date"=>"17-10-2024", "password_change_indicator"=>"no_change", "password_change_date"=>"02-01-2025", "shipping_address_usage_indicator"=>"current_transaction", "shipping_address_date_first_used"=>"12-01-2025", "transactions_activity_last_24_hours"=>"2", "transactions_activity_previous_year"=>"10", "provision_attempts_last_24_hours"=>"1", "purchases_count_last_6_months"=>"5", "suspicious_activity_indicator"=>"no_suspicious_observed", "registration_indicator"=>"30_to_60_days", "registration_date"=>"17-01-2023"}')
->setThreedsBrowser('{"accept_header"=>"*/*", "java_enabled"=>"false", "language"=>"en-GB", "color_depth"=>"24", "screen_height"=>"900", "screen_width"=>"1440", "time_zone_offset"=>"-120", "user_agent"=>"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"}')
->setThreedsSdk('{"interface"=>"native", "ui_types"=>{"ui_type"=>"multi_select"}, "application_id"=>"fc1650c0-5778-0138-8205-2cbc32a32d65", "encrypted_data"=>"encrypted-data-here", "ephemeral_public_key_pair"=>"public-key-pair", "max_timeout"=>"10", "reference_number"=>"sdk-reference-number-here"}')
// Sca Params
->setScaExemption('low_risk')
->set#<Proc:0x00005586a2beea50 includes::Transactions::3ds::V2::Examples::Requests.md.erb:219 (lambda)>('');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.Authorize3DRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
Authorize3DRequest request = new Authorize3DRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4066330000000004");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
request.setNotificationUrl(new URL("https://www.example.com/notification"));
request.setReturnSuccessUrl(new URL("http://www.example.com/success"));
request.setReturnFailureUrl(new URL("http://www.example.com/failure"));
// Threeds V2 Params
request.setThreedsThreedsMethod("{"callback_url"=>"https://www.example.com/threeds/threeds_method/callback"}");
request.setThreedsControl("{"device_type"=>"browser", "challenge_window_size"=>"full_screen", "challenge_indicator"=>"preference"}");
request.setThreedsPurchase("{"category"=>"service"}");
request.setThreedsRecurring("{"expiration_date"=>"17-07-2025", "frequency"=>30}");
request.setThreedsMerchantRisk("{"shipping_indicator"=>"verified_address", "delivery_timeframe"=>"electronic", "reorder_items_indicator"=>"reordered", "pre_order_purchase_indicator"=>"merchandise_available", "pre_order_date"=>"17-02-2025", "gift_card"=>"true", "gift_card_count"=>"2"}");
request.setThreedsCardHolderAccount("{"creation_date"=>"17-01-2024", "update_indicator"=>"more_than_60days", "last_change_date"=>"17-10-2024", "password_change_indicator"=>"no_change", "password_change_date"=>"02-01-2025", "shipping_address_usage_indicator"=>"current_transaction", "shipping_address_date_first_used"=>"12-01-2025", "transactions_activity_last_24_hours"=>"2", "transactions_activity_previous_year"=>"10", "provision_attempts_last_24_hours"=>"1", "purchases_count_last_6_months"=>"5", "suspicious_activity_indicator"=>"no_suspicious_observed", "registration_indicator"=>"30_to_60_days", "registration_date"=>"17-01-2023"}");
request.setThreedsBrowser("{"accept_header"=>"*/*", "java_enabled"=>"false", "language"=>"en-GB", "color_depth"=>"24", "screen_height"=>"900", "screen_width"=>"1440", "time_zone_offset"=>"-120", "user_agent"=>"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"}");
request.setThreedsSdk("{"interface"=>"native", "ui_types"=>{"ui_type"=>"multi_select"}, "application_id"=>"fc1650c0-5778-0138-8205-2cbc32a32d65", "encrypted_data"=>"encrypted-data-here", "ephemeral_public_key_pair"=>"public-key-pair", "max_timeout"=>"10", "reference_number"=>"sdk-reference-number-here"}");
// Sca Params
request.setScaExemption("low_risk");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.authorize3d(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "4066330000000004",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"notification_url": "https://www.example.com/notification",
"return_success_url": "http://www.example.com/success",
"return_failure_url": "http://www.example.com/failure",
"threeds_v2_params": {
"threeds_method": {
"callback_url": "https://www.example.com/threeds/threeds_method/callback"
},
"control": {
"device_type": "browser",
"challenge_window_size": "full_screen",
"challenge_indicator": "preference"
},
"purchase": {
"category": "service"
},
"recurring": {
"expiration_date": "17-07-2025",
"frequency": 30
},
"merchant_risk": {
"shipping_indicator": "verified_address",
"delivery_timeframe": "electronic",
"reorder_items_indicator": "reordered",
"pre_order_purchase_indicator": "merchandise_available",
"pre_order_date": "17-02-2025",
"gift_card": "true",
"gift_card_count": "2"
},
"card_holder_account": {
"creation_date": "17-01-2024",
"update_indicator": "more_than_60days",
"last_change_date": "17-10-2024",
"password_change_indicator": "no_change",
"password_change_date": "02-01-2025",
"shipping_address_usage_indicator": "current_transaction",
"shipping_address_date_first_used": "12-01-2025",
"transactions_activity_last_24_hours": "2",
"transactions_activity_previous_year": "10",
"provision_attempts_last_24_hours": "1",
"purchases_count_last_6_months": "5",
"suspicious_activity_indicator": "no_suspicious_observed",
"registration_indicator": "30_to_60_days",
"registration_date": "17-01-2023"
},
"browser": {
"accept_header": "*/*",
"java_enabled": "false",
"language": "en-GB",
"color_depth": "24",
"screen_height": "900",
"screen_width": "1440",
"time_zone_offset": "-120",
"user_agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"
},
"sdk": {
"interface": "native",
"ui_types": {
"ui_type": "multi_select"
},
"application_id": "fc1650c0-5778-0138-8205-2cbc32a32d65",
"encrypted_data": "encrypted-data-here",
"ephemeral_public_key_pair": "public-key-pair",
"max_timeout": "10",
"reference_number": "sdk-reference-number-here"
}
},
"sca_params": {
"exemption": "low_risk"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>authorize3d</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4066330000000004</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<notification_url>https://www.example.com/notification</notification_url>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<threeds_v2_params>
<threeds_method>
<callback_url>https://www.example.com/threeds/threeds_method/callback</callback_url>
</threeds_method>
<control>
<device_type>browser</device_type>
<challenge_window_size>full_screen</challenge_window_size>
<challenge_indicator>preference</challenge_indicator>
</control>
<purchase>
<category>service</category>
</purchase>
<merchant_risk>
<shipping_indicator>verified_address</shipping_indicator>
<delivery_timeframe>electronic</delivery_timeframe>
<reorder_items_indicator>reordered</reorder_items_indicator>
<pre_order_purchase_indicator>merchandise_available</pre_order_purchase_indicator>
<pre_order_date>17-02-2025</pre_order_date>
<gift_card>true</gift_card>
<gift_card_count>2</gift_card_count>
</merchant_risk>
<card_holder_account>
<creation_date>17-01-2024</creation_date>
<update_indicator>more_than_60days</update_indicator>
<last_change_date>17-10-2024</last_change_date>
<password_change_indicator>no_change</password_change_indicator>
<password_change_date>02-01-2025</password_change_date>
<shipping_address_usage_indicator>current_transaction</shipping_address_usage_indicator>
<shipping_address_date_first_used>12-01-2025</shipping_address_date_first_used>
<transactions_activity_last_24_hours>2</transactions_activity_last_24_hours>
<transactions_activity_previous_year>10</transactions_activity_previous_year>
<provision_attempts_last_24_hours>1</provision_attempts_last_24_hours>
<purchases_count_last_6_months>5</purchases_count_last_6_months>
<suspicious_activity_indicator>no_suspicious_observed</suspicious_activity_indicator>
<registration_indicator>30_to_60_days</registration_indicator>
<registration_date>17-01-2023</registration_date>
</card_holder_account>
<browser>
<accept_header>*/*</accept_header>
<java_enabled>false</java_enabled>
<language>en-GB</language>
<color_depth>24</color_depth>
<screen_height>900</screen_height>
<screen_width>1440</screen_width>
<time_zone_offset>-120</time_zone_offset>
<user_agent>Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36</user_agent>
</browser>
<sdk>
<interface>native</interface>
<ui_types>
<ui_type>multi_select</ui_type>
</ui_types>
<application_id>fc1650c0-5778-0138-8205-2cbc32a32d65</application_id>
<encrypted_data>encrypted-data-here</encrypted_data>
<ephemeral_public_key_pair>public-key-pair</ephemeral_public_key_pair>
<max_timeout>10</max_timeout>
<reference_number>sdk-reference-number-here</reference_number>
</sdk>
</threeds_v2_params>
<sca_params>
<exemption>low_risk</exemption>
</sca_params>
</payment_transaction>'
Asynchronous 3 D Sv2 Challenge No 3ds Method Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Authorize3D');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('4918190000000002')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
->setNotificationUrl('https://www.example.com/notification')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
// Threeds V2 Params
->setThreedsThreedsMethod('{"callback_url"=>"https://www.example.com/threeds/threeds_method/callback"}')
->setThreedsControl('{"device_type"=>"browser", "challenge_window_size"=>"full_screen", "challenge_indicator"=>"preference"}')
->setThreedsPurchase('{"category"=>"service"}')
->setThreedsRecurring('{"expiration_date"=>"17-07-2025", "frequency"=>30}')
->setThreedsMerchantRisk('{"shipping_indicator"=>"verified_address", "delivery_timeframe"=>"electronic", "reorder_items_indicator"=>"reordered", "pre_order_purchase_indicator"=>"merchandise_available", "pre_order_date"=>"17-02-2025", "gift_card"=>"true", "gift_card_count"=>"2"}')
->setThreedsCardHolderAccount('{"creation_date"=>"17-01-2024", "update_indicator"=>"more_than_60days", "last_change_date"=>"17-10-2024", "password_change_indicator"=>"no_change", "password_change_date"=>"02-01-2025", "shipping_address_usage_indicator"=>"current_transaction", "shipping_address_date_first_used"=>"12-01-2025", "transactions_activity_last_24_hours"=>"2", "transactions_activity_previous_year"=>"10", "provision_attempts_last_24_hours"=>"1", "purchases_count_last_6_months"=>"5", "suspicious_activity_indicator"=>"no_suspicious_observed", "registration_indicator"=>"30_to_60_days", "registration_date"=>"17-01-2023"}')
->setThreedsBrowser('{"accept_header"=>"*/*", "java_enabled"=>"false", "language"=>"en-GB", "color_depth"=>"24", "screen_height"=>"900", "screen_width"=>"1440", "time_zone_offset"=>"-120", "user_agent"=>"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"}')
->setThreedsSdk('{"interface"=>"native", "ui_types"=>{"ui_type"=>"multi_select"}, "application_id"=>"fc1650c0-5778-0138-8205-2cbc32a32d65", "encrypted_data"=>"encrypted-data-here", "ephemeral_public_key_pair"=>"public-key-pair", "max_timeout"=>"10", "reference_number"=>"sdk-reference-number-here"}')
// Sca Params
->setScaExemption('low_risk')
->set#<Proc:0x000055869fcd7c30 includes::Transactions::3ds::V2::Examples::Requests.md.erb:219 (lambda)>('');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.Authorize3DRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
Authorize3DRequest request = new Authorize3DRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4918190000000002");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
request.setNotificationUrl(new URL("https://www.example.com/notification"));
request.setReturnSuccessUrl(new URL("http://www.example.com/success"));
request.setReturnFailureUrl(new URL("http://www.example.com/failure"));
// Threeds V2 Params
request.setThreedsThreedsMethod("{"callback_url"=>"https://www.example.com/threeds/threeds_method/callback"}");
request.setThreedsControl("{"device_type"=>"browser", "challenge_window_size"=>"full_screen", "challenge_indicator"=>"preference"}");
request.setThreedsPurchase("{"category"=>"service"}");
request.setThreedsRecurring("{"expiration_date"=>"17-07-2025", "frequency"=>30}");
request.setThreedsMerchantRisk("{"shipping_indicator"=>"verified_address", "delivery_timeframe"=>"electronic", "reorder_items_indicator"=>"reordered", "pre_order_purchase_indicator"=>"merchandise_available", "pre_order_date"=>"17-02-2025", "gift_card"=>"true", "gift_card_count"=>"2"}");
request.setThreedsCardHolderAccount("{"creation_date"=>"17-01-2024", "update_indicator"=>"more_than_60days", "last_change_date"=>"17-10-2024", "password_change_indicator"=>"no_change", "password_change_date"=>"02-01-2025", "shipping_address_usage_indicator"=>"current_transaction", "shipping_address_date_first_used"=>"12-01-2025", "transactions_activity_last_24_hours"=>"2", "transactions_activity_previous_year"=>"10", "provision_attempts_last_24_hours"=>"1", "purchases_count_last_6_months"=>"5", "suspicious_activity_indicator"=>"no_suspicious_observed", "registration_indicator"=>"30_to_60_days", "registration_date"=>"17-01-2023"}");
request.setThreedsBrowser("{"accept_header"=>"*/*", "java_enabled"=>"false", "language"=>"en-GB", "color_depth"=>"24", "screen_height"=>"900", "screen_width"=>"1440", "time_zone_offset"=>"-120", "user_agent"=>"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"}");
request.setThreedsSdk("{"interface"=>"native", "ui_types"=>{"ui_type"=>"multi_select"}, "application_id"=>"fc1650c0-5778-0138-8205-2cbc32a32d65", "encrypted_data"=>"encrypted-data-here", "ephemeral_public_key_pair"=>"public-key-pair", "max_timeout"=>"10", "reference_number"=>"sdk-reference-number-here"}");
// Sca Params
request.setScaExemption("low_risk");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.authorize3d(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "4918190000000002",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"notification_url": "https://www.example.com/notification",
"return_success_url": "http://www.example.com/success",
"return_failure_url": "http://www.example.com/failure",
"threeds_v2_params": {
"threeds_method": {
"callback_url": "https://www.example.com/threeds/threeds_method/callback"
},
"control": {
"device_type": "browser",
"challenge_window_size": "full_screen",
"challenge_indicator": "preference"
},
"purchase": {
"category": "service"
},
"recurring": {
"expiration_date": "17-07-2025",
"frequency": 30
},
"merchant_risk": {
"shipping_indicator": "verified_address",
"delivery_timeframe": "electronic",
"reorder_items_indicator": "reordered",
"pre_order_purchase_indicator": "merchandise_available",
"pre_order_date": "17-02-2025",
"gift_card": "true",
"gift_card_count": "2"
},
"card_holder_account": {
"creation_date": "17-01-2024",
"update_indicator": "more_than_60days",
"last_change_date": "17-10-2024",
"password_change_indicator": "no_change",
"password_change_date": "02-01-2025",
"shipping_address_usage_indicator": "current_transaction",
"shipping_address_date_first_used": "12-01-2025",
"transactions_activity_last_24_hours": "2",
"transactions_activity_previous_year": "10",
"provision_attempts_last_24_hours": "1",
"purchases_count_last_6_months": "5",
"suspicious_activity_indicator": "no_suspicious_observed",
"registration_indicator": "30_to_60_days",
"registration_date": "17-01-2023"
},
"browser": {
"accept_header": "*/*",
"java_enabled": "false",
"language": "en-GB",
"color_depth": "24",
"screen_height": "900",
"screen_width": "1440",
"time_zone_offset": "-120",
"user_agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"
},
"sdk": {
"interface": "native",
"ui_types": {
"ui_type": "multi_select"
},
"application_id": "fc1650c0-5778-0138-8205-2cbc32a32d65",
"encrypted_data": "encrypted-data-here",
"ephemeral_public_key_pair": "public-key-pair",
"max_timeout": "10",
"reference_number": "sdk-reference-number-here"
}
},
"sca_params": {
"exemption": "low_risk"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>authorize3d</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4918190000000002</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<notification_url>https://www.example.com/notification</notification_url>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<threeds_v2_params>
<threeds_method>
<callback_url>https://www.example.com/threeds/threeds_method/callback</callback_url>
</threeds_method>
<control>
<device_type>browser</device_type>
<challenge_window_size>full_screen</challenge_window_size>
<challenge_indicator>preference</challenge_indicator>
</control>
<purchase>
<category>service</category>
</purchase>
<merchant_risk>
<shipping_indicator>verified_address</shipping_indicator>
<delivery_timeframe>electronic</delivery_timeframe>
<reorder_items_indicator>reordered</reorder_items_indicator>
<pre_order_purchase_indicator>merchandise_available</pre_order_purchase_indicator>
<pre_order_date>17-02-2025</pre_order_date>
<gift_card>true</gift_card>
<gift_card_count>2</gift_card_count>
</merchant_risk>
<card_holder_account>
<creation_date>17-01-2024</creation_date>
<update_indicator>more_than_60days</update_indicator>
<last_change_date>17-10-2024</last_change_date>
<password_change_indicator>no_change</password_change_indicator>
<password_change_date>02-01-2025</password_change_date>
<shipping_address_usage_indicator>current_transaction</shipping_address_usage_indicator>
<shipping_address_date_first_used>12-01-2025</shipping_address_date_first_used>
<transactions_activity_last_24_hours>2</transactions_activity_last_24_hours>
<transactions_activity_previous_year>10</transactions_activity_previous_year>
<provision_attempts_last_24_hours>1</provision_attempts_last_24_hours>
<purchases_count_last_6_months>5</purchases_count_last_6_months>
<suspicious_activity_indicator>no_suspicious_observed</suspicious_activity_indicator>
<registration_indicator>30_to_60_days</registration_indicator>
<registration_date>17-01-2023</registration_date>
</card_holder_account>
<browser>
<accept_header>*/*</accept_header>
<java_enabled>false</java_enabled>
<language>en-GB</language>
<color_depth>24</color_depth>
<screen_height>900</screen_height>
<screen_width>1440</screen_width>
<time_zone_offset>-120</time_zone_offset>
<user_agent>Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36</user_agent>
</browser>
<sdk>
<interface>native</interface>
<ui_types>
<ui_type>multi_select</ui_type>
</ui_types>
<application_id>fc1650c0-5778-0138-8205-2cbc32a32d65</application_id>
<encrypted_data>encrypted-data-here</encrypted_data>
<ephemeral_public_key_pair>public-key-pair</ephemeral_public_key_pair>
<max_timeout>10</max_timeout>
<reference_number>sdk-reference-number-here</reference_number>
</sdk>
</threeds_v2_params>
<sca_params>
<exemption>low_risk</exemption>
</sca_params>
</payment_transaction>'
Asynchronous 3 D Sv2 Challenge With 3ds Method Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Authorize3D');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('4938730000000001')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
->setNotificationUrl('https://www.example.com/notification')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
// Threeds V2 Params
->setThreedsThreedsMethod('{"callback_url"=>"https://www.example.com/threeds/threeds_method/callback"}')
->setThreedsControl('{"device_type"=>"browser", "challenge_window_size"=>"full_screen", "challenge_indicator"=>"preference"}')
->setThreedsPurchase('{"category"=>"service"}')
->setThreedsRecurring('{"expiration_date"=>"17-07-2025", "frequency"=>30}')
->setThreedsMerchantRisk('{"shipping_indicator"=>"verified_address", "delivery_timeframe"=>"electronic", "reorder_items_indicator"=>"reordered", "pre_order_purchase_indicator"=>"merchandise_available", "pre_order_date"=>"17-02-2025", "gift_card"=>"true", "gift_card_count"=>"2"}')
->setThreedsCardHolderAccount('{"creation_date"=>"17-01-2024", "update_indicator"=>"more_than_60days", "last_change_date"=>"17-10-2024", "password_change_indicator"=>"no_change", "password_change_date"=>"02-01-2025", "shipping_address_usage_indicator"=>"current_transaction", "shipping_address_date_first_used"=>"12-01-2025", "transactions_activity_last_24_hours"=>"2", "transactions_activity_previous_year"=>"10", "provision_attempts_last_24_hours"=>"1", "purchases_count_last_6_months"=>"5", "suspicious_activity_indicator"=>"no_suspicious_observed", "registration_indicator"=>"30_to_60_days", "registration_date"=>"17-01-2023"}')
->setThreedsBrowser('{"accept_header"=>"*/*", "java_enabled"=>"false", "language"=>"en-GB", "color_depth"=>"24", "screen_height"=>"900", "screen_width"=>"1440", "time_zone_offset"=>"-120", "user_agent"=>"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"}')
->setThreedsSdk('{"interface"=>"native", "ui_types"=>{"ui_type"=>"multi_select"}, "application_id"=>"fc1650c0-5778-0138-8205-2cbc32a32d65", "encrypted_data"=>"encrypted-data-here", "ephemeral_public_key_pair"=>"public-key-pair", "max_timeout"=>"10", "reference_number"=>"sdk-reference-number-here"}')
// Sca Params
->setScaExemption('low_risk')
->set#<Proc:0x00005586a17ea608 includes::Transactions::3ds::V2::Examples::Requests.md.erb:219 (lambda)>('');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.Authorize3DRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
Authorize3DRequest request = new Authorize3DRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4938730000000001");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
request.setNotificationUrl(new URL("https://www.example.com/notification"));
request.setReturnSuccessUrl(new URL("http://www.example.com/success"));
request.setReturnFailureUrl(new URL("http://www.example.com/failure"));
// Threeds V2 Params
request.setThreedsThreedsMethod("{"callback_url"=>"https://www.example.com/threeds/threeds_method/callback"}");
request.setThreedsControl("{"device_type"=>"browser", "challenge_window_size"=>"full_screen", "challenge_indicator"=>"preference"}");
request.setThreedsPurchase("{"category"=>"service"}");
request.setThreedsRecurring("{"expiration_date"=>"17-07-2025", "frequency"=>30}");
request.setThreedsMerchantRisk("{"shipping_indicator"=>"verified_address", "delivery_timeframe"=>"electronic", "reorder_items_indicator"=>"reordered", "pre_order_purchase_indicator"=>"merchandise_available", "pre_order_date"=>"17-02-2025", "gift_card"=>"true", "gift_card_count"=>"2"}");
request.setThreedsCardHolderAccount("{"creation_date"=>"17-01-2024", "update_indicator"=>"more_than_60days", "last_change_date"=>"17-10-2024", "password_change_indicator"=>"no_change", "password_change_date"=>"02-01-2025", "shipping_address_usage_indicator"=>"current_transaction", "shipping_address_date_first_used"=>"12-01-2025", "transactions_activity_last_24_hours"=>"2", "transactions_activity_previous_year"=>"10", "provision_attempts_last_24_hours"=>"1", "purchases_count_last_6_months"=>"5", "suspicious_activity_indicator"=>"no_suspicious_observed", "registration_indicator"=>"30_to_60_days", "registration_date"=>"17-01-2023"}");
request.setThreedsBrowser("{"accept_header"=>"*/*", "java_enabled"=>"false", "language"=>"en-GB", "color_depth"=>"24", "screen_height"=>"900", "screen_width"=>"1440", "time_zone_offset"=>"-120", "user_agent"=>"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"}");
request.setThreedsSdk("{"interface"=>"native", "ui_types"=>{"ui_type"=>"multi_select"}, "application_id"=>"fc1650c0-5778-0138-8205-2cbc32a32d65", "encrypted_data"=>"encrypted-data-here", "ephemeral_public_key_pair"=>"public-key-pair", "max_timeout"=>"10", "reference_number"=>"sdk-reference-number-here"}");
// Sca Params
request.setScaExemption("low_risk");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.authorize3d(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "4938730000000001",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"notification_url": "https://www.example.com/notification",
"return_success_url": "http://www.example.com/success",
"return_failure_url": "http://www.example.com/failure",
"threeds_v2_params": {
"threeds_method": {
"callback_url": "https://www.example.com/threeds/threeds_method/callback"
},
"control": {
"device_type": "browser",
"challenge_window_size": "full_screen",
"challenge_indicator": "preference"
},
"purchase": {
"category": "service"
},
"recurring": {
"expiration_date": "17-07-2025",
"frequency": 30
},
"merchant_risk": {
"shipping_indicator": "verified_address",
"delivery_timeframe": "electronic",
"reorder_items_indicator": "reordered",
"pre_order_purchase_indicator": "merchandise_available",
"pre_order_date": "17-02-2025",
"gift_card": "true",
"gift_card_count": "2"
},
"card_holder_account": {
"creation_date": "17-01-2024",
"update_indicator": "more_than_60days",
"last_change_date": "17-10-2024",
"password_change_indicator": "no_change",
"password_change_date": "02-01-2025",
"shipping_address_usage_indicator": "current_transaction",
"shipping_address_date_first_used": "12-01-2025",
"transactions_activity_last_24_hours": "2",
"transactions_activity_previous_year": "10",
"provision_attempts_last_24_hours": "1",
"purchases_count_last_6_months": "5",
"suspicious_activity_indicator": "no_suspicious_observed",
"registration_indicator": "30_to_60_days",
"registration_date": "17-01-2023"
},
"browser": {
"accept_header": "*/*",
"java_enabled": "false",
"language": "en-GB",
"color_depth": "24",
"screen_height": "900",
"screen_width": "1440",
"time_zone_offset": "-120",
"user_agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"
},
"sdk": {
"interface": "native",
"ui_types": {
"ui_type": "multi_select"
},
"application_id": "fc1650c0-5778-0138-8205-2cbc32a32d65",
"encrypted_data": "encrypted-data-here",
"ephemeral_public_key_pair": "public-key-pair",
"max_timeout": "10",
"reference_number": "sdk-reference-number-here"
}
},
"sca_params": {
"exemption": "low_risk"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>authorize3d</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4938730000000001</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<notification_url>https://www.example.com/notification</notification_url>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<threeds_v2_params>
<threeds_method>
<callback_url>https://www.example.com/threeds/threeds_method/callback</callback_url>
</threeds_method>
<control>
<device_type>browser</device_type>
<challenge_window_size>full_screen</challenge_window_size>
<challenge_indicator>preference</challenge_indicator>
</control>
<purchase>
<category>service</category>
</purchase>
<merchant_risk>
<shipping_indicator>verified_address</shipping_indicator>
<delivery_timeframe>electronic</delivery_timeframe>
<reorder_items_indicator>reordered</reorder_items_indicator>
<pre_order_purchase_indicator>merchandise_available</pre_order_purchase_indicator>
<pre_order_date>17-02-2025</pre_order_date>
<gift_card>true</gift_card>
<gift_card_count>2</gift_card_count>
</merchant_risk>
<card_holder_account>
<creation_date>17-01-2024</creation_date>
<update_indicator>more_than_60days</update_indicator>
<last_change_date>17-10-2024</last_change_date>
<password_change_indicator>no_change</password_change_indicator>
<password_change_date>02-01-2025</password_change_date>
<shipping_address_usage_indicator>current_transaction</shipping_address_usage_indicator>
<shipping_address_date_first_used>12-01-2025</shipping_address_date_first_used>
<transactions_activity_last_24_hours>2</transactions_activity_last_24_hours>
<transactions_activity_previous_year>10</transactions_activity_previous_year>
<provision_attempts_last_24_hours>1</provision_attempts_last_24_hours>
<purchases_count_last_6_months>5</purchases_count_last_6_months>
<suspicious_activity_indicator>no_suspicious_observed</suspicious_activity_indicator>
<registration_indicator>30_to_60_days</registration_indicator>
<registration_date>17-01-2023</registration_date>
</card_holder_account>
<browser>
<accept_header>*/*</accept_header>
<java_enabled>false</java_enabled>
<language>en-GB</language>
<color_depth>24</color_depth>
<screen_height>900</screen_height>
<screen_width>1440</screen_width>
<time_zone_offset>-120</time_zone_offset>
<user_agent>Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36</user_agent>
</browser>
<sdk>
<interface>native</interface>
<ui_types>
<ui_type>multi_select</ui_type>
</ui_types>
<application_id>fc1650c0-5778-0138-8205-2cbc32a32d65</application_id>
<encrypted_data>encrypted-data-here</encrypted_data>
<ephemeral_public_key_pair>public-key-pair</ephemeral_public_key_pair>
<max_timeout>10</max_timeout>
<reference_number>sdk-reference-number-here</reference_number>
</sdk>
</threeds_v2_params>
<sca_params>
<exemption>low_risk</exemption>
</sca_params>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: authorize3d |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | required* | string(255) | Description of the transaction for later use. |
gaming | optional | "true" | Signifies whether a gaming transaction is performed. Gaming transactions usually use MCC 7995. Contact tech-support@emerchantpay.com for more details |
preauthorization | optional | "true" | Signifies whether a preauthorization transaction is performed. Check the Preauthorizations section or contact tech support for more details. |
moto | optional | "true" | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech-support@emerchantpay.com for more details |
crypto | optional | "true" | Signifies whether a purchase of crypto-currency transaction is performed. Must be populated when purchasing crypto-currency with a VISA card. Must be populated when purchasing crypto-currency with a MASTER or INTL MAESTRO card and MCC is one of 6051, 6211. Contact tech-support@emerchantpay.com for more details |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
notification_url | required1 | url | URL at merchant where gateway sends outcome of transaction. |
return_success_url | required1 | url | URL where customer is sent to after successful payment |
return_failure_url | required1 | url | URL where customer is sent to after unsuccessful payment |
amount | required | integer >= 0 | Transaction amount in minor currency unit, see Currency and Amount Handling for details. In certain cases, it is possible to submit a transaction with a zero-value amount to act as an account verification transaction - Contact tech-support@emerchantpay.com for more details regarding this scenario. |
currency | required | string(3) | Currency code in ISO 4217 |
card_holder | required | string(45) | Full name of customer as printed on credit card (first name and last name at least). Note, for async 3DSv2 transactions, the card holder name must NOT contain more than 45 chars. Otherwise, the rest will be truncated in the authentication request. |
card_number | required | 13 to 16 digits | Complete cc number of customer |
cvv | required | 3 to 4 digits | cvv of cc, requirement is based on terminal configuration |
expiration_month | required | MM | Expiration month as printed on credit card |
expiration_year | required | YYYY | Expiration year as printed on credit card |
token | optional | string(36) | See Tokenization for more details. If present, the cardholder parameters can be omitted. Cannot be set together with remember_card |
remember_card | optional | "true" | See Tokenize. Tokenizes cardholder parameters. Cannot be set together with token |
consumer_id | optional | string(10) | See Consumers and Tokenization. Combine with remember_card to tokenize or with token to use token |
scheme_tokenized | required* | "true" | Required when the card_number is DPAN instead of Funding Primary Account Number, see Tokenized e-commerce for details |
recurring_type | optional | string(255) | Specifies recurring type of the transaction, can be 'initial' or 'managed'. |
installment_plan_id | optional | string | The ID of the chosen installment plan. Check Installments for more details. |
installment_plan_reference | optional | string | The installment plan reference identifier returned by the schemes. |
credential_on_file | required* | See Credential On File (COF) for more details | |
initial_customer_initiated | required* | string(18) | Initial transaction initiated by customer. Required for external tokenization, and optional for gateway-based tokenization |
subsequent_customer_initiated | required* | string(18) | Subsequent transaction initiated by customer. Required for external tokenization, and optional for gateway-based tokenization |
merchant_unscheduled | optional | string(20) | Transaction is initiated by the merchant |
customer_email | required* | e-mail address | Must contain valid e-mail of customer |
customer_phone | required* | string(16) | Must contain а valid international phone number of the customer as per the ITU-T E.164. It's recommended to not submit a customer phone number containing more than 15 digits or less than 7 digits. Note, for async 3DS transactions that are using the 3DSv2 authentication protocol, it will be shortened up to 15 digits and a prefix + for international phone number will be added if missing. |
birth_date | required* | dd-mm-yyyy | Required when MCC is a Financial Services one (e.g. MCC 6012) and either card brand is Visa or Mastercard/Maestro with UK-based merchant, UK-based bin (domestic), and DEBIT card type |
document_id | required* | string(255) | Document ID value. |
fx_rate_id | optional | integer | See Get rates for FX Service. Offers the option to use a specific FX rate to convert the transaction processing amount. Used FX rate should have the same source currency as the processing currency. Contact tech-support@emerchantpay.com for more details |
business_attributes | required* | Check business attributes section. | |
event_start_date | required* | dd-mm-yyyy | The date when event starts in format dd-mm-yyyy |
event_end_date | required* | dd-mm-yyyy | The date when event ends in format dd-mm-yyyy |
event_organizer_id | required* | string | |
event_id | required* | string | |
date_of_order | required* | dd-mm-yyyy | The date when order was placed in format dd-mm-yyyy |
delivery_date | required* | dd-mm-yyyy | Date of the expected delivery in format dd-mm-yyyy |
name_of_the_supplier | required* | string | |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(150) | Primary address. The field length is limited to 150 chars only for async 3DS transactions that are using the 3DSv2 authentication protocol. |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string(16) | The field that holds the zip code is limited to 16 chars only for async 3DS transactions that are using the 3DSv2 authentication protocol. |
city | required* | string(50) | The field that holds the city is limited to 50 chars only for async 3DS transactions that are using the 3DSv2 authentication protocol. |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(3) | The field that holds the country state is limited to 3 chars only for async 3DS transactions that are using the 3DSv2 authentication protocol. Note: The value should be the country subdivision code defined in ISO 3166-2. Invalid values submitted NOT as per the ISO might lead to data integrity issues. |
country | required* | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(150) | Primary address. The field length is limited to 150 chars only for async 3DS transactions that are using the 3DSv2 authentication protocol. |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string(16) | The field that holds the zip code is limited to 16 chars only for async 3DS transactions that are using the 3DSv2 authentication protocol. |
city | optional | string(50) | The field that holds the city is limited to 50 chars only for async 3DS transactions that are using the 3DSv2 authentication protocol. |
neighborhood | optional | string(255) | Neighborhood |
state | optional | string(3) | The field that holds the country state is limited to 3 chars only for async 3DS transactions that are using the 3DSv2 authentication protocol. Note: The value should be the country subdivision code defined in ISO 3166-2. Invalid values submitted NOT as per the ISO might lead to data integrity issues. |
country | optional | string(2) | Country code in ISO 3166 |
mpi_params | required2 | ||
cavv | required3 | string(255) | Verification Id of the authentication. Please note this can be the CAVV for Visa Card or UCAF to identify MasterCard. |
eci | required3 | string(255) | See Electronic Commerce Indicator as returned from the MPI for details |
protocol_version | required4 | string | The used 3DS protocol version. |
protocol_sub_version | required4 | string | The used 3DS protocol sub-version. |
directory_server_id | required4 | string | The Directory Server ID used for 3DSecure transactions through the 3DSv2 authentication protocol. |
acs_transaction_id | optional | string | The ACS Transaction ID and is optional for 3DS transactions, but highly recommended for increasing the approval ratio. |
threeds_challenge_indicator | optional | string | The 3DS challenge indicator that represents the exact indicator used during the authentication request to the MPI provider for synchronous 3DS transactions. It is optional but highly recommended for increasing the approval ratio. It can only contain one of the following values no_preference, no_challenge_requested, preference and mandate. The default value is no_preference. Check 3DS Challenge Indicators for more details. |
sca_params | optional | SCA params | |
exemption | optional | string | The exemption that the transaction should take advantage of. Note that the requested exemption may not be accepted due to internal risk validations. Check SCA exemption values. |
visa_merchant_id | required5 | string(8) | VMID assigned by Visa if participating in Trusted merchant program. |
funding | optional | Funding Transaction Params | |
identifier_type | required* | string | This is only required in case of Mastercard. Type of Funding Transaction. Please check Identifier Types |
business_application_identifier | required* | string | This is only required in case of VISA. Type of VISA Funding Transaction. Please check BAI |
receiver | optional | Funding Transaction Receiver details | |
first_name | required* | string | First name of the receiver |
last_name | required* | string | Last name of the receiver |
country | required* | string(2) | Country code in ISO 3166 |
account_number | required* | string | Receiver account number. Mandatory for Mastercard. If Sender Reference Number is provided then it becomes optional for VISA |
account_number_type | required* | string | This is only required in case of Mastercard. Receiver account number type. Please check Receiver Account Types |
address | required* | string | Receiver address. Only required in case of VISA and Canadian cards |
state | required* | string | Receiver state. Only required in case of VISA and Canadian cards |
city | required* | string | Receiver city. Only required in case of VISA and Canadian cards |
sender | optional | Funding Transaction Sender details | |
name | required* | string | Sender name. Only required in case of VISA |
reference_number | required* | string | Sender Reference Number. Only required in case of VISA. This is option if Receiver Account Number is provided |
country | required* | string | Sender country. Only required in case of VISA. If not provided billing address is used |
address | required* | string | Sender address. Only required in case of VISA. If not provided billing address is used |
state | required* | string | Sender state. Only required in case of VISA and Canadian card. If not provided billing address is used |
city | required* | string | Sender city. Only required in case of VISA. If not provided billing address is used |
threeds_v2_params | required* | 3DSv2 async parameters. They must be submitted in order to use the 3DSv2 authentication protocol in asynchronous workflow | |
threeds_method | optional | 3DS-Method related parameters for any callbacks and notifications. | |
callback_url | optional | url | Specific 3DS-Method callback URL after the 3DS-Method completes. The actual status will be provided via HTTP POST to that URL. For more information, go to 3DSv2 method params |
control | required* | General params for preferences in authentication flow and providing device interface information. | |
device_type | required* | string | Identifies the device channel of the consumer, required in the 3DSv2 authentication protocol. For more information, go to 3DSv2 control params |
challenge_window_size | required* | string | Identifies the size of the challenge window for the consumer. For more information, go to 3DSv2 control params |
challenge_indicator | optional | string | The value has weight and might impact the decision whether a challenge will be required for the transaction or not. If not provided, it will be interpreted as no_preference. For more information, go to 3DSv2 control params |
purchase | optional | Purchase related params providing with additional information regarding the order. | |
category | optional | string | Identifies the type of transaction being authenticated. This field is required in some markets.Accepted values are: goods, service, check_acceptance, account_funding, quasi_cash, prepaid_activation, loan. |
merchant_risk | recommended | Merchant risk assessment params. They are all optional, but recommended. | |
shipping_indicator | optional | string(16) | Indicator code that most accurately describes the shipping method for the cardholder specific transaction. If one or more items are included in the sale, use the Shipping Indicator code for the physical goods. If all digital goods, use the code that describes the most expensive item. Accepted values are: same_as_billing, stored_address, verified_address, pick_up, digital_goods, travel, event_tickets, other. |
delivery_timeframe | optional | string(11) | Indicates the merchandise delivery timeframe. Accepted values are: electronic, same_day, over_night, another_day. |
reorder_items_indicator | optional | string(10) | Indicates whether the cardholder is reordering previously purchased merchandise. Accepted values are: first_time, reordered. |
pre_order_purchase_indicator | optional | string(21) | Indicates whether cardholder is placing an order for merchandise with a future-availability or release date. Accepted values are: merchandise_available, future_availability. |
pre_order_date | optional | dd-mm-yyyy | For a pre-ordered purchase, the expected date that the merchandise will be available. |
gift_card | optional | 'true' | Prepaid or gift card purchase. |
gift_card_count | optional | integer | For prepaid or gift card purchase, total count of individual prepaid or gift cards/codes purchased. The value is limited to 99. |
card_holder_account | recommended | Cardholder account additional information. They are all optional, but recommended, because they have a significant impact on approval rates | |
creation_date | optional | dd-mm-yyyy | Date that the cardholder opened the account with the 3DS Requester. |
update_indicator | optional | string(19) | Length of time since the cardholder’s account information with the 3DS Requestor was last changed. Includes Billing or Shipping address, new payment account, or new user(s) added. Accepted values are: current_transaction, less_than_30days, 30_to_60_days, more_than_60days. |
last_change_date | optional | dd-mm-yyyy | Date that the cardholder’s account with the 3DS Requestor was last changed. Including Billing or Shipping address, new payment accout, or new user(s) added. |
password_change_indicator | optional | string(18) | Length of time since the cardholder account with the 3DS Requestor had a password change or account reset. Accepted values are: no_change, during_transaction, less_than_30days, 30_to_60_days, more_than_60days. |
password_change_date | optional | dd-mm-yyyy | Date that cardholder’s account with the 3DS Requestor had a password change or account reset. |
shipping_address_usage_indicator | optional | string(19) | Indicates when the shipping address used for this transaction was first used with the 3DS Requestor. Accepted values are: current_transaction, less_than_30days, 30_to_60_days, more_than_60days. |
shipping_address_date_first_used | optional | dd-mm-yyyy | Date when the shipping address used for this transaction was first used with the 3DS Requestor. |
transactions_activity_last_24_hours | optional | integer | Number of transactions (successful and abandoned) for this cardholder account with the 3DS Requestor across all payment accounts in the previous 24 hours. |
transactions_activity_previous_year | optional | integer | Number of transactions (successful and abandoned) for this cardholder account with the 3DS Requestor across all payment accounts in the previous year. |
provision_attempts_last_24_hours | optional | integer | Number of Add Card attempts in the last 24 hours. |
purchases_count_last_6_months | optional | integer | Number of purchases with this cardholder account during the previous six months. |
suspicious_activity_indicator | optional | string(22) | Indicates whether the 3DS Requestor has experienced suspicious activity (including previous fraud) on the cardholder account. Accepted values are: no_suspicious_observed, suspicious_observed. |
registration_indicator | optional | string(19) | Indicates the length of time that the payment account was enrolled in the cardholder’s account with the 3DS Requester. Accepted values are: guest_checkout, current_transaction, less_than_30days, 30_to_60_days, more_than_60days. |
registration_date | optional | dd-mm-yyyy | Date that the payment account was enrolled in the cardholder’s account with the 3DS Requestor. |
browser | required* | For browser-based transactions. They are all required in case the device_type is set to browser | |
accept_header | required* | string(2048) | The exact content of the HTTP ACCEPT header as sent to the 3DS Requester from the Cardholder browser. Any other header different than the ACCEPT header will be rejected. Example: application/json,text/plain,text/html,*/* . |
java_enabled | required* | boolean | Boolean that represents the ability of the cardholder browser to execute Java. The value can be retrieved by accessing a property of the navigator with JavaScript, navigator.javaEnabled . |
language | required* | string(8) | Value representing the browser language as defined in IETF BCP47. Note that only one browser language tag is about to be submitted as per the above IETF BCP47. Numeric chars are also allowed in the subtag and will represent the region.Example: en-GB , zh-guoyu , fil-PH , gsw , es-419 , de-1996 , etc. The value can be retrieved by accessing a property of the navigator with JavaScript, navigator.language . |
color_depth | required* | integer | Value representing the bit depth of the colour palette for displaying images, in bits per pixel. Obtained from Cardholder browser using the screen.colorDepth property. The value as per EMVCo specs can be one of 1, 4, 8, 15, 16, 24, 32, 48. In case, an unsupported color_depth is determined, the nearest supported value that is less than the actual one needs to be submitted. For example, if the obtained value is 30, which is not supported as per EMVCo specs, 24 has to be submitted. |
screen_height | required* | integer | Total height of the Cardholder's screen in pixels. Value is returned from the screen.height property. |
screen_width | required* | integer | Total width of the Cardholder's screen in pixels. Value is returned from the screen.width property. |
time_zone_offset | required* | string(5) | Time difference between UTC time and the Cardholder browser local time, in minutes. Note that the offset is positive if the local time zone is behind UTC and negative if it is ahead. If UTC -5 hours then submit 300 or +300 , If UTC +2 hours then -120 . The value can be retrieved using Javascript getTimezoneOffset() method over Date object. |
user_agent | required* | string(2048) | Exact content of the HTTP user-agent header. |
sdk | required* | For application-based transactions. They are all required in case the device_type is set to application | |
interface | required* | string(6) | SDK Interface types that the device of the consumer supports for displaying specific challenge interfaces within the SDK. Accepted values are: native, html, both. |
ui_types | required* | Lists all UI types that the device of the consumer supports for displaying specific challenge interfaces within the SDK. | |
ui_type | required* | string(13) | UI type that the device of the consumer supports for displaying specific challenge interface. Accepted values are: text, single_select, multi_select, out_of_bag, other_html. |
application_id | required* | string(36) | Universally unique ID created upon all installations and updates of the 3DS Requestor APp on a Customer Device. This will be newly generated and stored by the 3DS SDK for each installation or update. The field is limited to 36 characters and it shall have a canonical format as defined in IETF RFC 4122. |
encrypted_data | required* | string(64000) | JWE Object as defined Section 6.2.2.1 containing data encrypted by the SDK for the DS to decrypt. The data will be present when sending to DS, but not present from DS to ACS. |
ephemeral_public_key_pair | required* | string(256) | Public key component of the ephemeral key pair generated by the 3DS SDK and used to establish session keys between the 3DS SDK and ACS. In AReq, this data element is contained within the ACS Signed Content JWS Object. The field is limited to maximum 256 characters. |
max_timeout | required* | integer | Indicates the maximum amount of time (in minutes) for all exchanges. The field shall have value greater or equals than 05. |
reference_number | required* | string(32) | Identifies the vendor and version of the 3DS SDK that is integrated in a 3DS Requestor App, assigned by EMVCo when the 3DS SDK is approved. The field is limited to 32 characters. |
dynamic_descriptor_params | optional | ||
merchant_name | optional | string(25) | Allows to dynamically override the charge descriptor |
merchant_city | optional | string(13) | Allows to dynamically override the merchant phone number |
sub_merchant_id | optional | string(15) | Allows to dynamically override the sub-merchant ID. |
merchant_country | optional | string(3) | Allows to dynamically override the merchant country. |
merchant_state | optional | string(3) | Allows to dynamically override the merchant subdivision code. |
merchant_zip_code | optional | string(10) | Allows to dynamically override the merchant zip/postal code. Required for VISA OCT transactions with Australian and Canadian card bins. |
merchant_address | optional | string(48) | Allows to dynamically override the merchant address. |
merchant_url | optional | string(60) | Allows to dynamically override the merchant URL |
merchant_phone | optional | string(16) | Allows to dynamically override the merchant phone number. |
merchant_service_city | optional | string(13) | Allows to dynamically override the merchant service city. |
merchant_service_country | optional | string(3) | Allows to dynamically override the merchant service country. |
merchant_service_state | optional | string(3) | Allows to dynamically override the merchant service subdivision code. |
merchant_service_zip_code | optional | string(10) | Allows to dynamically override the merchant service zip/postal code. |
merchant_service_phone | optional | string(16) | Allows to dynamically override the merchant service phone number. |
merchant_geo_coordinates | optional | string(20) | Allows to dynamically override the merchant geographic coordinates. |
merchant_service_geo_coordinates | optional | string(20) | Allows to dynamically override the merchant service geographic coordinates. |
required* = conditionally required
1 - Required if mpi_params
is not present, the transaction will be handled asynchronously. Not required if configured on Terminal or Merchant level. Contact Tech Support for more details.
2 - Required if transaction should be handled synchronous.
3 - eci
is always required if mpi_params
is present.
cavv
is not required for the 3D attempted only workflow, but it is strongly recommended in a combination with the Directory Server ID in order to be in the scope of the 3DSv2 authentication protocol.
4 - protocol_version
is required due to the only one 3DSv2 authentication protocol that is currently supported.
directory_server_id
is mandatory when protocol_version is 2. May be omitted for scheme tokenized transactions.
5 - visa_merchant_id
is required when exemption value is trusted_merchant
.
Frictionless / Challenge Response
stdClass Object
(
[transaction_type] => authorize3d
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[consumer_id] => 123456
[token] => ee946db8-d7db-4bb7-b608-b65b153e127d
[threeds_method_url] => https://staging.gate.emerchantpay.net/threeds/threeds_method
[threeds_method_continue_url] => https://staging.gate.emerchantpay.net/threeds/threeds_method/44177a21403427eb96664a6d7e5d5d48
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:48.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => false
[reason_for_not_honoring_exemption] => 8A01
[sca_exemption_result] => 13
)
<payment_response content=[
<transaction_type content=[authorize3d]>
<status content=[pending_async]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<consumer_id content=[123456]>
<token content=[ee946db8-d7db-4bb7-b608-b65b153e127d]>
<threeds_method_url content=[https://staging.gate.emerchantpay.net/threeds/threeds_method]>
<threeds_method_continue_url content=[https://staging.gate.emerchantpay.net/threeds/threeds_method/44177a21403427eb96664a6d7e5d5d48]>
<timestamp content=[2025-01-16T10:23:48Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[false]>
<reason_for_not_honoring_exemption content=[8A01]>
<sca_exemption_result content=[13]>
]>
{
transaction_type: "authorize3d",
status: "pending_async",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
consumer_id: "123456",
token: "ee946db8-d7db-4bb7-b608-b65b153e127d",
threeds_method_url: "https://staging.gate.emerchantpay.net/threeds/threeds_method",
threeds_method_continue_url: "https://staging.gate.emerchantpay.net/threeds/threeds_method/44177a21403427eb96664a6d7e5d5d48",
timestamp: "2025-01-16T10:23:48Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "false",
reason_for_not_honoring_exemption: "8A01",
sca_exemption_result: "13",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>authorize3d</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<consumer_id>123456</consumer_id>
<token>ee946db8-d7db-4bb7-b608-b65b153e127d</token>
<threeds_method_url>https://staging.gate.emerchantpay.net/threeds/threeds_method</threeds_method_url>
<threeds_method_continue_url>https://staging.gate.emerchantpay.net/threeds/threeds_method/44177a21403427eb96664a6d7e5d5d48</threeds_method_continue_url>
<timestamp>2025-01-16T10:23:48Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>false</sent_to_acquirer>
<reason_for_not_honoring_exemption>8A01</reason_for_not_honoring_exemption>
<sca_exemption_result>13</sca_exemption_result>
</payment_response>
Challenge Without 3 Ds Mеthod Response
stdClass Object
(
[transaction_type] => authorize3d
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[consumer_id] => 123456
[token] => ee946db8-d7db-4bb7-b608-b65b153e127d
[redirect_url] => https://staging.gate.emerchantpay.net/threeds/authentication/44177a21403427eb96664a6d7e5d5d48
[redirect_url_type] => 3ds_v2_challenge
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:48.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => false
[reason_for_not_honoring_exemption] => 8A01
[sca_exemption_result] => 13
)
<payment_response content=[
<transaction_type content=[authorize3d]>
<status content=[pending_async]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<consumer_id content=[123456]>
<token content=[ee946db8-d7db-4bb7-b608-b65b153e127d]>
<redirect_url content=[https://staging.gate.emerchantpay.net/threeds/authentication/44177a21403427eb96664a6d7e5d5d48]>
<redirect_url_type content=[3ds_v2_challenge]>
<timestamp content=[2025-01-16T10:23:48Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[false]>
<reason_for_not_honoring_exemption content=[8A01]>
<sca_exemption_result content=[13]>
]>
{
transaction_type: "authorize3d",
status: "pending_async",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
consumer_id: "123456",
token: "ee946db8-d7db-4bb7-b608-b65b153e127d",
redirect_url: "https://staging.gate.emerchantpay.net/threeds/authentication/44177a21403427eb96664a6d7e5d5d48",
redirect_url_type: "3ds_v2_challenge",
timestamp: "2025-01-16T10:23:48Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "false",
reason_for_not_honoring_exemption: "8A01",
sca_exemption_result: "13",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>authorize3d</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<consumer_id>123456</consumer_id>
<token>ee946db8-d7db-4bb7-b608-b65b153e127d</token>
<redirect_url>https://staging.gate.emerchantpay.net/threeds/authentication/44177a21403427eb96664a6d7e5d5d48</redirect_url>
<redirect_url_type>3ds_v2_challenge</redirect_url_type>
<timestamp>2025-01-16T10:23:48Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>false</sent_to_acquirer>
<reason_for_not_honoring_exemption>8A01</reason_for_not_honoring_exemption>
<sca_exemption_result>13</sca_exemption_result>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
consumer_id | string(10) | Consumer unique reference. See Consumers |
token | string(36) | Plain-text token value. See Tokenization |
gaming | 'true' | Signifies whether a gaming transaction is performed. Gaming transactions usually use MCC 7995, contact tech support for more details. |
moto | 'true' | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech support for more details. |
avs_response_code | string(255) | Generated by the card network on trying to match the billing address when performing the address verification. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
avs_response_text | string(255) | Gives the human response text for the AVS response code above. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
cvv_result_code | string(1) | Card Verification Value response code. Optional, returned only if acquirer supports it |
authorization_code | string(6) | Generated by the card network when an authorisation has occurred, used to identify that auth. Consists of 6 alphanumeric chars |
retrieval_reference_number | string(255) | A reference number used for tracking all messages related to a given cardholder transaction returned by some acquirers. |
payment_account_reference | string(255) | Payment Account Reference value returned from the schemes. Links tokenized and PAN-based transactions. |
response_code | string(2) | Defines the result of a transaction with the acquirer, the status of a message or some action taken or required. Contact tech-support@emerchantpay.com for more details. |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where the consumer has to be redirected to complete the payment process unless a 3DSecure Method is required. This redirect_url will not be included in the response if a 3DS-Method submission is required. For more information, to go 3DSv2 authentication flows |
redirect_url_type | string(64) | The type of the redirect URL in the 3DS scope. It will be present only for asynchronous 3D transactions when an interaction between consumer and issuer is required. This type identifies what kind of redirect url is returned, namely 3DSv2 Challenge. For more information, to go 3DSv2 authentication flows |
threeds_method_url | url | 3DSecure Method URL. It will be present only then 3DS-Method is required for 3D transaction. A 3DS-Method submission inside an iframe is required to be submitted using HTTP POST. For more information, to go 3DSv2 authentication flows |
threeds_method_continue_url | url | This is an API endpoint that accepts HTTP PUT & HTTP PATCH requests. It will be present when the threeds_method_url is included in the response. An HTTP PUT request must be submitted to that endpoint together with the proper signature to determine what the next step in the authentication is. For more information, to go 3DSv2 authentication flows |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
partial_approval | string(4) | Optional, set to ’true’ if partial approval happened. Partially approved amount is then in the amount field. Check Partial Approvals for details |
sent_to_acquirer | string(255) | "true" or "false" |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
scheme_transaction_identifier | string(32) | Id defined by card schemes. Corresponds to NETWORK DATA (field 63) for MasterCard or TRANS ID (field 62.2/125) for VISA. |
scheme_transaction_link_id | string(22) | The transaction unique identifier returned from the schemes. Corresponds to ADDITIONAL SERVICE DATA (field 65, MasterCard Transaction Link Id [TLID]). |
scheme_pan_indicator | string(1) | The account number indicator in scheme-tokenized transactions. See Account number indicator codes for details. |
scheme_pan_tail | string(4) | The tail of the PAN number tail associated with the token in scheme-tokenized transactions. Returned in conjunction with scheme_pan_indicator . |
scheme_max_settlement_date | string(10) | The final date an authorization could be captured which is returned from the card scheme. See Scheme Maximum Settlement Date for more details. |
scheme_authentication_data_quality | boolean | The Authentication Data Quality Indicator returned by the card scheme is used to indicate whether a transaction meets the authentication data quality requirements. The value can be either true or false . |
scheme_settlement_date | string(4) | MasterCard settlement date in MMDD format (e.g. 0117). Corresponds to NETWORK DATA (field 15). |
reason_for_not_honoring_exemption | string | Reason for not honoring exemption. Check SCA Reason For Not Honoring Exemption Values. |
sca_exemption_result | string | SCA exemption result. Check SCA Exemption Result Values. |
threeds | ||
eci | string(2) | See Electronic Commerce Indicator as returned from the MPI for details |
Error Response
stdClass Object
(
[transaction_type] => authorize3d
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[response_code] => 57
[code] => 340
[technical_message] => expiration_year is invalid
[message] => expiration_year is invalid
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:48.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => false
)
<payment_response content=[
<transaction_type content=[authorize3d]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<response_code content=[57]>
<code content=[340]>
<technical_message content=[expiration_year is invalid]>
<message content=[expiration_year is invalid]>
<timestamp content=[2025-01-16T10:23:48Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[false]>
]>
{
transaction_type: "authorize3d",
status: "error",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
response_code: "57",
code: "340",
technical_message: "expiration_year is invalid",
message: "expiration_year is invalid",
timestamp: "2025-01-16T10:23:48Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "false",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>authorize3d</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<response_code>57</response_code>
<code>340</code>
<technical_message>expiration_year is invalid</technical_message>
<message>expiration_year is invalid</message>
<timestamp>2025-01-16T10:23:48Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
gaming | 'true' | Signifies whether a gaming transaction is performed. Gaming transactions usually use MCC 7995, contact tech support for more details. |
moto | 'true' | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech support for more details. |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
threeds | ||
authentication | ||
status_reason_code | string(2) | See 3DS Authentication Status Reason Codes for details. |
Error Response
stdClass Object
(
[transaction_type] => authorize3d
[status] => declined
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 600
[technical_message] => Cardholder not participating 3DS.
[message] => Transaction failed, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:48.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
[threeds] => {"eci"=>"06", "authentication"=>{"status_reason_code"=>"08"}}
)
<payment_response content=[
<transaction_type content=[authorize3d]>
<status content=[declined]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<code content=[600]>
<technical_message content=[Cardholder not participating 3DS.]>
<message content=[Transaction failed, please contact support!]>
<timestamp content=[2025-01-16T10:23:48Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[true]>
<threeds content=[{"eci"=>"06", "authentication"=>{"status_reason_code"=>"08"}}]>
]>
{
transaction_type: "authorize3d",
status: "declined",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
code: "600",
technical_message: "Cardholder not participating 3DS.",
message: "Transaction failed, please contact support!",
timestamp: "2025-01-16T10:23:48Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "true",
threeds: "{"eci"=>"06", "authentication"=>{"status_reason_code"=>"08"}}",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>authorize3d</transaction_type>
<status>declined</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>600</code>
<technical_message>Cardholder not participating 3DS.</technical_message>
<message>Transaction failed, please contact support!</message>
<timestamp>2025-01-16T10:23:48Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
<threeds>
<eci>06</eci>
<authentication>
<status_reason_code>08</status_reason_code>
</authentication>
</threeds>
</payment_response>
Sale 3D
Sale3D transactions basically have the same request as standard sale transactions.
Visa Synchronous 3 D Sv2 Fully Authenticated Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Sale3D');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('4012000000060085')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
// MPI Synchronous 3DSv2
->setMpiEci('05')
->setMpiCavv('MDAwMDAwMDAwMDAxMTA2Njk5NFg=')
->setMpiProtocolVersion('2')
->setMpiProtocolSubVersion('2')
->setMpiDirectoryServerId('10737510-b6eb-013d-d770-0a58a9feac02')
->setMpiAcsTransactionId('107375f0-b6eb-013d-d770-0a58a9feac02')
->setMpiThreedsChallengeIndicator('preference')
// Sca Params
->setScaExemption('trusted_merchant')
->setScaVisaMerchantId('00000000')
->set#<Proc:0x00005586a295f488 includes::Transactions::3ds::V2::Examples::Requests.md.erb:43 (lambda)>('');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.Sale3DRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
Sale3DRequest request = new Sale3DRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4012000000060085");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
// Mpi Synchronous V2
request.setMpiParams("{"eci"=>"05", "cavv"=>"MDAwMDAwMDAwMDAxMTA2Njk5NFg=", "protocol_version"=>"2", "protocol_sub_version"=>"2", "directory_server_id"=>"10737510-b6eb-013d-d770-0a58a9feac02", "acs_transaction_id"=>"107375f0-b6eb-013d-d770-0a58a9feac02", "threeds_challenge_indicator"=>"preference"}");
// Sca Params
request.setScaExemption("trusted_merchant");
request.setScaVisaMerchantId("00000000");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.sale3d(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "4012000000060085",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"business_attributes": {
"event_start_date": "17-02-2025",
"event_end_date": "26-02-2025",
"event_organizer_id": "20192375",
"event_id": "1912"
},
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"mpi_params": {
"eci": "05",
"cavv": "MDAwMDAwMDAwMDAxMTA2Njk5NFg=",
"protocol_version": "2",
"protocol_sub_version": "2",
"directory_server_id": "10737510-b6eb-013d-d770-0a58a9feac02",
"acs_transaction_id": "107375f0-b6eb-013d-d770-0a58a9feac02",
"threeds_challenge_indicator": "preference"
},
"sca_params": {
"exemption": "trusted_merchant",
"visa_merchant_id": "00000000"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>sale3d</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4012000000060085</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<business_attributes>
<event_start_date>17-02-2025</event_start_date>
<event_end_date>26-02-2025</event_end_date>
<event_organizer_id>20192375</event_organizer_id>
<event_id>1912</event_id>
</business_attributes>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<mpi_params>
<eci>05</eci>
<cavv>MDAwMDAwMDAwMDAxMTA2Njk5NFg=</cavv>
<protocol_version>2</protocol_version>
<protocol_sub_version>2</protocol_sub_version>
<directory_server_id>10737510-b6eb-013d-d770-0a58a9feac02</directory_server_id>
<acs_transaction_id>107375f0-b6eb-013d-d770-0a58a9feac02</acs_transaction_id>
<threeds_challenge_indicator>preference</threeds_challenge_indicator>
</mpi_params>
<sca_params>
<exemption>trusted_merchant</exemption>
<visa_merchant_id>00000000</visa_merchant_id>
</sca_params>
</payment_transaction>'
Master Synchronous 3 D Sv2 Fully Authenticated Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Sale3D');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('5555555555559997')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
// MPI Synchronous 3DSv2
->setMpiEci('02')
->setMpiCavv('kQOImea0C/2ta1NZl4Hhwslmomqj')
->setMpiProtocolVersion('2')
->setMpiProtocolSubVersion('2')
->setMpiDirectoryServerId('107d2b20-b6eb-013d-d770-0a58a9feac02')
->setMpiAcsTransactionId('107d2bd0-b6eb-013d-d770-0a58a9feac02')
->setMpiThreedsChallengeIndicator('preference')
->set#<Proc:0x00005586a2c6f0d8 includes::Transactions::3ds::V2::Examples::Requests.md.erb:85 (lambda)>('');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.Sale3DRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
Sale3DRequest request = new Sale3DRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("5555555555559997");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
// Mpi Synchronous V2
request.setMpiParams("{"eci"=>"02", "cavv"=>"kQOImea0C/2ta1NZl4Hhwslmomqj", "protocol_version"=>"2", "protocol_sub_version"=>"2", "directory_server_id"=>"107d2b20-b6eb-013d-d770-0a58a9feac02", "acs_transaction_id"=>"107d2bd0-b6eb-013d-d770-0a58a9feac02", "threeds_challenge_indicator"=>"preference"}");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.sale3d(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "5555555555559997",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"business_attributes": {
"event_start_date": "17-02-2025",
"event_end_date": "26-02-2025",
"event_organizer_id": "20192375",
"event_id": "1912"
},
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"mpi_params": {
"eci": "02",
"cavv": "kQOImea0C/2ta1NZl4Hhwslmomqj",
"protocol_version": "2",
"protocol_sub_version": "2",
"directory_server_id": "107d2b20-b6eb-013d-d770-0a58a9feac02",
"acs_transaction_id": "107d2bd0-b6eb-013d-d770-0a58a9feac02",
"threeds_challenge_indicator": "preference"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>sale3d</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>5555555555559997</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<business_attributes>
<event_start_date>17-02-2025</event_start_date>
<event_end_date>26-02-2025</event_end_date>
<event_organizer_id>20192375</event_organizer_id>
<event_id>1912</event_id>
</business_attributes>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<mpi_params>
<eci>02</eci>
<cavv>kQOImea0C/2ta1NZl4Hhwslmomqj</cavv>
<protocol_version>2</protocol_version>
<protocol_sub_version>2</protocol_sub_version>
<directory_server_id>107d2b20-b6eb-013d-d770-0a58a9feac02</directory_server_id>
<acs_transaction_id>107d2bd0-b6eb-013d-d770-0a58a9feac02</acs_transaction_id>
<threeds_challenge_indicator>preference</threeds_challenge_indicator>
</mpi_params>
</payment_transaction>'
Visa Synchronous 3 D Sv2 Attempted Authentication Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Sale3D');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('4012000000060085')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
// MPI Synchronous 3DSv2
->setMpiEci('06')
->setMpiCavv('MDAwMDAwMDAwMDAxMTA2Njk5NFg=')
->setMpiProtocolVersion('2')
->setMpiProtocolSubVersion('2')
->setMpiDirectoryServerId('10860bd0-b6eb-013d-d770-0a58a9feac02')
->setMpiAcsTransactionId('10860c80-b6eb-013d-d770-0a58a9feac02')
->setMpiThreedsChallengeIndicator('preference')
// Sca Params
->setScaExemption('trusted_merchant')
->setScaVisaMerchantId('00000000')
->set#<Proc:0x000055869f7ed828 includes::Transactions::3ds::V2::Examples::Requests.md.erb:43 (lambda)>('');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.Sale3DRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
Sale3DRequest request = new Sale3DRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4012000000060085");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
// Mpi Synchronous V2
request.setMpiParams("{"eci"=>"06", "cavv"=>"MDAwMDAwMDAwMDAxMTA2Njk5NFg=", "protocol_version"=>"2", "protocol_sub_version"=>"2", "directory_server_id"=>"10860bd0-b6eb-013d-d770-0a58a9feac02", "acs_transaction_id"=>"10860c80-b6eb-013d-d770-0a58a9feac02", "threeds_challenge_indicator"=>"preference"}");
// Sca Params
request.setScaExemption("trusted_merchant");
request.setScaVisaMerchantId("00000000");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.sale3d(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "4012000000060085",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"business_attributes": {
"event_start_date": "17-02-2025",
"event_end_date": "26-02-2025",
"event_organizer_id": "20192375",
"event_id": "1912"
},
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"mpi_params": {
"eci": "06",
"cavv": "MDAwMDAwMDAwMDAxMTA2Njk5NFg=",
"protocol_version": "2",
"protocol_sub_version": "2",
"directory_server_id": "10860bd0-b6eb-013d-d770-0a58a9feac02",
"acs_transaction_id": "10860c80-b6eb-013d-d770-0a58a9feac02",
"threeds_challenge_indicator": "preference"
},
"sca_params": {
"exemption": "trusted_merchant",
"visa_merchant_id": "00000000"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>sale3d</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4012000000060085</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<business_attributes>
<event_start_date>17-02-2025</event_start_date>
<event_end_date>26-02-2025</event_end_date>
<event_organizer_id>20192375</event_organizer_id>
<event_id>1912</event_id>
</business_attributes>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<mpi_params>
<eci>06</eci>
<cavv>MDAwMDAwMDAwMDAxMTA2Njk5NFg=</cavv>
<protocol_version>2</protocol_version>
<protocol_sub_version>2</protocol_sub_version>
<directory_server_id>10860bd0-b6eb-013d-d770-0a58a9feac02</directory_server_id>
<acs_transaction_id>10860c80-b6eb-013d-d770-0a58a9feac02</acs_transaction_id>
<threeds_challenge_indicator>preference</threeds_challenge_indicator>
</mpi_params>
<sca_params>
<exemption>trusted_merchant</exemption>
<visa_merchant_id>00000000</visa_merchant_id>
</sca_params>
</payment_transaction>'
Master Synchronous 3 D Sv2 Attempted Authentication Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Sale3D');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('5555555555559997')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
// MPI Synchronous 3DSv2
->setMpiEci('01')
->setMpiCavv('kFOImea0C/2ta1NZl4Hhwslmomqj')
->setMpiProtocolVersion('2')
->setMpiProtocolSubVersion('2')
->setMpiDirectoryServerId('1090be80-b6eb-013d-d770-0a58a9feac02')
->setMpiAcsTransactionId('1090bf10-b6eb-013d-d770-0a58a9feac02')
->setMpiThreedsChallengeIndicator('preference')
->set#<Proc:0x00005586a1634e08 includes::Transactions::3ds::V2::Examples::Requests.md.erb:85 (lambda)>('');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.Sale3DRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
Sale3DRequest request = new Sale3DRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("5555555555559997");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
// Mpi Synchronous V2
request.setMpiParams("{"eci"=>"01", "cavv"=>"kFOImea0C/2ta1NZl4Hhwslmomqj", "protocol_version"=>"2", "protocol_sub_version"=>"2", "directory_server_id"=>"1090be80-b6eb-013d-d770-0a58a9feac02", "acs_transaction_id"=>"1090bf10-b6eb-013d-d770-0a58a9feac02", "threeds_challenge_indicator"=>"preference"}");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.sale3d(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "5555555555559997",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"business_attributes": {
"event_start_date": "17-02-2025",
"event_end_date": "26-02-2025",
"event_organizer_id": "20192375",
"event_id": "1912"
},
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"mpi_params": {
"eci": "01",
"cavv": "kFOImea0C/2ta1NZl4Hhwslmomqj",
"protocol_version": "2",
"protocol_sub_version": "2",
"directory_server_id": "1090be80-b6eb-013d-d770-0a58a9feac02",
"acs_transaction_id": "1090bf10-b6eb-013d-d770-0a58a9feac02",
"threeds_challenge_indicator": "preference"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>sale3d</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>5555555555559997</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<business_attributes>
<event_start_date>17-02-2025</event_start_date>
<event_end_date>26-02-2025</event_end_date>
<event_organizer_id>20192375</event_organizer_id>
<event_id>1912</event_id>
</business_attributes>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<mpi_params>
<eci>01</eci>
<cavv>kFOImea0C/2ta1NZl4Hhwslmomqj</cavv>
<protocol_version>2</protocol_version>
<protocol_sub_version>2</protocol_sub_version>
<directory_server_id>1090be80-b6eb-013d-d770-0a58a9feac02</directory_server_id>
<acs_transaction_id>1090bf10-b6eb-013d-d770-0a58a9feac02</acs_transaction_id>
<threeds_challenge_indicator>preference</threeds_challenge_indicator>
</mpi_params>
</payment_transaction>'
Master Synchronous 3 D Sv2 Acquirer Exemption Accepted (Tra Already Performed) Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Sale3D');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('5169750000001111')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
// MPI Synchronous 3DSv2
->setMpiEci('06')
->setMpiCavv('kNMAAAAA3S13awBkrWtTWZeBBCmy')
->setMpiProtocolVersion('2')
->setMpiProtocolSubVersion('2')
->setMpiDirectoryServerId('109d2220-b6eb-013d-d770-0a58a9feac02')
->setMpiAcsTransactionId('109d22e0-b6eb-013d-d770-0a58a9feac02')
->setMpiThreedsChallengeIndicator('preference')
// Sca Params
->setScaExemption('low_risk')
->set#<Proc:0x00005586a198c650 includes::Transactions::3ds::V2::Examples::Requests.md.erb:132 (lambda)>('');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.Sale3DRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
Sale3DRequest request = new Sale3DRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("5169750000001111");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
// Mpi Synchronous V2
request.setMpiParams("{"eci"=>"06", "cavv"=>"kNMAAAAA3S13awBkrWtTWZeBBCmy", "protocol_version"=>"2", "protocol_sub_version"=>"2", "directory_server_id"=>"109d2220-b6eb-013d-d770-0a58a9feac02", "acs_transaction_id"=>"109d22e0-b6eb-013d-d770-0a58a9feac02", "threeds_challenge_indicator"=>"preference"}");
// Sca Params
request.setScaExemption("low_risk");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.sale3d(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "5169750000001111",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"business_attributes": {
"event_start_date": "17-02-2025",
"event_end_date": "26-02-2025",
"event_organizer_id": "20192375",
"event_id": "1912"
},
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"mpi_params": {
"eci": "06",
"cavv": "kNMAAAAA3S13awBkrWtTWZeBBCmy",
"protocol_version": "2",
"protocol_sub_version": "2",
"directory_server_id": "109d2220-b6eb-013d-d770-0a58a9feac02",
"acs_transaction_id": "109d22e0-b6eb-013d-d770-0a58a9feac02",
"threeds_challenge_indicator": "preference"
},
"sca_params": {
"exemption": "low_risk"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>sale3d</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>5169750000001111</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<business_attributes>
<event_start_date>17-02-2025</event_start_date>
<event_end_date>26-02-2025</event_end_date>
<event_organizer_id>20192375</event_organizer_id>
<event_id>1912</event_id>
</business_attributes>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<mpi_params>
<eci>06</eci>
<cavv>kNMAAAAA3S13awBkrWtTWZeBBCmy</cavv>
<protocol_version>2</protocol_version>
<protocol_sub_version>2</protocol_sub_version>
<directory_server_id>109d2220-b6eb-013d-d770-0a58a9feac02</directory_server_id>
<acs_transaction_id>109d22e0-b6eb-013d-d770-0a58a9feac02</acs_transaction_id>
<threeds_challenge_indicator>preference</threeds_challenge_indicator>
</mpi_params>
<sca_params>
<exemption>low_risk</exemption>
</sca_params>
</payment_transaction>'
Visa Synchronous 3 D Sv2 Acquirer Exemption Accepted (Tra Already Performed) Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Sale3D');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('4378510000000004')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
// MPI Synchronous 3DSv2
->setMpiEci('07')
->setMpiCavv('ApkCAlgGQCECEBJWNgZAAAAAAAA=')
->setMpiProtocolVersion('2')
->setMpiProtocolSubVersion('2')
->setMpiDirectoryServerId('10aaf0b0-b6eb-013d-d770-0a58a9feac02')
->setMpiAcsTransactionId('10aaf150-b6eb-013d-d770-0a58a9feac02')
->setMpiThreedsChallengeIndicator('preference')
// Sca Params
->setScaExemption('low_risk')
->set#<Proc:0x00005586a1be0640 includes::Transactions::3ds::V2::Examples::Requests.md.erb:179 (lambda)>('');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.Sale3DRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
Sale3DRequest request = new Sale3DRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4378510000000004");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
// Mpi Synchronous V2
request.setMpiParams("{"eci"=>"07", "cavv"=>"ApkCAlgGQCECEBJWNgZAAAAAAAA=", "protocol_version"=>"2", "protocol_sub_version"=>"2", "directory_server_id"=>"10aaf0b0-b6eb-013d-d770-0a58a9feac02", "acs_transaction_id"=>"10aaf150-b6eb-013d-d770-0a58a9feac02", "threeds_challenge_indicator"=>"preference"}");
// Sca Params
request.setScaExemption("low_risk");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.sale3d(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "4378510000000004",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"business_attributes": {
"event_start_date": "17-02-2025",
"event_end_date": "26-02-2025",
"event_organizer_id": "20192375",
"event_id": "1912"
},
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"mpi_params": {
"eci": "07",
"cavv": "ApkCAlgGQCECEBJWNgZAAAAAAAA=",
"protocol_version": "2",
"protocol_sub_version": "2",
"directory_server_id": "10aaf0b0-b6eb-013d-d770-0a58a9feac02",
"acs_transaction_id": "10aaf150-b6eb-013d-d770-0a58a9feac02",
"threeds_challenge_indicator": "preference"
},
"sca_params": {
"exemption": "low_risk"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>sale3d</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4378510000000004</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<business_attributes>
<event_start_date>17-02-2025</event_start_date>
<event_end_date>26-02-2025</event_end_date>
<event_organizer_id>20192375</event_organizer_id>
<event_id>1912</event_id>
</business_attributes>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<mpi_params>
<eci>07</eci>
<cavv>ApkCAlgGQCECEBJWNgZAAAAAAAA=</cavv>
<protocol_version>2</protocol_version>
<protocol_sub_version>2</protocol_sub_version>
<directory_server_id>10aaf0b0-b6eb-013d-d770-0a58a9feac02</directory_server_id>
<acs_transaction_id>10aaf150-b6eb-013d-d770-0a58a9feac02</acs_transaction_id>
<threeds_challenge_indicator>preference</threeds_challenge_indicator>
</mpi_params>
<sca_params>
<exemption>low_risk</exemption>
</sca_params>
</payment_transaction>'
Asynchronous 3 D Sv2 Frictionless No 3ds Method Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Sale3D');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('4012000000060085')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
->setNotificationUrl('https://www.example.com/notification')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
// Threeds V2 Params
->setThreedsThreedsMethod('{"callback_url"=>"https://www.example.com/threeds/threeds_method/callback"}')
->setThreedsControl('{"device_type"=>"browser", "challenge_window_size"=>"full_screen", "challenge_indicator"=>"preference"}')
->setThreedsPurchase('{"category"=>"service"}')
->setThreedsRecurring('{"expiration_date"=>"17-07-2025", "frequency"=>30}')
->setThreedsMerchantRisk('{"shipping_indicator"=>"verified_address", "delivery_timeframe"=>"electronic", "reorder_items_indicator"=>"reordered", "pre_order_purchase_indicator"=>"merchandise_available", "pre_order_date"=>"17-02-2025", "gift_card"=>"true", "gift_card_count"=>"2"}')
->setThreedsCardHolderAccount('{"creation_date"=>"17-01-2024", "update_indicator"=>"more_than_60days", "last_change_date"=>"17-10-2024", "password_change_indicator"=>"no_change", "password_change_date"=>"02-01-2025", "shipping_address_usage_indicator"=>"current_transaction", "shipping_address_date_first_used"=>"12-01-2025", "transactions_activity_last_24_hours"=>"2", "transactions_activity_previous_year"=>"10", "provision_attempts_last_24_hours"=>"1", "purchases_count_last_6_months"=>"5", "suspicious_activity_indicator"=>"no_suspicious_observed", "registration_indicator"=>"30_to_60_days", "registration_date"=>"17-01-2023"}')
->setThreedsBrowser('{"accept_header"=>"*/*", "java_enabled"=>"false", "language"=>"en-GB", "color_depth"=>"24", "screen_height"=>"900", "screen_width"=>"1440", "time_zone_offset"=>"-120", "user_agent"=>"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"}')
->setThreedsSdk('{"interface"=>"native", "ui_types"=>{"ui_type"=>"multi_select"}, "application_id"=>"fc1650c0-5778-0138-8205-2cbc32a32d65", "encrypted_data"=>"encrypted-data-here", "ephemeral_public_key_pair"=>"public-key-pair", "max_timeout"=>"10", "reference_number"=>"sdk-reference-number-here"}')
// Sca Params
->setScaExemption('low_risk')
->set#<Proc:0x00005586a1e58468 includes::Transactions::3ds::V2::Examples::Requests.md.erb:219 (lambda)>('');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.Sale3DRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
Sale3DRequest request = new Sale3DRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4012000000060085");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
request.setNotificationUrl(new URL("https://www.example.com/notification"));
request.setReturnSuccessUrl(new URL("http://www.example.com/success"));
request.setReturnFailureUrl(new URL("http://www.example.com/failure"));
// Threeds V2 Params
request.setThreedsThreedsMethod("{"callback_url"=>"https://www.example.com/threeds/threeds_method/callback"}");
request.setThreedsControl("{"device_type"=>"browser", "challenge_window_size"=>"full_screen", "challenge_indicator"=>"preference"}");
request.setThreedsPurchase("{"category"=>"service"}");
request.setThreedsRecurring("{"expiration_date"=>"17-07-2025", "frequency"=>30}");
request.setThreedsMerchantRisk("{"shipping_indicator"=>"verified_address", "delivery_timeframe"=>"electronic", "reorder_items_indicator"=>"reordered", "pre_order_purchase_indicator"=>"merchandise_available", "pre_order_date"=>"17-02-2025", "gift_card"=>"true", "gift_card_count"=>"2"}");
request.setThreedsCardHolderAccount("{"creation_date"=>"17-01-2024", "update_indicator"=>"more_than_60days", "last_change_date"=>"17-10-2024", "password_change_indicator"=>"no_change", "password_change_date"=>"02-01-2025", "shipping_address_usage_indicator"=>"current_transaction", "shipping_address_date_first_used"=>"12-01-2025", "transactions_activity_last_24_hours"=>"2", "transactions_activity_previous_year"=>"10", "provision_attempts_last_24_hours"=>"1", "purchases_count_last_6_months"=>"5", "suspicious_activity_indicator"=>"no_suspicious_observed", "registration_indicator"=>"30_to_60_days", "registration_date"=>"17-01-2023"}");
request.setThreedsBrowser("{"accept_header"=>"*/*", "java_enabled"=>"false", "language"=>"en-GB", "color_depth"=>"24", "screen_height"=>"900", "screen_width"=>"1440", "time_zone_offset"=>"-120", "user_agent"=>"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"}");
request.setThreedsSdk("{"interface"=>"native", "ui_types"=>{"ui_type"=>"multi_select"}, "application_id"=>"fc1650c0-5778-0138-8205-2cbc32a32d65", "encrypted_data"=>"encrypted-data-here", "ephemeral_public_key_pair"=>"public-key-pair", "max_timeout"=>"10", "reference_number"=>"sdk-reference-number-here"}");
// Sca Params
request.setScaExemption("low_risk");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.sale3d(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "4012000000060085",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"notification_url": "https://www.example.com/notification",
"return_success_url": "http://www.example.com/success",
"return_failure_url": "http://www.example.com/failure",
"threeds_v2_params": {
"threeds_method": {
"callback_url": "https://www.example.com/threeds/threeds_method/callback"
},
"control": {
"device_type": "browser",
"challenge_window_size": "full_screen",
"challenge_indicator": "preference"
},
"purchase": {
"category": "service"
},
"recurring": {
"expiration_date": "17-07-2025",
"frequency": 30
},
"merchant_risk": {
"shipping_indicator": "verified_address",
"delivery_timeframe": "electronic",
"reorder_items_indicator": "reordered",
"pre_order_purchase_indicator": "merchandise_available",
"pre_order_date": "17-02-2025",
"gift_card": "true",
"gift_card_count": "2"
},
"card_holder_account": {
"creation_date": "17-01-2024",
"update_indicator": "more_than_60days",
"last_change_date": "17-10-2024",
"password_change_indicator": "no_change",
"password_change_date": "02-01-2025",
"shipping_address_usage_indicator": "current_transaction",
"shipping_address_date_first_used": "12-01-2025",
"transactions_activity_last_24_hours": "2",
"transactions_activity_previous_year": "10",
"provision_attempts_last_24_hours": "1",
"purchases_count_last_6_months": "5",
"suspicious_activity_indicator": "no_suspicious_observed",
"registration_indicator": "30_to_60_days",
"registration_date": "17-01-2023"
},
"browser": {
"accept_header": "*/*",
"java_enabled": "false",
"language": "en-GB",
"color_depth": "24",
"screen_height": "900",
"screen_width": "1440",
"time_zone_offset": "-120",
"user_agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"
},
"sdk": {
"interface": "native",
"ui_types": {
"ui_type": "multi_select"
},
"application_id": "fc1650c0-5778-0138-8205-2cbc32a32d65",
"encrypted_data": "encrypted-data-here",
"ephemeral_public_key_pair": "public-key-pair",
"max_timeout": "10",
"reference_number": "sdk-reference-number-here"
}
},
"sca_params": {
"exemption": "low_risk"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>sale3d</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4012000000060085</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<notification_url>https://www.example.com/notification</notification_url>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<threeds_v2_params>
<threeds_method>
<callback_url>https://www.example.com/threeds/threeds_method/callback</callback_url>
</threeds_method>
<control>
<device_type>browser</device_type>
<challenge_window_size>full_screen</challenge_window_size>
<challenge_indicator>preference</challenge_indicator>
</control>
<purchase>
<category>service</category>
</purchase>
<merchant_risk>
<shipping_indicator>verified_address</shipping_indicator>
<delivery_timeframe>electronic</delivery_timeframe>
<reorder_items_indicator>reordered</reorder_items_indicator>
<pre_order_purchase_indicator>merchandise_available</pre_order_purchase_indicator>
<pre_order_date>17-02-2025</pre_order_date>
<gift_card>true</gift_card>
<gift_card_count>2</gift_card_count>
</merchant_risk>
<card_holder_account>
<creation_date>17-01-2024</creation_date>
<update_indicator>more_than_60days</update_indicator>
<last_change_date>17-10-2024</last_change_date>
<password_change_indicator>no_change</password_change_indicator>
<password_change_date>02-01-2025</password_change_date>
<shipping_address_usage_indicator>current_transaction</shipping_address_usage_indicator>
<shipping_address_date_first_used>12-01-2025</shipping_address_date_first_used>
<transactions_activity_last_24_hours>2</transactions_activity_last_24_hours>
<transactions_activity_previous_year>10</transactions_activity_previous_year>
<provision_attempts_last_24_hours>1</provision_attempts_last_24_hours>
<purchases_count_last_6_months>5</purchases_count_last_6_months>
<suspicious_activity_indicator>no_suspicious_observed</suspicious_activity_indicator>
<registration_indicator>30_to_60_days</registration_indicator>
<registration_date>17-01-2023</registration_date>
</card_holder_account>
<browser>
<accept_header>*/*</accept_header>
<java_enabled>false</java_enabled>
<language>en-GB</language>
<color_depth>24</color_depth>
<screen_height>900</screen_height>
<screen_width>1440</screen_width>
<time_zone_offset>-120</time_zone_offset>
<user_agent>Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36</user_agent>
</browser>
<sdk>
<interface>native</interface>
<ui_types>
<ui_type>multi_select</ui_type>
</ui_types>
<application_id>fc1650c0-5778-0138-8205-2cbc32a32d65</application_id>
<encrypted_data>encrypted-data-here</encrypted_data>
<ephemeral_public_key_pair>public-key-pair</ephemeral_public_key_pair>
<max_timeout>10</max_timeout>
<reference_number>sdk-reference-number-here</reference_number>
</sdk>
</threeds_v2_params>
<sca_params>
<exemption>low_risk</exemption>
</sca_params>
</payment_transaction>'
Asynchronous 3 D Sv2 Frictionless With 3ds Method Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Sale3D');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('4066330000000004')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
->setNotificationUrl('https://www.example.com/notification')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
// Threeds V2 Params
->setThreedsThreedsMethod('{"callback_url"=>"https://www.example.com/threeds/threeds_method/callback"}')
->setThreedsControl('{"device_type"=>"browser", "challenge_window_size"=>"full_screen", "challenge_indicator"=>"preference"}')
->setThreedsPurchase('{"category"=>"service"}')
->setThreedsRecurring('{"expiration_date"=>"17-07-2025", "frequency"=>30}')
->setThreedsMerchantRisk('{"shipping_indicator"=>"verified_address", "delivery_timeframe"=>"electronic", "reorder_items_indicator"=>"reordered", "pre_order_purchase_indicator"=>"merchandise_available", "pre_order_date"=>"17-02-2025", "gift_card"=>"true", "gift_card_count"=>"2"}')
->setThreedsCardHolderAccount('{"creation_date"=>"17-01-2024", "update_indicator"=>"more_than_60days", "last_change_date"=>"17-10-2024", "password_change_indicator"=>"no_change", "password_change_date"=>"02-01-2025", "shipping_address_usage_indicator"=>"current_transaction", "shipping_address_date_first_used"=>"12-01-2025", "transactions_activity_last_24_hours"=>"2", "transactions_activity_previous_year"=>"10", "provision_attempts_last_24_hours"=>"1", "purchases_count_last_6_months"=>"5", "suspicious_activity_indicator"=>"no_suspicious_observed", "registration_indicator"=>"30_to_60_days", "registration_date"=>"17-01-2023"}')
->setThreedsBrowser('{"accept_header"=>"*/*", "java_enabled"=>"false", "language"=>"en-GB", "color_depth"=>"24", "screen_height"=>"900", "screen_width"=>"1440", "time_zone_offset"=>"-120", "user_agent"=>"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"}')
->setThreedsSdk('{"interface"=>"native", "ui_types"=>{"ui_type"=>"multi_select"}, "application_id"=>"fc1650c0-5778-0138-8205-2cbc32a32d65", "encrypted_data"=>"encrypted-data-here", "ephemeral_public_key_pair"=>"public-key-pair", "max_timeout"=>"10", "reference_number"=>"sdk-reference-number-here"}')
// Sca Params
->setScaExemption('low_risk')
->set#<Proc:0x00005586a242f080 includes::Transactions::3ds::V2::Examples::Requests.md.erb:219 (lambda)>('');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.Sale3DRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
Sale3DRequest request = new Sale3DRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4066330000000004");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
request.setNotificationUrl(new URL("https://www.example.com/notification"));
request.setReturnSuccessUrl(new URL("http://www.example.com/success"));
request.setReturnFailureUrl(new URL("http://www.example.com/failure"));
// Threeds V2 Params
request.setThreedsThreedsMethod("{"callback_url"=>"https://www.example.com/threeds/threeds_method/callback"}");
request.setThreedsControl("{"device_type"=>"browser", "challenge_window_size"=>"full_screen", "challenge_indicator"=>"preference"}");
request.setThreedsPurchase("{"category"=>"service"}");
request.setThreedsRecurring("{"expiration_date"=>"17-07-2025", "frequency"=>30}");
request.setThreedsMerchantRisk("{"shipping_indicator"=>"verified_address", "delivery_timeframe"=>"electronic", "reorder_items_indicator"=>"reordered", "pre_order_purchase_indicator"=>"merchandise_available", "pre_order_date"=>"17-02-2025", "gift_card"=>"true", "gift_card_count"=>"2"}");
request.setThreedsCardHolderAccount("{"creation_date"=>"17-01-2024", "update_indicator"=>"more_than_60days", "last_change_date"=>"17-10-2024", "password_change_indicator"=>"no_change", "password_change_date"=>"02-01-2025", "shipping_address_usage_indicator"=>"current_transaction", "shipping_address_date_first_used"=>"12-01-2025", "transactions_activity_last_24_hours"=>"2", "transactions_activity_previous_year"=>"10", "provision_attempts_last_24_hours"=>"1", "purchases_count_last_6_months"=>"5", "suspicious_activity_indicator"=>"no_suspicious_observed", "registration_indicator"=>"30_to_60_days", "registration_date"=>"17-01-2023"}");
request.setThreedsBrowser("{"accept_header"=>"*/*", "java_enabled"=>"false", "language"=>"en-GB", "color_depth"=>"24", "screen_height"=>"900", "screen_width"=>"1440", "time_zone_offset"=>"-120", "user_agent"=>"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"}");
request.setThreedsSdk("{"interface"=>"native", "ui_types"=>{"ui_type"=>"multi_select"}, "application_id"=>"fc1650c0-5778-0138-8205-2cbc32a32d65", "encrypted_data"=>"encrypted-data-here", "ephemeral_public_key_pair"=>"public-key-pair", "max_timeout"=>"10", "reference_number"=>"sdk-reference-number-here"}");
// Sca Params
request.setScaExemption("low_risk");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.sale3d(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "4066330000000004",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"notification_url": "https://www.example.com/notification",
"return_success_url": "http://www.example.com/success",
"return_failure_url": "http://www.example.com/failure",
"threeds_v2_params": {
"threeds_method": {
"callback_url": "https://www.example.com/threeds/threeds_method/callback"
},
"control": {
"device_type": "browser",
"challenge_window_size": "full_screen",
"challenge_indicator": "preference"
},
"purchase": {
"category": "service"
},
"recurring": {
"expiration_date": "17-07-2025",
"frequency": 30
},
"merchant_risk": {
"shipping_indicator": "verified_address",
"delivery_timeframe": "electronic",
"reorder_items_indicator": "reordered",
"pre_order_purchase_indicator": "merchandise_available",
"pre_order_date": "17-02-2025",
"gift_card": "true",
"gift_card_count": "2"
},
"card_holder_account": {
"creation_date": "17-01-2024",
"update_indicator": "more_than_60days",
"last_change_date": "17-10-2024",
"password_change_indicator": "no_change",
"password_change_date": "02-01-2025",
"shipping_address_usage_indicator": "current_transaction",
"shipping_address_date_first_used": "12-01-2025",
"transactions_activity_last_24_hours": "2",
"transactions_activity_previous_year": "10",
"provision_attempts_last_24_hours": "1",
"purchases_count_last_6_months": "5",
"suspicious_activity_indicator": "no_suspicious_observed",
"registration_indicator": "30_to_60_days",
"registration_date": "17-01-2023"
},
"browser": {
"accept_header": "*/*",
"java_enabled": "false",
"language": "en-GB",
"color_depth": "24",
"screen_height": "900",
"screen_width": "1440",
"time_zone_offset": "-120",
"user_agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"
},
"sdk": {
"interface": "native",
"ui_types": {
"ui_type": "multi_select"
},
"application_id": "fc1650c0-5778-0138-8205-2cbc32a32d65",
"encrypted_data": "encrypted-data-here",
"ephemeral_public_key_pair": "public-key-pair",
"max_timeout": "10",
"reference_number": "sdk-reference-number-here"
}
},
"sca_params": {
"exemption": "low_risk"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>sale3d</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4066330000000004</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<notification_url>https://www.example.com/notification</notification_url>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<threeds_v2_params>
<threeds_method>
<callback_url>https://www.example.com/threeds/threeds_method/callback</callback_url>
</threeds_method>
<control>
<device_type>browser</device_type>
<challenge_window_size>full_screen</challenge_window_size>
<challenge_indicator>preference</challenge_indicator>
</control>
<purchase>
<category>service</category>
</purchase>
<merchant_risk>
<shipping_indicator>verified_address</shipping_indicator>
<delivery_timeframe>electronic</delivery_timeframe>
<reorder_items_indicator>reordered</reorder_items_indicator>
<pre_order_purchase_indicator>merchandise_available</pre_order_purchase_indicator>
<pre_order_date>17-02-2025</pre_order_date>
<gift_card>true</gift_card>
<gift_card_count>2</gift_card_count>
</merchant_risk>
<card_holder_account>
<creation_date>17-01-2024</creation_date>
<update_indicator>more_than_60days</update_indicator>
<last_change_date>17-10-2024</last_change_date>
<password_change_indicator>no_change</password_change_indicator>
<password_change_date>02-01-2025</password_change_date>
<shipping_address_usage_indicator>current_transaction</shipping_address_usage_indicator>
<shipping_address_date_first_used>12-01-2025</shipping_address_date_first_used>
<transactions_activity_last_24_hours>2</transactions_activity_last_24_hours>
<transactions_activity_previous_year>10</transactions_activity_previous_year>
<provision_attempts_last_24_hours>1</provision_attempts_last_24_hours>
<purchases_count_last_6_months>5</purchases_count_last_6_months>
<suspicious_activity_indicator>no_suspicious_observed</suspicious_activity_indicator>
<registration_indicator>30_to_60_days</registration_indicator>
<registration_date>17-01-2023</registration_date>
</card_holder_account>
<browser>
<accept_header>*/*</accept_header>
<java_enabled>false</java_enabled>
<language>en-GB</language>
<color_depth>24</color_depth>
<screen_height>900</screen_height>
<screen_width>1440</screen_width>
<time_zone_offset>-120</time_zone_offset>
<user_agent>Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36</user_agent>
</browser>
<sdk>
<interface>native</interface>
<ui_types>
<ui_type>multi_select</ui_type>
</ui_types>
<application_id>fc1650c0-5778-0138-8205-2cbc32a32d65</application_id>
<encrypted_data>encrypted-data-here</encrypted_data>
<ephemeral_public_key_pair>public-key-pair</ephemeral_public_key_pair>
<max_timeout>10</max_timeout>
<reference_number>sdk-reference-number-here</reference_number>
</sdk>
</threeds_v2_params>
<sca_params>
<exemption>low_risk</exemption>
</sca_params>
</payment_transaction>'
Asynchronous 3 D Sv2 Challenge No 3ds Method Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Sale3D');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('4918190000000002')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
->setNotificationUrl('https://www.example.com/notification')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
// Threeds V2 Params
->setThreedsThreedsMethod('{"callback_url"=>"https://www.example.com/threeds/threeds_method/callback"}')
->setThreedsControl('{"device_type"=>"browser", "challenge_window_size"=>"full_screen", "challenge_indicator"=>"preference"}')
->setThreedsPurchase('{"category"=>"service"}')
->setThreedsRecurring('{"expiration_date"=>"17-07-2025", "frequency"=>30}')
->setThreedsMerchantRisk('{"shipping_indicator"=>"verified_address", "delivery_timeframe"=>"electronic", "reorder_items_indicator"=>"reordered", "pre_order_purchase_indicator"=>"merchandise_available", "pre_order_date"=>"17-02-2025", "gift_card"=>"true", "gift_card_count"=>"2"}')
->setThreedsCardHolderAccount('{"creation_date"=>"17-01-2024", "update_indicator"=>"more_than_60days", "last_change_date"=>"17-10-2024", "password_change_indicator"=>"no_change", "password_change_date"=>"02-01-2025", "shipping_address_usage_indicator"=>"current_transaction", "shipping_address_date_first_used"=>"12-01-2025", "transactions_activity_last_24_hours"=>"2", "transactions_activity_previous_year"=>"10", "provision_attempts_last_24_hours"=>"1", "purchases_count_last_6_months"=>"5", "suspicious_activity_indicator"=>"no_suspicious_observed", "registration_indicator"=>"30_to_60_days", "registration_date"=>"17-01-2023"}')
->setThreedsBrowser('{"accept_header"=>"*/*", "java_enabled"=>"false", "language"=>"en-GB", "color_depth"=>"24", "screen_height"=>"900", "screen_width"=>"1440", "time_zone_offset"=>"-120", "user_agent"=>"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"}')
->setThreedsSdk('{"interface"=>"native", "ui_types"=>{"ui_type"=>"multi_select"}, "application_id"=>"fc1650c0-5778-0138-8205-2cbc32a32d65", "encrypted_data"=>"encrypted-data-here", "ephemeral_public_key_pair"=>"public-key-pair", "max_timeout"=>"10", "reference_number"=>"sdk-reference-number-here"}')
// Sca Params
->setScaExemption('low_risk')
->set#<Proc:0x00005586a274fcd8 includes::Transactions::3ds::V2::Examples::Requests.md.erb:219 (lambda)>('');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.Sale3DRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
Sale3DRequest request = new Sale3DRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4918190000000002");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
request.setNotificationUrl(new URL("https://www.example.com/notification"));
request.setReturnSuccessUrl(new URL("http://www.example.com/success"));
request.setReturnFailureUrl(new URL("http://www.example.com/failure"));
// Threeds V2 Params
request.setThreedsThreedsMethod("{"callback_url"=>"https://www.example.com/threeds/threeds_method/callback"}");
request.setThreedsControl("{"device_type"=>"browser", "challenge_window_size"=>"full_screen", "challenge_indicator"=>"preference"}");
request.setThreedsPurchase("{"category"=>"service"}");
request.setThreedsRecurring("{"expiration_date"=>"17-07-2025", "frequency"=>30}");
request.setThreedsMerchantRisk("{"shipping_indicator"=>"verified_address", "delivery_timeframe"=>"electronic", "reorder_items_indicator"=>"reordered", "pre_order_purchase_indicator"=>"merchandise_available", "pre_order_date"=>"17-02-2025", "gift_card"=>"true", "gift_card_count"=>"2"}");
request.setThreedsCardHolderAccount("{"creation_date"=>"17-01-2024", "update_indicator"=>"more_than_60days", "last_change_date"=>"17-10-2024", "password_change_indicator"=>"no_change", "password_change_date"=>"02-01-2025", "shipping_address_usage_indicator"=>"current_transaction", "shipping_address_date_first_used"=>"12-01-2025", "transactions_activity_last_24_hours"=>"2", "transactions_activity_previous_year"=>"10", "provision_attempts_last_24_hours"=>"1", "purchases_count_last_6_months"=>"5", "suspicious_activity_indicator"=>"no_suspicious_observed", "registration_indicator"=>"30_to_60_days", "registration_date"=>"17-01-2023"}");
request.setThreedsBrowser("{"accept_header"=>"*/*", "java_enabled"=>"false", "language"=>"en-GB", "color_depth"=>"24", "screen_height"=>"900", "screen_width"=>"1440", "time_zone_offset"=>"-120", "user_agent"=>"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"}");
request.setThreedsSdk("{"interface"=>"native", "ui_types"=>{"ui_type"=>"multi_select"}, "application_id"=>"fc1650c0-5778-0138-8205-2cbc32a32d65", "encrypted_data"=>"encrypted-data-here", "ephemeral_public_key_pair"=>"public-key-pair", "max_timeout"=>"10", "reference_number"=>"sdk-reference-number-here"}");
// Sca Params
request.setScaExemption("low_risk");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.sale3d(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "4918190000000002",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"notification_url": "https://www.example.com/notification",
"return_success_url": "http://www.example.com/success",
"return_failure_url": "http://www.example.com/failure",
"threeds_v2_params": {
"threeds_method": {
"callback_url": "https://www.example.com/threeds/threeds_method/callback"
},
"control": {
"device_type": "browser",
"challenge_window_size": "full_screen",
"challenge_indicator": "preference"
},
"purchase": {
"category": "service"
},
"recurring": {
"expiration_date": "17-07-2025",
"frequency": 30
},
"merchant_risk": {
"shipping_indicator": "verified_address",
"delivery_timeframe": "electronic",
"reorder_items_indicator": "reordered",
"pre_order_purchase_indicator": "merchandise_available",
"pre_order_date": "17-02-2025",
"gift_card": "true",
"gift_card_count": "2"
},
"card_holder_account": {
"creation_date": "17-01-2024",
"update_indicator": "more_than_60days",
"last_change_date": "17-10-2024",
"password_change_indicator": "no_change",
"password_change_date": "02-01-2025",
"shipping_address_usage_indicator": "current_transaction",
"shipping_address_date_first_used": "12-01-2025",
"transactions_activity_last_24_hours": "2",
"transactions_activity_previous_year": "10",
"provision_attempts_last_24_hours": "1",
"purchases_count_last_6_months": "5",
"suspicious_activity_indicator": "no_suspicious_observed",
"registration_indicator": "30_to_60_days",
"registration_date": "17-01-2023"
},
"browser": {
"accept_header": "*/*",
"java_enabled": "false",
"language": "en-GB",
"color_depth": "24",
"screen_height": "900",
"screen_width": "1440",
"time_zone_offset": "-120",
"user_agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"
},
"sdk": {
"interface": "native",
"ui_types": {
"ui_type": "multi_select"
},
"application_id": "fc1650c0-5778-0138-8205-2cbc32a32d65",
"encrypted_data": "encrypted-data-here",
"ephemeral_public_key_pair": "public-key-pair",
"max_timeout": "10",
"reference_number": "sdk-reference-number-here"
}
},
"sca_params": {
"exemption": "low_risk"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>sale3d</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4918190000000002</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<notification_url>https://www.example.com/notification</notification_url>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<threeds_v2_params>
<threeds_method>
<callback_url>https://www.example.com/threeds/threeds_method/callback</callback_url>
</threeds_method>
<control>
<device_type>browser</device_type>
<challenge_window_size>full_screen</challenge_window_size>
<challenge_indicator>preference</challenge_indicator>
</control>
<purchase>
<category>service</category>
</purchase>
<merchant_risk>
<shipping_indicator>verified_address</shipping_indicator>
<delivery_timeframe>electronic</delivery_timeframe>
<reorder_items_indicator>reordered</reorder_items_indicator>
<pre_order_purchase_indicator>merchandise_available</pre_order_purchase_indicator>
<pre_order_date>17-02-2025</pre_order_date>
<gift_card>true</gift_card>
<gift_card_count>2</gift_card_count>
</merchant_risk>
<card_holder_account>
<creation_date>17-01-2024</creation_date>
<update_indicator>more_than_60days</update_indicator>
<last_change_date>17-10-2024</last_change_date>
<password_change_indicator>no_change</password_change_indicator>
<password_change_date>02-01-2025</password_change_date>
<shipping_address_usage_indicator>current_transaction</shipping_address_usage_indicator>
<shipping_address_date_first_used>12-01-2025</shipping_address_date_first_used>
<transactions_activity_last_24_hours>2</transactions_activity_last_24_hours>
<transactions_activity_previous_year>10</transactions_activity_previous_year>
<provision_attempts_last_24_hours>1</provision_attempts_last_24_hours>
<purchases_count_last_6_months>5</purchases_count_last_6_months>
<suspicious_activity_indicator>no_suspicious_observed</suspicious_activity_indicator>
<registration_indicator>30_to_60_days</registration_indicator>
<registration_date>17-01-2023</registration_date>
</card_holder_account>
<browser>
<accept_header>*/*</accept_header>
<java_enabled>false</java_enabled>
<language>en-GB</language>
<color_depth>24</color_depth>
<screen_height>900</screen_height>
<screen_width>1440</screen_width>
<time_zone_offset>-120</time_zone_offset>
<user_agent>Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36</user_agent>
</browser>
<sdk>
<interface>native</interface>
<ui_types>
<ui_type>multi_select</ui_type>
</ui_types>
<application_id>fc1650c0-5778-0138-8205-2cbc32a32d65</application_id>
<encrypted_data>encrypted-data-here</encrypted_data>
<ephemeral_public_key_pair>public-key-pair</ephemeral_public_key_pair>
<max_timeout>10</max_timeout>
<reference_number>sdk-reference-number-here</reference_number>
</sdk>
</threeds_v2_params>
<sca_params>
<exemption>low_risk</exemption>
</sca_params>
</payment_transaction>'
Asynchronous 3 D Sv2 Challenge With 3ds Method Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Sale3D');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('4938730000000001')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
->setNotificationUrl('https://www.example.com/notification')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
// Threeds V2 Params
->setThreedsThreedsMethod('{"callback_url"=>"https://www.example.com/threeds/threeds_method/callback"}')
->setThreedsControl('{"device_type"=>"browser", "challenge_window_size"=>"full_screen", "challenge_indicator"=>"preference"}')
->setThreedsPurchase('{"category"=>"service"}')
->setThreedsRecurring('{"expiration_date"=>"17-07-2025", "frequency"=>30}')
->setThreedsMerchantRisk('{"shipping_indicator"=>"verified_address", "delivery_timeframe"=>"electronic", "reorder_items_indicator"=>"reordered", "pre_order_purchase_indicator"=>"merchandise_available", "pre_order_date"=>"17-02-2025", "gift_card"=>"true", "gift_card_count"=>"2"}')
->setThreedsCardHolderAccount('{"creation_date"=>"17-01-2024", "update_indicator"=>"more_than_60days", "last_change_date"=>"17-10-2024", "password_change_indicator"=>"no_change", "password_change_date"=>"02-01-2025", "shipping_address_usage_indicator"=>"current_transaction", "shipping_address_date_first_used"=>"12-01-2025", "transactions_activity_last_24_hours"=>"2", "transactions_activity_previous_year"=>"10", "provision_attempts_last_24_hours"=>"1", "purchases_count_last_6_months"=>"5", "suspicious_activity_indicator"=>"no_suspicious_observed", "registration_indicator"=>"30_to_60_days", "registration_date"=>"17-01-2023"}')
->setThreedsBrowser('{"accept_header"=>"*/*", "java_enabled"=>"false", "language"=>"en-GB", "color_depth"=>"24", "screen_height"=>"900", "screen_width"=>"1440", "time_zone_offset"=>"-120", "user_agent"=>"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"}')
->setThreedsSdk('{"interface"=>"native", "ui_types"=>{"ui_type"=>"multi_select"}, "application_id"=>"fc1650c0-5778-0138-8205-2cbc32a32d65", "encrypted_data"=>"encrypted-data-here", "ephemeral_public_key_pair"=>"public-key-pair", "max_timeout"=>"10", "reference_number"=>"sdk-reference-number-here"}')
// Sca Params
->setScaExemption('low_risk')
->set#<Proc:0x00005586a2aaf3b0 includes::Transactions::3ds::V2::Examples::Requests.md.erb:219 (lambda)>('');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.Sale3DRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
Sale3DRequest request = new Sale3DRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4938730000000001");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
request.setNotificationUrl(new URL("https://www.example.com/notification"));
request.setReturnSuccessUrl(new URL("http://www.example.com/success"));
request.setReturnFailureUrl(new URL("http://www.example.com/failure"));
// Threeds V2 Params
request.setThreedsThreedsMethod("{"callback_url"=>"https://www.example.com/threeds/threeds_method/callback"}");
request.setThreedsControl("{"device_type"=>"browser", "challenge_window_size"=>"full_screen", "challenge_indicator"=>"preference"}");
request.setThreedsPurchase("{"category"=>"service"}");
request.setThreedsRecurring("{"expiration_date"=>"17-07-2025", "frequency"=>30}");
request.setThreedsMerchantRisk("{"shipping_indicator"=>"verified_address", "delivery_timeframe"=>"electronic", "reorder_items_indicator"=>"reordered", "pre_order_purchase_indicator"=>"merchandise_available", "pre_order_date"=>"17-02-2025", "gift_card"=>"true", "gift_card_count"=>"2"}");
request.setThreedsCardHolderAccount("{"creation_date"=>"17-01-2024", "update_indicator"=>"more_than_60days", "last_change_date"=>"17-10-2024", "password_change_indicator"=>"no_change", "password_change_date"=>"02-01-2025", "shipping_address_usage_indicator"=>"current_transaction", "shipping_address_date_first_used"=>"12-01-2025", "transactions_activity_last_24_hours"=>"2", "transactions_activity_previous_year"=>"10", "provision_attempts_last_24_hours"=>"1", "purchases_count_last_6_months"=>"5", "suspicious_activity_indicator"=>"no_suspicious_observed", "registration_indicator"=>"30_to_60_days", "registration_date"=>"17-01-2023"}");
request.setThreedsBrowser("{"accept_header"=>"*/*", "java_enabled"=>"false", "language"=>"en-GB", "color_depth"=>"24", "screen_height"=>"900", "screen_width"=>"1440", "time_zone_offset"=>"-120", "user_agent"=>"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"}");
request.setThreedsSdk("{"interface"=>"native", "ui_types"=>{"ui_type"=>"multi_select"}, "application_id"=>"fc1650c0-5778-0138-8205-2cbc32a32d65", "encrypted_data"=>"encrypted-data-here", "ephemeral_public_key_pair"=>"public-key-pair", "max_timeout"=>"10", "reference_number"=>"sdk-reference-number-here"}");
// Sca Params
request.setScaExemption("low_risk");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.sale3d(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "4938730000000001",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"notification_url": "https://www.example.com/notification",
"return_success_url": "http://www.example.com/success",
"return_failure_url": "http://www.example.com/failure",
"threeds_v2_params": {
"threeds_method": {
"callback_url": "https://www.example.com/threeds/threeds_method/callback"
},
"control": {
"device_type": "browser",
"challenge_window_size": "full_screen",
"challenge_indicator": "preference"
},
"purchase": {
"category": "service"
},
"recurring": {
"expiration_date": "17-07-2025",
"frequency": 30
},
"merchant_risk": {
"shipping_indicator": "verified_address",
"delivery_timeframe": "electronic",
"reorder_items_indicator": "reordered",
"pre_order_purchase_indicator": "merchandise_available",
"pre_order_date": "17-02-2025",
"gift_card": "true",
"gift_card_count": "2"
},
"card_holder_account": {
"creation_date": "17-01-2024",
"update_indicator": "more_than_60days",
"last_change_date": "17-10-2024",
"password_change_indicator": "no_change",
"password_change_date": "02-01-2025",
"shipping_address_usage_indicator": "current_transaction",
"shipping_address_date_first_used": "12-01-2025",
"transactions_activity_last_24_hours": "2",
"transactions_activity_previous_year": "10",
"provision_attempts_last_24_hours": "1",
"purchases_count_last_6_months": "5",
"suspicious_activity_indicator": "no_suspicious_observed",
"registration_indicator": "30_to_60_days",
"registration_date": "17-01-2023"
},
"browser": {
"accept_header": "*/*",
"java_enabled": "false",
"language": "en-GB",
"color_depth": "24",
"screen_height": "900",
"screen_width": "1440",
"time_zone_offset": "-120",
"user_agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"
},
"sdk": {
"interface": "native",
"ui_types": {
"ui_type": "multi_select"
},
"application_id": "fc1650c0-5778-0138-8205-2cbc32a32d65",
"encrypted_data": "encrypted-data-here",
"ephemeral_public_key_pair": "public-key-pair",
"max_timeout": "10",
"reference_number": "sdk-reference-number-here"
}
},
"sca_params": {
"exemption": "low_risk"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>sale3d</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4938730000000001</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<notification_url>https://www.example.com/notification</notification_url>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<threeds_v2_params>
<threeds_method>
<callback_url>https://www.example.com/threeds/threeds_method/callback</callback_url>
</threeds_method>
<control>
<device_type>browser</device_type>
<challenge_window_size>full_screen</challenge_window_size>
<challenge_indicator>preference</challenge_indicator>
</control>
<purchase>
<category>service</category>
</purchase>
<merchant_risk>
<shipping_indicator>verified_address</shipping_indicator>
<delivery_timeframe>electronic</delivery_timeframe>
<reorder_items_indicator>reordered</reorder_items_indicator>
<pre_order_purchase_indicator>merchandise_available</pre_order_purchase_indicator>
<pre_order_date>17-02-2025</pre_order_date>
<gift_card>true</gift_card>
<gift_card_count>2</gift_card_count>
</merchant_risk>
<card_holder_account>
<creation_date>17-01-2024</creation_date>
<update_indicator>more_than_60days</update_indicator>
<last_change_date>17-10-2024</last_change_date>
<password_change_indicator>no_change</password_change_indicator>
<password_change_date>02-01-2025</password_change_date>
<shipping_address_usage_indicator>current_transaction</shipping_address_usage_indicator>
<shipping_address_date_first_used>12-01-2025</shipping_address_date_first_used>
<transactions_activity_last_24_hours>2</transactions_activity_last_24_hours>
<transactions_activity_previous_year>10</transactions_activity_previous_year>
<provision_attempts_last_24_hours>1</provision_attempts_last_24_hours>
<purchases_count_last_6_months>5</purchases_count_last_6_months>
<suspicious_activity_indicator>no_suspicious_observed</suspicious_activity_indicator>
<registration_indicator>30_to_60_days</registration_indicator>
<registration_date>17-01-2023</registration_date>
</card_holder_account>
<browser>
<accept_header>*/*</accept_header>
<java_enabled>false</java_enabled>
<language>en-GB</language>
<color_depth>24</color_depth>
<screen_height>900</screen_height>
<screen_width>1440</screen_width>
<time_zone_offset>-120</time_zone_offset>
<user_agent>Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36</user_agent>
</browser>
<sdk>
<interface>native</interface>
<ui_types>
<ui_type>multi_select</ui_type>
</ui_types>
<application_id>fc1650c0-5778-0138-8205-2cbc32a32d65</application_id>
<encrypted_data>encrypted-data-here</encrypted_data>
<ephemeral_public_key_pair>public-key-pair</ephemeral_public_key_pair>
<max_timeout>10</max_timeout>
<reference_number>sdk-reference-number-here</reference_number>
</sdk>
</threeds_v2_params>
<sca_params>
<exemption>low_risk</exemption>
</sca_params>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: sale3d |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | required* | string(255) | Description of the transaction for later use. |
gaming | optional | "true" | Signifies whether a gaming transaction is performed. Gaming transactions usually use MCC 7995. Contact tech-support@emerchantpay.com for more details |
moto | optional | "true" | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech-support@emerchantpay.com for more details |
crypto | optional | "true" | Signifies whether a purchase of crypto-currency transaction is performed. Must be populated when purchasing crypto-currency with a VISA card. Must be populated when purchasing crypto-currency with a MASTER or INTL MAESTRO card and MCC is one of 6051, 6211. Contact tech-support@emerchantpay.com for more details |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
notification_url | required1 | url | URL at merchant where gateway sends outcome of transaction. |
return_success_url | required1 | url | URL where customer is sent to after successful payment |
return_failure_url | required1 | url | URL where customer is sent to after unsuccessful payment |
amount | required | integer >= 0 | Transaction amount in minor currency unit, see Currency and Amount Handling for details. In certain cases, it is possible to submit a transaction with a zero-value amount to act as an account verification transaction - Contact tech-support@emerchantpay.com for more details regarding this scenario. |
currency | required | string(3) | Currency code in ISO 4217 |
card_holder | required | string(45) | Full name of customer as printed on credit card (first name and last name at least). Note, for async 3DSv2 transactions, the card holder name must NOT contain more than 45 chars. Otherwise, the rest will be truncated in the authentication request. |
card_number | required | 13 to 16 digits | Complete cc number of customer |
cvv | required | 3 to 4 digits | cvv of cc, requirement is based on terminal configuration |
expiration_month | required | MM | Expiration month as printed on credit card |
expiration_year | required | YYYY | Expiration year as printed on credit card |
token | optional | string(36) | See Tokenization for more details. If present, the cardholder parameters can be omitted. Cannot be set together with remember_card |
remember_card | optional | "true" | See Tokenize. Tokenizes cardholder parameters. Cannot be set together with token |
consumer_id | optional | string(10) | See Consumers and Tokenization. Combine with remember_card to tokenize or with token to use token |
scheme_tokenized | required* | "true" | Required when the card_number is DPAN instead of Funding Primary Account Number, see Tokenized e-commerce for details |
recurring_type | optional | string(255) | Specifies recurring type of the transaction, can be 'initial' or 'managed'. |
installment_plan_id | optional | string | The ID of the chosen installment plan. Check Installments for more details. |
installment_plan_reference | optional | string | The installment plan reference identifier returned by the schemes. |
credential_on_file | required* | See Credential On File (COF) for more details | |
initial_customer_initiated | required* | string(18) | Initial transaction initiated by customer. Required for external tokenization, and optional for gateway-based tokenization |
subsequent_customer_initiated | required* | string(18) | Subsequent transaction initiated by customer. Required for external tokenization, and optional for gateway-based tokenization |
merchant_unscheduled | optional | string(20) | Transaction is initiated by the merchant |
customer_email | required* | e-mail address | Must contain valid e-mail of customer |
customer_phone | required* | string(16) | Must contain а valid international phone number of the customer as per the ITU-T E.164. It's recommended to not submit a customer phone number containing more than 15 digits or less than 7 digits. Note, for async 3DS transactions that are using the 3DSv2 authentication protocol, it will be shortened up to 15 digits and a prefix + for international phone number will be added if missing. |
birth_date | required* | dd-mm-yyyy | Required when MCC is a Financial Services one (e.g. MCC 6012) and either card brand is Visa or Mastercard/Maestro with UK-based merchant, UK-based bin (domestic), and DEBIT card type |
document_id | required* | string(255) | Document ID value. |
fx_rate_id | optional | integer | See Get rates for FX Service. Offers the option to use a specific FX rate to convert the transaction processing amount. Used FX rate should have the same source currency as the processing currency. Contact tech-support@emerchantpay.com for more details |
business_attributes | required* | Check business attributes section. | |
event_start_date | required* | dd-mm-yyyy | The date when event starts in format dd-mm-yyyy |
event_end_date | required* | dd-mm-yyyy | The date when event ends in format dd-mm-yyyy |
event_organizer_id | required* | string | |
event_id | required* | string | |
date_of_order | required* | dd-mm-yyyy | The date when order was placed in format dd-mm-yyyy |
delivery_date | required* | dd-mm-yyyy | Date of the expected delivery in format dd-mm-yyyy |
name_of_the_supplier | required* | string | |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(150) | Primary address. The field length is limited to 150 chars only for async 3DS transactions that are using the 3DSv2 authentication protocol. |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string(16) | The field that holds the zip code is limited to 16 chars only for async 3DS transactions that are using the 3DSv2 authentication protocol. |
city | required* | string(50) | The field that holds the city is limited to 50 chars only for async 3DS transactions that are using the 3DSv2 authentication protocol. |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(3) | The field that holds the country state is limited to 3 chars only for async 3DS transactions that are using the 3DSv2 authentication protocol. Note: The value should be the country subdivision code defined in ISO 3166-2. Invalid values submitted NOT as per the ISO might lead to data integrity issues. |
country | required* | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(150) | Primary address. The field length is limited to 150 chars only for async 3DS transactions that are using the 3DSv2 authentication protocol. |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string(16) | The field that holds the zip code is limited to 16 chars only for async 3DS transactions that are using the 3DSv2 authentication protocol. |
city | optional | string(50) | The field that holds the city is limited to 50 chars only for async 3DS transactions that are using the 3DSv2 authentication protocol. |
neighborhood | optional | string(255) | Neighborhood |
state | optional | string(3) | The field that holds the country state is limited to 3 chars only for async 3DS transactions that are using the 3DSv2 authentication protocol. Note: The value should be the country subdivision code defined in ISO 3166-2. Invalid values submitted NOT as per the ISO might lead to data integrity issues. |
country | optional | string(2) | Country code in ISO 3166 |
mpi_params | required2 | ||
cavv | required3 | string(255) | Verification Id of the authentication. Please note this can be the CAVV for Visa Card or UCAF to identify MasterCard. |
eci | required3 | string(255) | See Electronic Commerce Indicator as returned from the MPI for details |
protocol_version | required4 | string | The used 3DS protocol version. |
protocol_sub_version | required4 | string | The used 3DS protocol sub-version. |
directory_server_id | required4 | string | The Directory Server ID used for 3DSecure transactions through the 3DSv2 authentication protocol. |
acs_transaction_id | optional | string | The ACS Transaction ID and is optional for 3DS transactions, but highly recommended for increasing the approval ratio. |
threeds_challenge_indicator | optional | string | The 3DS challenge indicator that represents the exact indicator used during the authentication request to the MPI provider for synchronous 3DS transactions. It is optional but highly recommended for increasing the approval ratio. It can only contain one of the following values no_preference, no_challenge_requested, preference and mandate. The default value is no_preference. Check 3DS Challenge Indicators for more details. |
sca_params | optional | SCA params | |
exemption | optional | string | The exemption that the transaction should take advantage of. Note that the requested exemption may not be accepted due to internal risk validations. Check SCA exemption values. |
visa_merchant_id | required5 | string(8) | VMID assigned by Visa if participating in Trusted merchant program. |
funding | optional | Funding Transaction Params | |
identifier_type | required* | string | This is only required in case of Mastercard. Type of Funding Transaction. Please check Identifier Types |
business_application_identifier | required* | string | This is only required in case of VISA. Type of VISA Funding Transaction. Please check BAI |
receiver | optional | Funding Transaction Receiver details | |
first_name | required* | string | First name of the receiver |
last_name | required* | string | Last name of the receiver |
country | required* | string(2) | Country code in ISO 3166 |
account_number | required* | string | Receiver account number. Mandatory for Mastercard. If Sender Reference Number is provided then it becomes optional for VISA |
account_number_type | required* | string | This is only required in case of Mastercard. Receiver account number type. Please check Receiver Account Types |
address | required* | string | Receiver address. Only required in case of VISA and Canadian cards |
state | required* | string | Receiver state. Only required in case of VISA and Canadian cards |
city | required* | string | Receiver city. Only required in case of VISA and Canadian cards |
sender | optional | Funding Transaction Sender details | |
name | required* | string | Sender name. Only required in case of VISA |
reference_number | required* | string | Sender Reference Number. Only required in case of VISA. This is option if Receiver Account Number is provided |
country | required* | string | Sender country. Only required in case of VISA. If not provided billing address is used |
address | required* | string | Sender address. Only required in case of VISA. If not provided billing address is used |
state | required* | string | Sender state. Only required in case of VISA and Canadian card. If not provided billing address is used |
city | required* | string | Sender city. Only required in case of VISA. If not provided billing address is used |
threeds_v2_params | required* | 3DSv2 async parameters. They must be submitted in order to use the 3DSv2 authentication protocol in asynchronous workflow | |
threeds_method | optional | 3DS-Method related parameters for any callbacks and notifications. | |
callback_url | optional | url | Specific 3DS-Method callback URL after the 3DS-Method completes. The actual status will be provided via HTTP POST to that URL. For more information, go to 3DSv2 method params |
control | required* | General params for preferences in authentication flow and providing device interface information. | |
device_type | required* | string | Identifies the device channel of the consumer, required in the 3DSv2 authentication protocol. For more information, go to 3DSv2 control params |
challenge_window_size | required* | string | Identifies the size of the challenge window for the consumer. For more information, go to 3DSv2 control params |
challenge_indicator | optional | string | The value has weight and might impact the decision whether a challenge will be required for the transaction or not. If not provided, it will be interpreted as no_preference. For more information, go to 3DSv2 control params |
purchase | optional | Purchase related params providing with additional information regarding the order. | |
category | optional | string | Identifies the type of transaction being authenticated. This field is required in some markets.Accepted values are: goods, service, check_acceptance, account_funding, quasi_cash, prepaid_activation, loan. |
merchant_risk | recommended | Merchant risk assessment params. They are all optional, but recommended. | |
shipping_indicator | optional | string(16) | Indicator code that most accurately describes the shipping method for the cardholder specific transaction. If one or more items are included in the sale, use the Shipping Indicator code for the physical goods. If all digital goods, use the code that describes the most expensive item. Accepted values are: same_as_billing, stored_address, verified_address, pick_up, digital_goods, travel, event_tickets, other. |
delivery_timeframe | optional | string(11) | Indicates the merchandise delivery timeframe. Accepted values are: electronic, same_day, over_night, another_day. |
reorder_items_indicator | optional | string(10) | Indicates whether the cardholder is reordering previously purchased merchandise. Accepted values are: first_time, reordered. |
pre_order_purchase_indicator | optional | string(21) | Indicates whether cardholder is placing an order for merchandise with a future-availability or release date. Accepted values are: merchandise_available, future_availability. |
pre_order_date | optional | dd-mm-yyyy | For a pre-ordered purchase, the expected date that the merchandise will be available. |
gift_card | optional | 'true' | Prepaid or gift card purchase. |
gift_card_count | optional | integer | For prepaid or gift card purchase, total count of individual prepaid or gift cards/codes purchased. The value is limited to 99. |
card_holder_account | recommended | Cardholder account additional information. They are all optional, but recommended, because they have a significant impact on approval rates | |
creation_date | optional | dd-mm-yyyy | Date that the cardholder opened the account with the 3DS Requester. |
update_indicator | optional | string(19) | Length of time since the cardholder’s account information with the 3DS Requestor was last changed. Includes Billing or Shipping address, new payment account, or new user(s) added. Accepted values are: current_transaction, less_than_30days, 30_to_60_days, more_than_60days. |
last_change_date | optional | dd-mm-yyyy | Date that the cardholder’s account with the 3DS Requestor was last changed. Including Billing or Shipping address, new payment accout, or new user(s) added. |
password_change_indicator | optional | string(18) | Length of time since the cardholder account with the 3DS Requestor had a password change or account reset. Accepted values are: no_change, during_transaction, less_than_30days, 30_to_60_days, more_than_60days. |
password_change_date | optional | dd-mm-yyyy | Date that cardholder’s account with the 3DS Requestor had a password change or account reset. |
shipping_address_usage_indicator | optional | string(19) | Indicates when the shipping address used for this transaction was first used with the 3DS Requestor. Accepted values are: current_transaction, less_than_30days, 30_to_60_days, more_than_60days. |
shipping_address_date_first_used | optional | dd-mm-yyyy | Date when the shipping address used for this transaction was first used with the 3DS Requestor. |
transactions_activity_last_24_hours | optional | integer | Number of transactions (successful and abandoned) for this cardholder account with the 3DS Requestor across all payment accounts in the previous 24 hours. |
transactions_activity_previous_year | optional | integer | Number of transactions (successful and abandoned) for this cardholder account with the 3DS Requestor across all payment accounts in the previous year. |
provision_attempts_last_24_hours | optional | integer | Number of Add Card attempts in the last 24 hours. |
purchases_count_last_6_months | optional | integer | Number of purchases with this cardholder account during the previous six months. |
suspicious_activity_indicator | optional | string(22) | Indicates whether the 3DS Requestor has experienced suspicious activity (including previous fraud) on the cardholder account. Accepted values are: no_suspicious_observed, suspicious_observed. |
registration_indicator | optional | string(19) | Indicates the length of time that the payment account was enrolled in the cardholder’s account with the 3DS Requester. Accepted values are: guest_checkout, current_transaction, less_than_30days, 30_to_60_days, more_than_60days. |
registration_date | optional | dd-mm-yyyy | Date that the payment account was enrolled in the cardholder’s account with the 3DS Requestor. |
browser | required* | For browser-based transactions. They are all required in case the device_type is set to browser | |
accept_header | required* | string(2048) | The exact content of the HTTP ACCEPT header as sent to the 3DS Requester from the Cardholder browser. Any other header different than the ACCEPT header will be rejected. Example: application/json,text/plain,text/html,*/* . |
java_enabled | required* | boolean | Boolean that represents the ability of the cardholder browser to execute Java. The value can be retrieved by accessing a property of the navigator with JavaScript, navigator.javaEnabled . |
language | required* | string(8) | Value representing the browser language as defined in IETF BCP47. Note that only one browser language tag is about to be submitted as per the above IETF BCP47. Numeric chars are also allowed in the subtag and will represent the region.Example: en-GB , zh-guoyu , fil-PH , gsw , es-419 , de-1996 , etc. The value can be retrieved by accessing a property of the navigator with JavaScript, navigator.language . |
color_depth | required* | integer | Value representing the bit depth of the colour palette for displaying images, in bits per pixel. Obtained from Cardholder browser using the screen.colorDepth property. The value as per EMVCo specs can be one of 1, 4, 8, 15, 16, 24, 32, 48. In case, an unsupported color_depth is determined, the nearest supported value that is less than the actual one needs to be submitted. For example, if the obtained value is 30, which is not supported as per EMVCo specs, 24 has to be submitted. |
screen_height | required* | integer | Total height of the Cardholder's screen in pixels. Value is returned from the screen.height property. |
screen_width | required* | integer | Total width of the Cardholder's screen in pixels. Value is returned from the screen.width property. |
time_zone_offset | required* | string(5) | Time difference between UTC time and the Cardholder browser local time, in minutes. Note that the offset is positive if the local time zone is behind UTC and negative if it is ahead. If UTC -5 hours then submit 300 or +300 , If UTC +2 hours then -120 . The value can be retrieved using Javascript getTimezoneOffset() method over Date object. |
user_agent | required* | string(2048) | Exact content of the HTTP user-agent header. |
sdk | required* | For application-based transactions. They are all required in case the device_type is set to application | |
interface | required* | string(6) | SDK Interface types that the device of the consumer supports for displaying specific challenge interfaces within the SDK. Accepted values are: native, html, both. |
ui_types | required* | Lists all UI types that the device of the consumer supports for displaying specific challenge interfaces within the SDK. | |
ui_type | required* | string(13) | UI type that the device of the consumer supports for displaying specific challenge interface. Accepted values are: text, single_select, multi_select, out_of_bag, other_html. |
application_id | required* | string(36) | Universally unique ID created upon all installations and updates of the 3DS Requestor APp on a Customer Device. This will be newly generated and stored by the 3DS SDK for each installation or update. The field is limited to 36 characters and it shall have a canonical format as defined in IETF RFC 4122. |
encrypted_data | required* | string(64000) | JWE Object as defined Section 6.2.2.1 containing data encrypted by the SDK for the DS to decrypt. The data will be present when sending to DS, but not present from DS to ACS. |
ephemeral_public_key_pair | required* | string(256) | Public key component of the ephemeral key pair generated by the 3DS SDK and used to establish session keys between the 3DS SDK and ACS. In AReq, this data element is contained within the ACS Signed Content JWS Object. The field is limited to maximum 256 characters. |
max_timeout | required* | integer | Indicates the maximum amount of time (in minutes) for all exchanges. The field shall have value greater or equals than 05. |
reference_number | required* | string(32) | Identifies the vendor and version of the 3DS SDK that is integrated in a 3DS Requestor App, assigned by EMVCo when the 3DS SDK is approved. The field is limited to 32 characters. |
dynamic_descriptor_params | optional | ||
merchant_name | optional | string(25) | Allows to dynamically override the charge descriptor |
merchant_city | optional | string(13) | Allows to dynamically override the merchant phone number |
sub_merchant_id | optional | string(15) | Allows to dynamically override the sub-merchant ID. |
merchant_country | optional | string(3) | Allows to dynamically override the merchant country. |
merchant_state | optional | string(3) | Allows to dynamically override the merchant subdivision code. |
merchant_zip_code | optional | string(10) | Allows to dynamically override the merchant zip/postal code. Required for VISA OCT transactions with Australian and Canadian card bins. |
merchant_address | optional | string(48) | Allows to dynamically override the merchant address. |
merchant_url | optional | string(60) | Allows to dynamically override the merchant URL |
merchant_phone | optional | string(16) | Allows to dynamically override the merchant phone number. |
merchant_service_city | optional | string(13) | Allows to dynamically override the merchant service city. |
merchant_service_country | optional | string(3) | Allows to dynamically override the merchant service country. |
merchant_service_state | optional | string(3) | Allows to dynamically override the merchant service subdivision code. |
merchant_service_zip_code | optional | string(10) | Allows to dynamically override the merchant service zip/postal code. |
merchant_service_phone | optional | string(16) | Allows to dynamically override the merchant service phone number. |
merchant_geo_coordinates | optional | string(20) | Allows to dynamically override the merchant geographic coordinates. |
merchant_service_geo_coordinates | optional | string(20) | Allows to dynamically override the merchant service geographic coordinates. |
required* = conditionally required
1 - Required if mpi_params
is not present, the transaction will be handled asynchronously. Not required if configured on Terminal or Merchant level. Contact Tech Support for more details.
2 - Required if transaction should be handled synchronous.
3 - eci
is always required if mpi_params
is present.
cavv
is not required for the 3D attempted only workflow, but it is strongly recommended in a combination with the Directory Server ID in order to be in the scope of the 3DSv2 authentication protocol.
4 - protocol_version
is required due to the only one 3DSv2 authentication protocol that is currently supported.
directory_server_id
is mandatory when protocol_version is 2. May be omitted for scheme tokenized transactions.
5 - visa_merchant_id
is required when exemption value is trusted_merchant
.
Frictionless / Challenge Response
stdClass Object
(
[transaction_type] => sale3d
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[consumer_id] => 123456
[token] => ee946db8-d7db-4bb7-b608-b65b153e127d
[threeds_method_url] => https://staging.gate.emerchantpay.net/threeds/threeds_method
[threeds_method_continue_url] => https://staging.gate.emerchantpay.net/threeds/threeds_method/44177a21403427eb96664a6d7e5d5d48
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:49.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => false
[reason_for_not_honoring_exemption] => 8A01
[sca_exemption_result] => 13
)
<payment_response content=[
<transaction_type content=[sale3d]>
<status content=[pending_async]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<consumer_id content=[123456]>
<token content=[ee946db8-d7db-4bb7-b608-b65b153e127d]>
<threeds_method_url content=[https://staging.gate.emerchantpay.net/threeds/threeds_method]>
<threeds_method_continue_url content=[https://staging.gate.emerchantpay.net/threeds/threeds_method/44177a21403427eb96664a6d7e5d5d48]>
<timestamp content=[2025-01-16T10:23:49Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[false]>
<reason_for_not_honoring_exemption content=[8A01]>
<sca_exemption_result content=[13]>
]>
{
transaction_type: "sale3d",
status: "pending_async",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
consumer_id: "123456",
token: "ee946db8-d7db-4bb7-b608-b65b153e127d",
threeds_method_url: "https://staging.gate.emerchantpay.net/threeds/threeds_method",
threeds_method_continue_url: "https://staging.gate.emerchantpay.net/threeds/threeds_method/44177a21403427eb96664a6d7e5d5d48",
timestamp: "2025-01-16T10:23:49Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "false",
reason_for_not_honoring_exemption: "8A01",
sca_exemption_result: "13",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>sale3d</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<consumer_id>123456</consumer_id>
<token>ee946db8-d7db-4bb7-b608-b65b153e127d</token>
<threeds_method_url>https://staging.gate.emerchantpay.net/threeds/threeds_method</threeds_method_url>
<threeds_method_continue_url>https://staging.gate.emerchantpay.net/threeds/threeds_method/44177a21403427eb96664a6d7e5d5d48</threeds_method_continue_url>
<timestamp>2025-01-16T10:23:49Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>false</sent_to_acquirer>
<reason_for_not_honoring_exemption>8A01</reason_for_not_honoring_exemption>
<sca_exemption_result>13</sca_exemption_result>
</payment_response>
Challenge Without 3 Ds Mеthod Response
stdClass Object
(
[transaction_type] => sale3d
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[consumer_id] => 123456
[token] => ee946db8-d7db-4bb7-b608-b65b153e127d
[redirect_url] => https://staging.gate.emerchantpay.net/threeds/authentication/44177a21403427eb96664a6d7e5d5d48
[redirect_url_type] => 3ds_v2_challenge
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:49.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => false
[reason_for_not_honoring_exemption] => 8A01
[sca_exemption_result] => 13
)
<payment_response content=[
<transaction_type content=[sale3d]>
<status content=[pending_async]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<consumer_id content=[123456]>
<token content=[ee946db8-d7db-4bb7-b608-b65b153e127d]>
<redirect_url content=[https://staging.gate.emerchantpay.net/threeds/authentication/44177a21403427eb96664a6d7e5d5d48]>
<redirect_url_type content=[3ds_v2_challenge]>
<timestamp content=[2025-01-16T10:23:49Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[false]>
<reason_for_not_honoring_exemption content=[8A01]>
<sca_exemption_result content=[13]>
]>
{
transaction_type: "sale3d",
status: "pending_async",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
consumer_id: "123456",
token: "ee946db8-d7db-4bb7-b608-b65b153e127d",
redirect_url: "https://staging.gate.emerchantpay.net/threeds/authentication/44177a21403427eb96664a6d7e5d5d48",
redirect_url_type: "3ds_v2_challenge",
timestamp: "2025-01-16T10:23:49Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "false",
reason_for_not_honoring_exemption: "8A01",
sca_exemption_result: "13",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>sale3d</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<consumer_id>123456</consumer_id>
<token>ee946db8-d7db-4bb7-b608-b65b153e127d</token>
<redirect_url>https://staging.gate.emerchantpay.net/threeds/authentication/44177a21403427eb96664a6d7e5d5d48</redirect_url>
<redirect_url_type>3ds_v2_challenge</redirect_url_type>
<timestamp>2025-01-16T10:23:49Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>false</sent_to_acquirer>
<reason_for_not_honoring_exemption>8A01</reason_for_not_honoring_exemption>
<sca_exemption_result>13</sca_exemption_result>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
consumer_id | string(10) | Consumer unique reference. See Consumers |
token | string(36) | Plain-text token value. See Tokenization |
gaming | 'true' | Signifies whether a gaming transaction is performed. Gaming transactions usually use MCC 7995, contact tech support for more details. |
moto | 'true' | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech support for more details. |
avs_response_code | string(255) | Generated by the card network on trying to match the billing address when performing the address verification. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
avs_response_text | string(255) | Gives the human response text for the AVS response code above. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
cvv_result_code | string(1) | Card Verification Value response code. Optional, returned only if acquirer supports it |
authorization_code | string(6) | Generated by the card network when an authorisation has occurred, used to identify that auth. Consists of 6 alphanumeric chars |
retrieval_reference_number | string(255) | A reference number used for tracking all messages related to a given cardholder transaction returned by some acquirers. |
payment_account_reference | string(255) | Payment Account Reference value returned from the schemes. Links tokenized and PAN-based transactions. |
response_code | string(2) | Defines the result of a transaction with the acquirer, the status of a message or some action taken or required. Contact tech-support@emerchantpay.com for more details. |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where the consumer has to be redirected to complete the payment process unless a 3DSecure Method is required. This redirect_url will not be included in the response if a 3DS-Method submission is required. For more information, to go 3DSv2 authentication flows |
redirect_url_type | string(64) | The type of the redirect URL in the 3DS scope. It will be present only for asynchronous 3D transactions when an interaction between consumer and issuer is required. This type identifies what kind of redirect url is returned, namely 3DSv2 Challenge. For more information, to go 3DSv2 authentication flows |
threeds_method_url | url | 3DSecure Method URL. It will be present only then 3DS-Method is required for 3D transaction. A 3DS-Method submission inside an iframe is required to be submitted using HTTP POST. For more information, to go 3DSv2 authentication flows |
threeds_method_continue_url | url | This is an API endpoint that accepts HTTP PUT & HTTP PATCH requests. It will be present when the threeds_method_url is included in the response. An HTTP PUT request must be submitted to that endpoint together with the proper signature to determine what the next step in the authentication is. For more information, to go 3DSv2 authentication flows |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
partial_approval | string(4) | Optional, set to ’true’ if partial approval happened. Partially approved amount is then in the amount field. Check Partial Approvals for details |
sent_to_acquirer | string(255) | "true" or "false" |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
scheme_transaction_identifier | string(32) | Id defined by card schemes. Corresponds to NETWORK DATA (field 63) for MasterCard or TRANS ID (field 62.2/125) for VISA. |
scheme_transaction_link_id | string(22) | The transaction unique identifier returned from the schemes. Corresponds to ADDITIONAL SERVICE DATA (field 65, MasterCard Transaction Link Id [TLID]). |
scheme_pan_indicator | string(1) | The account number indicator in scheme-tokenized transactions. See Account number indicator codes for details. |
scheme_pan_tail | string(4) | The tail of the PAN number tail associated with the token in scheme-tokenized transactions. Returned in conjunction with scheme_pan_indicator . |
scheme_max_settlement_date | string(10) | The final date an authorization could be captured which is returned from the card scheme. See Scheme Maximum Settlement Date for more details. |
scheme_authentication_data_quality | boolean | The Authentication Data Quality Indicator returned by the card scheme is used to indicate whether a transaction meets the authentication data quality requirements. The value can be either true or false . |
scheme_settlement_date | string(4) | MasterCard settlement date in MMDD format (e.g. 0117). Corresponds to NETWORK DATA (field 15). |
reason_for_not_honoring_exemption | string | Reason for not honoring exemption. Check SCA Reason For Not Honoring Exemption Values. |
sca_exemption_result | string | SCA exemption result. Check SCA Exemption Result Values. |
threeds | ||
eci | string(2) | See Electronic Commerce Indicator as returned from the MPI for details |
Error Response
stdClass Object
(
[transaction_type] => sale3d
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[response_code] => 57
[code] => 340
[technical_message] => expiration_year is invalid
[message] => expiration_year is invalid
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:49.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => false
)
<payment_response content=[
<transaction_type content=[sale3d]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<response_code content=[57]>
<code content=[340]>
<technical_message content=[expiration_year is invalid]>
<message content=[expiration_year is invalid]>
<timestamp content=[2025-01-16T10:23:49Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[false]>
]>
{
transaction_type: "sale3d",
status: "error",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
response_code: "57",
code: "340",
technical_message: "expiration_year is invalid",
message: "expiration_year is invalid",
timestamp: "2025-01-16T10:23:49Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "false",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>sale3d</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<response_code>57</response_code>
<code>340</code>
<technical_message>expiration_year is invalid</technical_message>
<message>expiration_year is invalid</message>
<timestamp>2025-01-16T10:23:49Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
gaming | 'true' | Signifies whether a gaming transaction is performed. Gaming transactions usually use MCC 7995, contact tech support for more details. |
moto | 'true' | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech support for more details. |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
threeds | ||
authentication | ||
status_reason_code | string(2) | See 3DS Authentication Status Reason Codes for details. |
Error Response
stdClass Object
(
[transaction_type] => sale3d
[status] => declined
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 600
[technical_message] => Cardholder not participating 3DS.
[message] => Transaction failed, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:49.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
[threeds] => {"eci"=>"06", "authentication"=>{"status_reason_code"=>"08"}}
)
<payment_response content=[
<transaction_type content=[sale3d]>
<status content=[declined]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<code content=[600]>
<technical_message content=[Cardholder not participating 3DS.]>
<message content=[Transaction failed, please contact support!]>
<timestamp content=[2025-01-16T10:23:49Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[true]>
<threeds content=[{"eci"=>"06", "authentication"=>{"status_reason_code"=>"08"}}]>
]>
{
transaction_type: "sale3d",
status: "declined",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
code: "600",
technical_message: "Cardholder not participating 3DS.",
message: "Transaction failed, please contact support!",
timestamp: "2025-01-16T10:23:49Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "true",
threeds: "{"eci"=>"06", "authentication"=>{"status_reason_code"=>"08"}}",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>sale3d</transaction_type>
<status>declined</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>600</code>
<technical_message>Cardholder not participating 3DS.</technical_message>
<message>Transaction failed, please contact support!</message>
<timestamp>2025-01-16T10:23:49Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
<threeds>
<eci>06</eci>
<authentication>
<status_reason_code>08</status_reason_code>
</authentication>
</threeds>
</payment_response>
Init Recurring Sale 3D
InitRecurringSale3D transactions basically have the same request as standard InitRecurringSale transactions.
Visa Synchronous 3 D Sv2 Fully Authenticated Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Recurring\InitRecurringSale3D');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('4012000000060085')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
// MPI Synchronous 3DSv2
->setMpiEci('05')
->setMpiCavv('MDAwMDAwMDAwMDAxMTA2Njk5NFg=')
->setMpiProtocolVersion('2')
->setMpiProtocolSubVersion('2')
->setMpiDirectoryServerId('11008d90-b6eb-013d-d770-0a58a9feac02')
->setMpiAcsTransactionId('11008e40-b6eb-013d-d770-0a58a9feac02')
->setMpiThreedsChallengeIndicator('preference')
// Sca Params
->setScaExemption('trusted_merchant')
->setScaVisaMerchantId('00000000')
->set#<Proc:0x00005586a21ee960 includes::Transactions::3ds::V2::Examples::Requests.md.erb:43 (lambda)>('');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.recurring.InitRecurringSale3D;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
InitRecurringSale3D request = new InitRecurringSale3D();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4012000000060085");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
// Mpi Synchronous V2
request.setMpiParams("{"eci"=>"05", "cavv"=>"MDAwMDAwMDAwMDAxMTA2Njk5NFg=", "protocol_version"=>"2", "protocol_sub_version"=>"2", "directory_server_id"=>"11008d90-b6eb-013d-d770-0a58a9feac02", "acs_transaction_id"=>"11008e40-b6eb-013d-d770-0a58a9feac02", "threeds_challenge_indicator"=>"preference"}");
// Sca Params
request.setScaExemption("trusted_merchant");
request.setScaVisaMerchantId("00000000");
request.setRecurringCategory("subscription");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.init_recurring_sale3d(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "4012000000060085",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"business_attributes": {
"event_start_date": "17-02-2025",
"event_end_date": "26-02-2025",
"event_organizer_id": "20192375",
"event_id": "1912"
},
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"mpi_params": {
"eci": "05",
"cavv": "MDAwMDAwMDAwMDAxMTA2Njk5NFg=",
"protocol_version": "2",
"protocol_sub_version": "2",
"directory_server_id": "11008d90-b6eb-013d-d770-0a58a9feac02",
"acs_transaction_id": "11008e40-b6eb-013d-d770-0a58a9feac02",
"threeds_challenge_indicator": "preference"
},
"sca_params": {
"exemption": "trusted_merchant",
"visa_merchant_id": "00000000"
},
"recurring_category": "subscription"
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>init_recurring_sale3d</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4012000000060085</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<business_attributes>
<event_start_date>17-02-2025</event_start_date>
<event_end_date>26-02-2025</event_end_date>
<event_organizer_id>20192375</event_organizer_id>
<event_id>1912</event_id>
</business_attributes>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<mpi_params>
<eci>05</eci>
<cavv>MDAwMDAwMDAwMDAxMTA2Njk5NFg=</cavv>
<protocol_version>2</protocol_version>
<protocol_sub_version>2</protocol_sub_version>
<directory_server_id>11008d90-b6eb-013d-d770-0a58a9feac02</directory_server_id>
<acs_transaction_id>11008e40-b6eb-013d-d770-0a58a9feac02</acs_transaction_id>
<threeds_challenge_indicator>preference</threeds_challenge_indicator>
</mpi_params>
<sca_params>
<exemption>trusted_merchant</exemption>
<visa_merchant_id>00000000</visa_merchant_id>
</sca_params>
<recurring_category>subscription</recurring_category>
</payment_transaction>'
Master Synchronous 3 D Sv2 Fully Authenticated Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Recurring\InitRecurringSale3D');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('5555555555559997')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
// MPI Synchronous 3DSv2
->setMpiEci('02')
->setMpiCavv('kQOImea0C/2ta1NZl4Hhwslmomqj')
->setMpiProtocolVersion('2')
->setMpiProtocolSubVersion('2')
->setMpiDirectoryServerId('11063240-b6eb-013d-d770-0a58a9feac02')
->setMpiAcsTransactionId('11063300-b6eb-013d-d770-0a58a9feac02')
->setMpiThreedsChallengeIndicator('preference')
->set#<Proc:0x00005586a24a5988 includes::Transactions::3ds::V2::Examples::Requests.md.erb:85 (lambda)>('');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.recurring.InitRecurringSale3D;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
InitRecurringSale3D request = new InitRecurringSale3D();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("5555555555559997");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
// Mpi Synchronous V2
request.setMpiParams("{"eci"=>"02", "cavv"=>"kQOImea0C/2ta1NZl4Hhwslmomqj", "protocol_version"=>"2", "protocol_sub_version"=>"2", "directory_server_id"=>"11063240-b6eb-013d-d770-0a58a9feac02", "acs_transaction_id"=>"11063300-b6eb-013d-d770-0a58a9feac02", "threeds_challenge_indicator"=>"preference"}");
request.setRecurringCategory("subscription");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.init_recurring_sale3d(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "5555555555559997",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"business_attributes": {
"event_start_date": "17-02-2025",
"event_end_date": "26-02-2025",
"event_organizer_id": "20192375",
"event_id": "1912"
},
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"mpi_params": {
"eci": "02",
"cavv": "kQOImea0C/2ta1NZl4Hhwslmomqj",
"protocol_version": "2",
"protocol_sub_version": "2",
"directory_server_id": "11063240-b6eb-013d-d770-0a58a9feac02",
"acs_transaction_id": "11063300-b6eb-013d-d770-0a58a9feac02",
"threeds_challenge_indicator": "preference"
},
"recurring_category": "subscription"
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>init_recurring_sale3d</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>5555555555559997</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<business_attributes>
<event_start_date>17-02-2025</event_start_date>
<event_end_date>26-02-2025</event_end_date>
<event_organizer_id>20192375</event_organizer_id>
<event_id>1912</event_id>
</business_attributes>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<mpi_params>
<eci>02</eci>
<cavv>kQOImea0C/2ta1NZl4Hhwslmomqj</cavv>
<protocol_version>2</protocol_version>
<protocol_sub_version>2</protocol_sub_version>
<directory_server_id>11063240-b6eb-013d-d770-0a58a9feac02</directory_server_id>
<acs_transaction_id>11063300-b6eb-013d-d770-0a58a9feac02</acs_transaction_id>
<threeds_challenge_indicator>preference</threeds_challenge_indicator>
</mpi_params>
<recurring_category>subscription</recurring_category>
</payment_transaction>'
Visa Synchronous 3 D Sv2 Attempted Authentication Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Recurring\InitRecurringSale3D');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('4012000000060085')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
// MPI Synchronous 3DSv2
->setMpiEci('06')
->setMpiCavv('MDAwMDAwMDAwMDAxMTA2Njk5NFg=')
->setMpiProtocolVersion('2')
->setMpiProtocolSubVersion('2')
->setMpiDirectoryServerId('110c4c30-b6eb-013d-d770-0a58a9feac02')
->setMpiAcsTransactionId('110c4cc0-b6eb-013d-d770-0a58a9feac02')
->setMpiThreedsChallengeIndicator('preference')
// Sca Params
->setScaExemption('trusted_merchant')
->setScaVisaMerchantId('00000000')
->set#<Proc:0x00005586a2724ec0 includes::Transactions::3ds::V2::Examples::Requests.md.erb:43 (lambda)>('');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.recurring.InitRecurringSale3D;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
InitRecurringSale3D request = new InitRecurringSale3D();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4012000000060085");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
// Mpi Synchronous V2
request.setMpiParams("{"eci"=>"06", "cavv"=>"MDAwMDAwMDAwMDAxMTA2Njk5NFg=", "protocol_version"=>"2", "protocol_sub_version"=>"2", "directory_server_id"=>"110c4c30-b6eb-013d-d770-0a58a9feac02", "acs_transaction_id"=>"110c4cc0-b6eb-013d-d770-0a58a9feac02", "threeds_challenge_indicator"=>"preference"}");
// Sca Params
request.setScaExemption("trusted_merchant");
request.setScaVisaMerchantId("00000000");
request.setRecurringCategory("subscription");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.init_recurring_sale3d(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "4012000000060085",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"business_attributes": {
"event_start_date": "17-02-2025",
"event_end_date": "26-02-2025",
"event_organizer_id": "20192375",
"event_id": "1912"
},
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"mpi_params": {
"eci": "06",
"cavv": "MDAwMDAwMDAwMDAxMTA2Njk5NFg=",
"protocol_version": "2",
"protocol_sub_version": "2",
"directory_server_id": "110c4c30-b6eb-013d-d770-0a58a9feac02",
"acs_transaction_id": "110c4cc0-b6eb-013d-d770-0a58a9feac02",
"threeds_challenge_indicator": "preference"
},
"sca_params": {
"exemption": "trusted_merchant",
"visa_merchant_id": "00000000"
},
"recurring_category": "subscription"
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>init_recurring_sale3d</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4012000000060085</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<business_attributes>
<event_start_date>17-02-2025</event_start_date>
<event_end_date>26-02-2025</event_end_date>
<event_organizer_id>20192375</event_organizer_id>
<event_id>1912</event_id>
</business_attributes>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<mpi_params>
<eci>06</eci>
<cavv>MDAwMDAwMDAwMDAxMTA2Njk5NFg=</cavv>
<protocol_version>2</protocol_version>
<protocol_sub_version>2</protocol_sub_version>
<directory_server_id>110c4c30-b6eb-013d-d770-0a58a9feac02</directory_server_id>
<acs_transaction_id>110c4cc0-b6eb-013d-d770-0a58a9feac02</acs_transaction_id>
<threeds_challenge_indicator>preference</threeds_challenge_indicator>
</mpi_params>
<sca_params>
<exemption>trusted_merchant</exemption>
<visa_merchant_id>00000000</visa_merchant_id>
</sca_params>
<recurring_category>subscription</recurring_category>
</payment_transaction>'
Master Synchronous 3 D Sv2 Attempted Authentication Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Recurring\InitRecurringSale3D');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('5555555555559997')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
// MPI Synchronous 3DSv2
->setMpiEci('01')
->setMpiCavv('kFOImea0C/2ta1NZl4Hhwslmomqj')
->setMpiProtocolVersion('2')
->setMpiProtocolSubVersion('2')
->setMpiDirectoryServerId('1111bde0-b6eb-013d-d770-0a58a9feac02')
->setMpiAcsTransactionId('1111be70-b6eb-013d-d770-0a58a9feac02')
->setMpiThreedsChallengeIndicator('preference')
->set#<Proc:0x00005586a29a4628 includes::Transactions::3ds::V2::Examples::Requests.md.erb:85 (lambda)>('');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.recurring.InitRecurringSale3D;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
InitRecurringSale3D request = new InitRecurringSale3D();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("5555555555559997");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
// Mpi Synchronous V2
request.setMpiParams("{"eci"=>"01", "cavv"=>"kFOImea0C/2ta1NZl4Hhwslmomqj", "protocol_version"=>"2", "protocol_sub_version"=>"2", "directory_server_id"=>"1111bde0-b6eb-013d-d770-0a58a9feac02", "acs_transaction_id"=>"1111be70-b6eb-013d-d770-0a58a9feac02", "threeds_challenge_indicator"=>"preference"}");
request.setRecurringCategory("subscription");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.init_recurring_sale3d(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "5555555555559997",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"business_attributes": {
"event_start_date": "17-02-2025",
"event_end_date": "26-02-2025",
"event_organizer_id": "20192375",
"event_id": "1912"
},
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"mpi_params": {
"eci": "01",
"cavv": "kFOImea0C/2ta1NZl4Hhwslmomqj",
"protocol_version": "2",
"protocol_sub_version": "2",
"directory_server_id": "1111bde0-b6eb-013d-d770-0a58a9feac02",
"acs_transaction_id": "1111be70-b6eb-013d-d770-0a58a9feac02",
"threeds_challenge_indicator": "preference"
},
"recurring_category": "subscription"
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>init_recurring_sale3d</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>5555555555559997</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<business_attributes>
<event_start_date>17-02-2025</event_start_date>
<event_end_date>26-02-2025</event_end_date>
<event_organizer_id>20192375</event_organizer_id>
<event_id>1912</event_id>
</business_attributes>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<mpi_params>
<eci>01</eci>
<cavv>kFOImea0C/2ta1NZl4Hhwslmomqj</cavv>
<protocol_version>2</protocol_version>
<protocol_sub_version>2</protocol_sub_version>
<directory_server_id>1111bde0-b6eb-013d-d770-0a58a9feac02</directory_server_id>
<acs_transaction_id>1111be70-b6eb-013d-d770-0a58a9feac02</acs_transaction_id>
<threeds_challenge_indicator>preference</threeds_challenge_indicator>
</mpi_params>
<recurring_category>subscription</recurring_category>
</payment_transaction>'
Master Synchronous 3 D Sv2 Acquirer Exemption Accepted (Tra Already Performed) Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Recurring\InitRecurringSale3D');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('5169750000001111')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
// MPI Synchronous 3DSv2
->setMpiEci('06')
->setMpiCavv('kNMAAAAA3S13awBkrWtTWZeBBCmy')
->setMpiProtocolVersion('2')
->setMpiProtocolSubVersion('2')
->setMpiDirectoryServerId('11171530-b6eb-013d-d770-0a58a9feac02')
->setMpiAcsTransactionId('111715d0-b6eb-013d-d770-0a58a9feac02')
->setMpiThreedsChallengeIndicator('preference')
// Sca Params
->setScaExemption('low_risk')
->set#<Proc:0x00005586a2cee3d8 includes::Transactions::3ds::V2::Examples::Requests.md.erb:132 (lambda)>('');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.recurring.InitRecurringSale3D;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
InitRecurringSale3D request = new InitRecurringSale3D();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("5169750000001111");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
// Mpi Synchronous V2
request.setMpiParams("{"eci"=>"06", "cavv"=>"kNMAAAAA3S13awBkrWtTWZeBBCmy", "protocol_version"=>"2", "protocol_sub_version"=>"2", "directory_server_id"=>"11171530-b6eb-013d-d770-0a58a9feac02", "acs_transaction_id"=>"111715d0-b6eb-013d-d770-0a58a9feac02", "threeds_challenge_indicator"=>"preference"}");
// Sca Params
request.setScaExemption("low_risk");
request.setRecurringCategory("subscription");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.init_recurring_sale3d(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "5169750000001111",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"business_attributes": {
"event_start_date": "17-02-2025",
"event_end_date": "26-02-2025",
"event_organizer_id": "20192375",
"event_id": "1912"
},
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"mpi_params": {
"eci": "06",
"cavv": "kNMAAAAA3S13awBkrWtTWZeBBCmy",
"protocol_version": "2",
"protocol_sub_version": "2",
"directory_server_id": "11171530-b6eb-013d-d770-0a58a9feac02",
"acs_transaction_id": "111715d0-b6eb-013d-d770-0a58a9feac02",
"threeds_challenge_indicator": "preference"
},
"sca_params": {
"exemption": "low_risk"
},
"recurring_category": "subscription"
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>init_recurring_sale3d</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>5169750000001111</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<business_attributes>
<event_start_date>17-02-2025</event_start_date>
<event_end_date>26-02-2025</event_end_date>
<event_organizer_id>20192375</event_organizer_id>
<event_id>1912</event_id>
</business_attributes>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<mpi_params>
<eci>06</eci>
<cavv>kNMAAAAA3S13awBkrWtTWZeBBCmy</cavv>
<protocol_version>2</protocol_version>
<protocol_sub_version>2</protocol_sub_version>
<directory_server_id>11171530-b6eb-013d-d770-0a58a9feac02</directory_server_id>
<acs_transaction_id>111715d0-b6eb-013d-d770-0a58a9feac02</acs_transaction_id>
<threeds_challenge_indicator>preference</threeds_challenge_indicator>
</mpi_params>
<sca_params>
<exemption>low_risk</exemption>
</sca_params>
<recurring_category>subscription</recurring_category>
</payment_transaction>'
Visa Synchronous 3 D Sv2 Acquirer Exemption Accepted (Tra Already Performed) Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Recurring\InitRecurringSale3D');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('4378510000000004')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
// MPI Synchronous 3DSv2
->setMpiEci('07')
->setMpiCavv('ApkCAlgGQCECEBJWNgZAAAAAAAA=')
->setMpiProtocolVersion('2')
->setMpiProtocolSubVersion('2')
->setMpiDirectoryServerId('111c6e20-b6eb-013d-d770-0a58a9feac02')
->setMpiAcsTransactionId('111c6ed0-b6eb-013d-d770-0a58a9feac02')
->setMpiThreedsChallengeIndicator('preference')
// Sca Params
->setScaExemption('low_risk')
->set#<Proc:0x00005586a082b7d0 includes::Transactions::3ds::V2::Examples::Requests.md.erb:179 (lambda)>('');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.recurring.InitRecurringSale3D;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
InitRecurringSale3D request = new InitRecurringSale3D();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4378510000000004");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
// Mpi Synchronous V2
request.setMpiParams("{"eci"=>"07", "cavv"=>"ApkCAlgGQCECEBJWNgZAAAAAAAA=", "protocol_version"=>"2", "protocol_sub_version"=>"2", "directory_server_id"=>"111c6e20-b6eb-013d-d770-0a58a9feac02", "acs_transaction_id"=>"111c6ed0-b6eb-013d-d770-0a58a9feac02", "threeds_challenge_indicator"=>"preference"}");
// Sca Params
request.setScaExemption("low_risk");
request.setRecurringCategory("subscription");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.init_recurring_sale3d(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "4378510000000004",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"business_attributes": {
"event_start_date": "17-02-2025",
"event_end_date": "26-02-2025",
"event_organizer_id": "20192375",
"event_id": "1912"
},
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"mpi_params": {
"eci": "07",
"cavv": "ApkCAlgGQCECEBJWNgZAAAAAAAA=",
"protocol_version": "2",
"protocol_sub_version": "2",
"directory_server_id": "111c6e20-b6eb-013d-d770-0a58a9feac02",
"acs_transaction_id": "111c6ed0-b6eb-013d-d770-0a58a9feac02",
"threeds_challenge_indicator": "preference"
},
"sca_params": {
"exemption": "low_risk"
},
"recurring_category": "subscription"
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>init_recurring_sale3d</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4378510000000004</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<business_attributes>
<event_start_date>17-02-2025</event_start_date>
<event_end_date>26-02-2025</event_end_date>
<event_organizer_id>20192375</event_organizer_id>
<event_id>1912</event_id>
</business_attributes>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<mpi_params>
<eci>07</eci>
<cavv>ApkCAlgGQCECEBJWNgZAAAAAAAA=</cavv>
<protocol_version>2</protocol_version>
<protocol_sub_version>2</protocol_sub_version>
<directory_server_id>111c6e20-b6eb-013d-d770-0a58a9feac02</directory_server_id>
<acs_transaction_id>111c6ed0-b6eb-013d-d770-0a58a9feac02</acs_transaction_id>
<threeds_challenge_indicator>preference</threeds_challenge_indicator>
</mpi_params>
<sca_params>
<exemption>low_risk</exemption>
</sca_params>
<recurring_category>subscription</recurring_category>
</payment_transaction>'
Asynchronous 3 D Sv2 Frictionless No 3ds Method Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Recurring\InitRecurringSale3D');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('4012000000060085')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
->setNotificationUrl('https://www.example.com/notification')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
// Threeds V2 Params
->setThreedsThreedsMethod('{"callback_url"=>"https://www.example.com/threeds/threeds_method/callback"}')
->setThreedsControl('{"device_type"=>"browser", "challenge_window_size"=>"full_screen", "challenge_indicator"=>"preference"}')
->setThreedsPurchase('{"category"=>"service"}')
->setThreedsRecurring('{"expiration_date"=>"17-07-2025", "frequency"=>30}')
->setThreedsMerchantRisk('{"shipping_indicator"=>"verified_address", "delivery_timeframe"=>"electronic", "reorder_items_indicator"=>"reordered", "pre_order_purchase_indicator"=>"merchandise_available", "pre_order_date"=>"17-02-2025", "gift_card"=>"true", "gift_card_count"=>"2"}')
->setThreedsCardHolderAccount('{"creation_date"=>"17-01-2024", "update_indicator"=>"more_than_60days", "last_change_date"=>"17-10-2024", "password_change_indicator"=>"no_change", "password_change_date"=>"02-01-2025", "shipping_address_usage_indicator"=>"current_transaction", "shipping_address_date_first_used"=>"12-01-2025", "transactions_activity_last_24_hours"=>"2", "transactions_activity_previous_year"=>"10", "provision_attempts_last_24_hours"=>"1", "purchases_count_last_6_months"=>"5", "suspicious_activity_indicator"=>"no_suspicious_observed", "registration_indicator"=>"30_to_60_days", "registration_date"=>"17-01-2023"}')
->setThreedsBrowser('{"accept_header"=>"*/*", "java_enabled"=>"false", "language"=>"en-GB", "color_depth"=>"24", "screen_height"=>"900", "screen_width"=>"1440", "time_zone_offset"=>"-120", "user_agent"=>"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"}')
->setThreedsSdk('{"interface"=>"native", "ui_types"=>{"ui_type"=>"multi_select"}, "application_id"=>"fc1650c0-5778-0138-8205-2cbc32a32d65", "encrypted_data"=>"encrypted-data-here", "ephemeral_public_key_pair"=>"public-key-pair", "max_timeout"=>"10", "reference_number"=>"sdk-reference-number-here"}')
// Sca Params
->setScaExemption('low_risk')
->set#<Proc:0x00005586a1790540 includes::Transactions::3ds::V2::Examples::Requests.md.erb:219 (lambda)>('');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.recurring.InitRecurringSale3D;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
InitRecurringSale3D request = new InitRecurringSale3D();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4012000000060085");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
request.setNotificationUrl(new URL("https://www.example.com/notification"));
request.setReturnSuccessUrl(new URL("http://www.example.com/success"));
request.setReturnFailureUrl(new URL("http://www.example.com/failure"));
// Threeds V2 Params
request.setThreedsThreedsMethod("{"callback_url"=>"https://www.example.com/threeds/threeds_method/callback"}");
request.setThreedsControl("{"device_type"=>"browser", "challenge_window_size"=>"full_screen", "challenge_indicator"=>"preference"}");
request.setThreedsPurchase("{"category"=>"service"}");
request.setThreedsRecurring("{"expiration_date"=>"17-07-2025", "frequency"=>30}");
request.setThreedsMerchantRisk("{"shipping_indicator"=>"verified_address", "delivery_timeframe"=>"electronic", "reorder_items_indicator"=>"reordered", "pre_order_purchase_indicator"=>"merchandise_available", "pre_order_date"=>"17-02-2025", "gift_card"=>"true", "gift_card_count"=>"2"}");
request.setThreedsCardHolderAccount("{"creation_date"=>"17-01-2024", "update_indicator"=>"more_than_60days", "last_change_date"=>"17-10-2024", "password_change_indicator"=>"no_change", "password_change_date"=>"02-01-2025", "shipping_address_usage_indicator"=>"current_transaction", "shipping_address_date_first_used"=>"12-01-2025", "transactions_activity_last_24_hours"=>"2", "transactions_activity_previous_year"=>"10", "provision_attempts_last_24_hours"=>"1", "purchases_count_last_6_months"=>"5", "suspicious_activity_indicator"=>"no_suspicious_observed", "registration_indicator"=>"30_to_60_days", "registration_date"=>"17-01-2023"}");
request.setThreedsBrowser("{"accept_header"=>"*/*", "java_enabled"=>"false", "language"=>"en-GB", "color_depth"=>"24", "screen_height"=>"900", "screen_width"=>"1440", "time_zone_offset"=>"-120", "user_agent"=>"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"}");
request.setThreedsSdk("{"interface"=>"native", "ui_types"=>{"ui_type"=>"multi_select"}, "application_id"=>"fc1650c0-5778-0138-8205-2cbc32a32d65", "encrypted_data"=>"encrypted-data-here", "ephemeral_public_key_pair"=>"public-key-pair", "max_timeout"=>"10", "reference_number"=>"sdk-reference-number-here"}");
// Sca Params
request.setScaExemption("low_risk");
request.setRecurringCategory("subscription");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.init_recurring_sale3d(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "4012000000060085",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"notification_url": "https://www.example.com/notification",
"return_success_url": "http://www.example.com/success",
"return_failure_url": "http://www.example.com/failure",
"threeds_v2_params": {
"threeds_method": {
"callback_url": "https://www.example.com/threeds/threeds_method/callback"
},
"control": {
"device_type": "browser",
"challenge_window_size": "full_screen",
"challenge_indicator": "preference"
},
"purchase": {
"category": "service"
},
"recurring": {
"expiration_date": "17-07-2025",
"frequency": 30
},
"merchant_risk": {
"shipping_indicator": "verified_address",
"delivery_timeframe": "electronic",
"reorder_items_indicator": "reordered",
"pre_order_purchase_indicator": "merchandise_available",
"pre_order_date": "17-02-2025",
"gift_card": "true",
"gift_card_count": "2"
},
"card_holder_account": {
"creation_date": "17-01-2024",
"update_indicator": "more_than_60days",
"last_change_date": "17-10-2024",
"password_change_indicator": "no_change",
"password_change_date": "02-01-2025",
"shipping_address_usage_indicator": "current_transaction",
"shipping_address_date_first_used": "12-01-2025",
"transactions_activity_last_24_hours": "2",
"transactions_activity_previous_year": "10",
"provision_attempts_last_24_hours": "1",
"purchases_count_last_6_months": "5",
"suspicious_activity_indicator": "no_suspicious_observed",
"registration_indicator": "30_to_60_days",
"registration_date": "17-01-2023"
},
"browser": {
"accept_header": "*/*",
"java_enabled": "false",
"language": "en-GB",
"color_depth": "24",
"screen_height": "900",
"screen_width": "1440",
"time_zone_offset": "-120",
"user_agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"
},
"sdk": {
"interface": "native",
"ui_types": {
"ui_type": "multi_select"
},
"application_id": "fc1650c0-5778-0138-8205-2cbc32a32d65",
"encrypted_data": "encrypted-data-here",
"ephemeral_public_key_pair": "public-key-pair",
"max_timeout": "10",
"reference_number": "sdk-reference-number-here"
}
},
"sca_params": {
"exemption": "low_risk"
},
"recurring_category": "subscription"
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>init_recurring_sale3d</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4012000000060085</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<notification_url>https://www.example.com/notification</notification_url>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<threeds_v2_params>
<threeds_method>
<callback_url>https://www.example.com/threeds/threeds_method/callback</callback_url>
</threeds_method>
<control>
<device_type>browser</device_type>
<challenge_window_size>full_screen</challenge_window_size>
<challenge_indicator>preference</challenge_indicator>
</control>
<purchase>
<category>service</category>
</purchase>
<recurring>
<expiration_date>17-07-2025</expiration_date>
<frequency>30</frequency>
</recurring>
<merchant_risk>
<shipping_indicator>verified_address</shipping_indicator>
<delivery_timeframe>electronic</delivery_timeframe>
<reorder_items_indicator>reordered</reorder_items_indicator>
<pre_order_purchase_indicator>merchandise_available</pre_order_purchase_indicator>
<pre_order_date>17-02-2025</pre_order_date>
<gift_card>true</gift_card>
<gift_card_count>2</gift_card_count>
</merchant_risk>
<card_holder_account>
<creation_date>17-01-2024</creation_date>
<update_indicator>more_than_60days</update_indicator>
<last_change_date>17-10-2024</last_change_date>
<password_change_indicator>no_change</password_change_indicator>
<password_change_date>02-01-2025</password_change_date>
<shipping_address_usage_indicator>current_transaction</shipping_address_usage_indicator>
<shipping_address_date_first_used>12-01-2025</shipping_address_date_first_used>
<transactions_activity_last_24_hours>2</transactions_activity_last_24_hours>
<transactions_activity_previous_year>10</transactions_activity_previous_year>
<provision_attempts_last_24_hours>1</provision_attempts_last_24_hours>
<purchases_count_last_6_months>5</purchases_count_last_6_months>
<suspicious_activity_indicator>no_suspicious_observed</suspicious_activity_indicator>
<registration_indicator>30_to_60_days</registration_indicator>
<registration_date>17-01-2023</registration_date>
</card_holder_account>
<browser>
<accept_header>*/*</accept_header>
<java_enabled>false</java_enabled>
<language>en-GB</language>
<color_depth>24</color_depth>
<screen_height>900</screen_height>
<screen_width>1440</screen_width>
<time_zone_offset>-120</time_zone_offset>
<user_agent>Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36</user_agent>
</browser>
<sdk>
<interface>native</interface>
<ui_types>
<ui_type>multi_select</ui_type>
</ui_types>
<application_id>fc1650c0-5778-0138-8205-2cbc32a32d65</application_id>
<encrypted_data>encrypted-data-here</encrypted_data>
<ephemeral_public_key_pair>public-key-pair</ephemeral_public_key_pair>
<max_timeout>10</max_timeout>
<reference_number>sdk-reference-number-here</reference_number>
</sdk>
</threeds_v2_params>
<sca_params>
<exemption>low_risk</exemption>
</sca_params>
<recurring_category>subscription</recurring_category>
</payment_transaction>'
Asynchronous 3 D Sv2 Frictionless With 3ds Method Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Recurring\InitRecurringSale3D');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('4066330000000004')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
->setNotificationUrl('https://www.example.com/notification')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
// Threeds V2 Params
->setThreedsThreedsMethod('{"callback_url"=>"https://www.example.com/threeds/threeds_method/callback"}')
->setThreedsControl('{"device_type"=>"browser", "challenge_window_size"=>"full_screen", "challenge_indicator"=>"preference"}')
->setThreedsPurchase('{"category"=>"service"}')
->setThreedsRecurring('{"expiration_date"=>"17-07-2025", "frequency"=>30}')
->setThreedsMerchantRisk('{"shipping_indicator"=>"verified_address", "delivery_timeframe"=>"electronic", "reorder_items_indicator"=>"reordered", "pre_order_purchase_indicator"=>"merchandise_available", "pre_order_date"=>"17-02-2025", "gift_card"=>"true", "gift_card_count"=>"2"}')
->setThreedsCardHolderAccount('{"creation_date"=>"17-01-2024", "update_indicator"=>"more_than_60days", "last_change_date"=>"17-10-2024", "password_change_indicator"=>"no_change", "password_change_date"=>"02-01-2025", "shipping_address_usage_indicator"=>"current_transaction", "shipping_address_date_first_used"=>"12-01-2025", "transactions_activity_last_24_hours"=>"2", "transactions_activity_previous_year"=>"10", "provision_attempts_last_24_hours"=>"1", "purchases_count_last_6_months"=>"5", "suspicious_activity_indicator"=>"no_suspicious_observed", "registration_indicator"=>"30_to_60_days", "registration_date"=>"17-01-2023"}')
->setThreedsBrowser('{"accept_header"=>"*/*", "java_enabled"=>"false", "language"=>"en-GB", "color_depth"=>"24", "screen_height"=>"900", "screen_width"=>"1440", "time_zone_offset"=>"-120", "user_agent"=>"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"}')
->setThreedsSdk('{"interface"=>"native", "ui_types"=>{"ui_type"=>"multi_select"}, "application_id"=>"fc1650c0-5778-0138-8205-2cbc32a32d65", "encrypted_data"=>"encrypted-data-here", "ephemeral_public_key_pair"=>"public-key-pair", "max_timeout"=>"10", "reference_number"=>"sdk-reference-number-here"}')
// Sca Params
->setScaExemption('low_risk')
->set#<Proc:0x00005586a1a913c0 includes::Transactions::3ds::V2::Examples::Requests.md.erb:219 (lambda)>('');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.recurring.InitRecurringSale3D;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
InitRecurringSale3D request = new InitRecurringSale3D();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4066330000000004");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
request.setNotificationUrl(new URL("https://www.example.com/notification"));
request.setReturnSuccessUrl(new URL("http://www.example.com/success"));
request.setReturnFailureUrl(new URL("http://www.example.com/failure"));
// Threeds V2 Params
request.setThreedsThreedsMethod("{"callback_url"=>"https://www.example.com/threeds/threeds_method/callback"}");
request.setThreedsControl("{"device_type"=>"browser", "challenge_window_size"=>"full_screen", "challenge_indicator"=>"preference"}");
request.setThreedsPurchase("{"category"=>"service"}");
request.setThreedsRecurring("{"expiration_date"=>"17-07-2025", "frequency"=>30}");
request.setThreedsMerchantRisk("{"shipping_indicator"=>"verified_address", "delivery_timeframe"=>"electronic", "reorder_items_indicator"=>"reordered", "pre_order_purchase_indicator"=>"merchandise_available", "pre_order_date"=>"17-02-2025", "gift_card"=>"true", "gift_card_count"=>"2"}");
request.setThreedsCardHolderAccount("{"creation_date"=>"17-01-2024", "update_indicator"=>"more_than_60days", "last_change_date"=>"17-10-2024", "password_change_indicator"=>"no_change", "password_change_date"=>"02-01-2025", "shipping_address_usage_indicator"=>"current_transaction", "shipping_address_date_first_used"=>"12-01-2025", "transactions_activity_last_24_hours"=>"2", "transactions_activity_previous_year"=>"10", "provision_attempts_last_24_hours"=>"1", "purchases_count_last_6_months"=>"5", "suspicious_activity_indicator"=>"no_suspicious_observed", "registration_indicator"=>"30_to_60_days", "registration_date"=>"17-01-2023"}");
request.setThreedsBrowser("{"accept_header"=>"*/*", "java_enabled"=>"false", "language"=>"en-GB", "color_depth"=>"24", "screen_height"=>"900", "screen_width"=>"1440", "time_zone_offset"=>"-120", "user_agent"=>"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"}");
request.setThreedsSdk("{"interface"=>"native", "ui_types"=>{"ui_type"=>"multi_select"}, "application_id"=>"fc1650c0-5778-0138-8205-2cbc32a32d65", "encrypted_data"=>"encrypted-data-here", "ephemeral_public_key_pair"=>"public-key-pair", "max_timeout"=>"10", "reference_number"=>"sdk-reference-number-here"}");
// Sca Params
request.setScaExemption("low_risk");
request.setRecurringCategory("subscription");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.init_recurring_sale3d(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "4066330000000004",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"notification_url": "https://www.example.com/notification",
"return_success_url": "http://www.example.com/success",
"return_failure_url": "http://www.example.com/failure",
"threeds_v2_params": {
"threeds_method": {
"callback_url": "https://www.example.com/threeds/threeds_method/callback"
},
"control": {
"device_type": "browser",
"challenge_window_size": "full_screen",
"challenge_indicator": "preference"
},
"purchase": {
"category": "service"
},
"recurring": {
"expiration_date": "17-07-2025",
"frequency": 30
},
"merchant_risk": {
"shipping_indicator": "verified_address",
"delivery_timeframe": "electronic",
"reorder_items_indicator": "reordered",
"pre_order_purchase_indicator": "merchandise_available",
"pre_order_date": "17-02-2025",
"gift_card": "true",
"gift_card_count": "2"
},
"card_holder_account": {
"creation_date": "17-01-2024",
"update_indicator": "more_than_60days",
"last_change_date": "17-10-2024",
"password_change_indicator": "no_change",
"password_change_date": "02-01-2025",
"shipping_address_usage_indicator": "current_transaction",
"shipping_address_date_first_used": "12-01-2025",
"transactions_activity_last_24_hours": "2",
"transactions_activity_previous_year": "10",
"provision_attempts_last_24_hours": "1",
"purchases_count_last_6_months": "5",
"suspicious_activity_indicator": "no_suspicious_observed",
"registration_indicator": "30_to_60_days",
"registration_date": "17-01-2023"
},
"browser": {
"accept_header": "*/*",
"java_enabled": "false",
"language": "en-GB",
"color_depth": "24",
"screen_height": "900",
"screen_width": "1440",
"time_zone_offset": "-120",
"user_agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"
},
"sdk": {
"interface": "native",
"ui_types": {
"ui_type": "multi_select"
},
"application_id": "fc1650c0-5778-0138-8205-2cbc32a32d65",
"encrypted_data": "encrypted-data-here",
"ephemeral_public_key_pair": "public-key-pair",
"max_timeout": "10",
"reference_number": "sdk-reference-number-here"
}
},
"sca_params": {
"exemption": "low_risk"
},
"recurring_category": "subscription"
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>init_recurring_sale3d</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4066330000000004</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<notification_url>https://www.example.com/notification</notification_url>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<threeds_v2_params>
<threeds_method>
<callback_url>https://www.example.com/threeds/threeds_method/callback</callback_url>
</threeds_method>
<control>
<device_type>browser</device_type>
<challenge_window_size>full_screen</challenge_window_size>
<challenge_indicator>preference</challenge_indicator>
</control>
<purchase>
<category>service</category>
</purchase>
<recurring>
<expiration_date>17-07-2025</expiration_date>
<frequency>30</frequency>
</recurring>
<merchant_risk>
<shipping_indicator>verified_address</shipping_indicator>
<delivery_timeframe>electronic</delivery_timeframe>
<reorder_items_indicator>reordered</reorder_items_indicator>
<pre_order_purchase_indicator>merchandise_available</pre_order_purchase_indicator>
<pre_order_date>17-02-2025</pre_order_date>
<gift_card>true</gift_card>
<gift_card_count>2</gift_card_count>
</merchant_risk>
<card_holder_account>
<creation_date>17-01-2024</creation_date>
<update_indicator>more_than_60days</update_indicator>
<last_change_date>17-10-2024</last_change_date>
<password_change_indicator>no_change</password_change_indicator>
<password_change_date>02-01-2025</password_change_date>
<shipping_address_usage_indicator>current_transaction</shipping_address_usage_indicator>
<shipping_address_date_first_used>12-01-2025</shipping_address_date_first_used>
<transactions_activity_last_24_hours>2</transactions_activity_last_24_hours>
<transactions_activity_previous_year>10</transactions_activity_previous_year>
<provision_attempts_last_24_hours>1</provision_attempts_last_24_hours>
<purchases_count_last_6_months>5</purchases_count_last_6_months>
<suspicious_activity_indicator>no_suspicious_observed</suspicious_activity_indicator>
<registration_indicator>30_to_60_days</registration_indicator>
<registration_date>17-01-2023</registration_date>
</card_holder_account>
<browser>
<accept_header>*/*</accept_header>
<java_enabled>false</java_enabled>
<language>en-GB</language>
<color_depth>24</color_depth>
<screen_height>900</screen_height>
<screen_width>1440</screen_width>
<time_zone_offset>-120</time_zone_offset>
<user_agent>Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36</user_agent>
</browser>
<sdk>
<interface>native</interface>
<ui_types>
<ui_type>multi_select</ui_type>
</ui_types>
<application_id>fc1650c0-5778-0138-8205-2cbc32a32d65</application_id>
<encrypted_data>encrypted-data-here</encrypted_data>
<ephemeral_public_key_pair>public-key-pair</ephemeral_public_key_pair>
<max_timeout>10</max_timeout>
<reference_number>sdk-reference-number-here</reference_number>
</sdk>
</threeds_v2_params>
<sca_params>
<exemption>low_risk</exemption>
</sca_params>
<recurring_category>subscription</recurring_category>
</payment_transaction>'
Asynchronous 3 D Sv2 Challenge No 3ds Method Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Recurring\InitRecurringSale3D');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('4918190000000002')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
->setNotificationUrl('https://www.example.com/notification')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
// Threeds V2 Params
->setThreedsThreedsMethod('{"callback_url"=>"https://www.example.com/threeds/threeds_method/callback"}')
->setThreedsControl('{"device_type"=>"browser", "challenge_window_size"=>"full_screen", "challenge_indicator"=>"preference"}')
->setThreedsPurchase('{"category"=>"service"}')
->setThreedsRecurring('{"expiration_date"=>"17-07-2025", "frequency"=>30}')
->setThreedsMerchantRisk('{"shipping_indicator"=>"verified_address", "delivery_timeframe"=>"electronic", "reorder_items_indicator"=>"reordered", "pre_order_purchase_indicator"=>"merchandise_available", "pre_order_date"=>"17-02-2025", "gift_card"=>"true", "gift_card_count"=>"2"}')
->setThreedsCardHolderAccount('{"creation_date"=>"17-01-2024", "update_indicator"=>"more_than_60days", "last_change_date"=>"17-10-2024", "password_change_indicator"=>"no_change", "password_change_date"=>"02-01-2025", "shipping_address_usage_indicator"=>"current_transaction", "shipping_address_date_first_used"=>"12-01-2025", "transactions_activity_last_24_hours"=>"2", "transactions_activity_previous_year"=>"10", "provision_attempts_last_24_hours"=>"1", "purchases_count_last_6_months"=>"5", "suspicious_activity_indicator"=>"no_suspicious_observed", "registration_indicator"=>"30_to_60_days", "registration_date"=>"17-01-2023"}')
->setThreedsBrowser('{"accept_header"=>"*/*", "java_enabled"=>"false", "language"=>"en-GB", "color_depth"=>"24", "screen_height"=>"900", "screen_width"=>"1440", "time_zone_offset"=>"-120", "user_agent"=>"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"}')
->setThreedsSdk('{"interface"=>"native", "ui_types"=>{"ui_type"=>"multi_select"}, "application_id"=>"fc1650c0-5778-0138-8205-2cbc32a32d65", "encrypted_data"=>"encrypted-data-here", "ephemeral_public_key_pair"=>"public-key-pair", "max_timeout"=>"10", "reference_number"=>"sdk-reference-number-here"}')
// Sca Params
->setScaExemption('low_risk')
->set#<Proc:0x00005586a1dab830 includes::Transactions::3ds::V2::Examples::Requests.md.erb:219 (lambda)>('');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.recurring.InitRecurringSale3D;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
InitRecurringSale3D request = new InitRecurringSale3D();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4918190000000002");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
request.setNotificationUrl(new URL("https://www.example.com/notification"));
request.setReturnSuccessUrl(new URL("http://www.example.com/success"));
request.setReturnFailureUrl(new URL("http://www.example.com/failure"));
// Threeds V2 Params
request.setThreedsThreedsMethod("{"callback_url"=>"https://www.example.com/threeds/threeds_method/callback"}");
request.setThreedsControl("{"device_type"=>"browser", "challenge_window_size"=>"full_screen", "challenge_indicator"=>"preference"}");
request.setThreedsPurchase("{"category"=>"service"}");
request.setThreedsRecurring("{"expiration_date"=>"17-07-2025", "frequency"=>30}");
request.setThreedsMerchantRisk("{"shipping_indicator"=>"verified_address", "delivery_timeframe"=>"electronic", "reorder_items_indicator"=>"reordered", "pre_order_purchase_indicator"=>"merchandise_available", "pre_order_date"=>"17-02-2025", "gift_card"=>"true", "gift_card_count"=>"2"}");
request.setThreedsCardHolderAccount("{"creation_date"=>"17-01-2024", "update_indicator"=>"more_than_60days", "last_change_date"=>"17-10-2024", "password_change_indicator"=>"no_change", "password_change_date"=>"02-01-2025", "shipping_address_usage_indicator"=>"current_transaction", "shipping_address_date_first_used"=>"12-01-2025", "transactions_activity_last_24_hours"=>"2", "transactions_activity_previous_year"=>"10", "provision_attempts_last_24_hours"=>"1", "purchases_count_last_6_months"=>"5", "suspicious_activity_indicator"=>"no_suspicious_observed", "registration_indicator"=>"30_to_60_days", "registration_date"=>"17-01-2023"}");
request.setThreedsBrowser("{"accept_header"=>"*/*", "java_enabled"=>"false", "language"=>"en-GB", "color_depth"=>"24", "screen_height"=>"900", "screen_width"=>"1440", "time_zone_offset"=>"-120", "user_agent"=>"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"}");
request.setThreedsSdk("{"interface"=>"native", "ui_types"=>{"ui_type"=>"multi_select"}, "application_id"=>"fc1650c0-5778-0138-8205-2cbc32a32d65", "encrypted_data"=>"encrypted-data-here", "ephemeral_public_key_pair"=>"public-key-pair", "max_timeout"=>"10", "reference_number"=>"sdk-reference-number-here"}");
// Sca Params
request.setScaExemption("low_risk");
request.setRecurringCategory("subscription");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.init_recurring_sale3d(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "4918190000000002",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"notification_url": "https://www.example.com/notification",
"return_success_url": "http://www.example.com/success",
"return_failure_url": "http://www.example.com/failure",
"threeds_v2_params": {
"threeds_method": {
"callback_url": "https://www.example.com/threeds/threeds_method/callback"
},
"control": {
"device_type": "browser",
"challenge_window_size": "full_screen",
"challenge_indicator": "preference"
},
"purchase": {
"category": "service"
},
"recurring": {
"expiration_date": "17-07-2025",
"frequency": 30
},
"merchant_risk": {
"shipping_indicator": "verified_address",
"delivery_timeframe": "electronic",
"reorder_items_indicator": "reordered",
"pre_order_purchase_indicator": "merchandise_available",
"pre_order_date": "17-02-2025",
"gift_card": "true",
"gift_card_count": "2"
},
"card_holder_account": {
"creation_date": "17-01-2024",
"update_indicator": "more_than_60days",
"last_change_date": "17-10-2024",
"password_change_indicator": "no_change",
"password_change_date": "02-01-2025",
"shipping_address_usage_indicator": "current_transaction",
"shipping_address_date_first_used": "12-01-2025",
"transactions_activity_last_24_hours": "2",
"transactions_activity_previous_year": "10",
"provision_attempts_last_24_hours": "1",
"purchases_count_last_6_months": "5",
"suspicious_activity_indicator": "no_suspicious_observed",
"registration_indicator": "30_to_60_days",
"registration_date": "17-01-2023"
},
"browser": {
"accept_header": "*/*",
"java_enabled": "false",
"language": "en-GB",
"color_depth": "24",
"screen_height": "900",
"screen_width": "1440",
"time_zone_offset": "-120",
"user_agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"
},
"sdk": {
"interface": "native",
"ui_types": {
"ui_type": "multi_select"
},
"application_id": "fc1650c0-5778-0138-8205-2cbc32a32d65",
"encrypted_data": "encrypted-data-here",
"ephemeral_public_key_pair": "public-key-pair",
"max_timeout": "10",
"reference_number": "sdk-reference-number-here"
}
},
"sca_params": {
"exemption": "low_risk"
},
"recurring_category": "subscription"
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>init_recurring_sale3d</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4918190000000002</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<notification_url>https://www.example.com/notification</notification_url>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<threeds_v2_params>
<threeds_method>
<callback_url>https://www.example.com/threeds/threeds_method/callback</callback_url>
</threeds_method>
<control>
<device_type>browser</device_type>
<challenge_window_size>full_screen</challenge_window_size>
<challenge_indicator>preference</challenge_indicator>
</control>
<purchase>
<category>service</category>
</purchase>
<recurring>
<expiration_date>17-07-2025</expiration_date>
<frequency>30</frequency>
</recurring>
<merchant_risk>
<shipping_indicator>verified_address</shipping_indicator>
<delivery_timeframe>electronic</delivery_timeframe>
<reorder_items_indicator>reordered</reorder_items_indicator>
<pre_order_purchase_indicator>merchandise_available</pre_order_purchase_indicator>
<pre_order_date>17-02-2025</pre_order_date>
<gift_card>true</gift_card>
<gift_card_count>2</gift_card_count>
</merchant_risk>
<card_holder_account>
<creation_date>17-01-2024</creation_date>
<update_indicator>more_than_60days</update_indicator>
<last_change_date>17-10-2024</last_change_date>
<password_change_indicator>no_change</password_change_indicator>
<password_change_date>02-01-2025</password_change_date>
<shipping_address_usage_indicator>current_transaction</shipping_address_usage_indicator>
<shipping_address_date_first_used>12-01-2025</shipping_address_date_first_used>
<transactions_activity_last_24_hours>2</transactions_activity_last_24_hours>
<transactions_activity_previous_year>10</transactions_activity_previous_year>
<provision_attempts_last_24_hours>1</provision_attempts_last_24_hours>
<purchases_count_last_6_months>5</purchases_count_last_6_months>
<suspicious_activity_indicator>no_suspicious_observed</suspicious_activity_indicator>
<registration_indicator>30_to_60_days</registration_indicator>
<registration_date>17-01-2023</registration_date>
</card_holder_account>
<browser>
<accept_header>*/*</accept_header>
<java_enabled>false</java_enabled>
<language>en-GB</language>
<color_depth>24</color_depth>
<screen_height>900</screen_height>
<screen_width>1440</screen_width>
<time_zone_offset>-120</time_zone_offset>
<user_agent>Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36</user_agent>
</browser>
<sdk>
<interface>native</interface>
<ui_types>
<ui_type>multi_select</ui_type>
</ui_types>
<application_id>fc1650c0-5778-0138-8205-2cbc32a32d65</application_id>
<encrypted_data>encrypted-data-here</encrypted_data>
<ephemeral_public_key_pair>public-key-pair</ephemeral_public_key_pair>
<max_timeout>10</max_timeout>
<reference_number>sdk-reference-number-here</reference_number>
</sdk>
</threeds_v2_params>
<sca_params>
<exemption>low_risk</exemption>
</sca_params>
<recurring_category>subscription</recurring_category>
</payment_transaction>'
Asynchronous 3 D Sv2 Challenge With 3ds Method Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Recurring\InitRecurringSale3D');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('4938730000000001')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
->setNotificationUrl('https://www.example.com/notification')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
// Threeds V2 Params
->setThreedsThreedsMethod('{"callback_url"=>"https://www.example.com/threeds/threeds_method/callback"}')
->setThreedsControl('{"device_type"=>"browser", "challenge_window_size"=>"full_screen", "challenge_indicator"=>"preference"}')
->setThreedsPurchase('{"category"=>"service"}')
->setThreedsRecurring('{"expiration_date"=>"17-07-2025", "frequency"=>30}')
->setThreedsMerchantRisk('{"shipping_indicator"=>"verified_address", "delivery_timeframe"=>"electronic", "reorder_items_indicator"=>"reordered", "pre_order_purchase_indicator"=>"merchandise_available", "pre_order_date"=>"17-02-2025", "gift_card"=>"true", "gift_card_count"=>"2"}')
->setThreedsCardHolderAccount('{"creation_date"=>"17-01-2024", "update_indicator"=>"more_than_60days", "last_change_date"=>"17-10-2024", "password_change_indicator"=>"no_change", "password_change_date"=>"02-01-2025", "shipping_address_usage_indicator"=>"current_transaction", "shipping_address_date_first_used"=>"12-01-2025", "transactions_activity_last_24_hours"=>"2", "transactions_activity_previous_year"=>"10", "provision_attempts_last_24_hours"=>"1", "purchases_count_last_6_months"=>"5", "suspicious_activity_indicator"=>"no_suspicious_observed", "registration_indicator"=>"30_to_60_days", "registration_date"=>"17-01-2023"}')
->setThreedsBrowser('{"accept_header"=>"*/*", "java_enabled"=>"false", "language"=>"en-GB", "color_depth"=>"24", "screen_height"=>"900", "screen_width"=>"1440", "time_zone_offset"=>"-120", "user_agent"=>"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"}')
->setThreedsSdk('{"interface"=>"native", "ui_types"=>{"ui_type"=>"multi_select"}, "application_id"=>"fc1650c0-5778-0138-8205-2cbc32a32d65", "encrypted_data"=>"encrypted-data-here", "ephemeral_public_key_pair"=>"public-key-pair", "max_timeout"=>"10", "reference_number"=>"sdk-reference-number-here"}')
// Sca Params
->setScaExemption('low_risk')
->set#<Proc:0x00005586a23751d0 includes::Transactions::3ds::V2::Examples::Requests.md.erb:219 (lambda)>('');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.recurring.InitRecurringSale3D;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
InitRecurringSale3D request = new InitRecurringSale3D();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4938730000000001");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
request.setNotificationUrl(new URL("https://www.example.com/notification"));
request.setReturnSuccessUrl(new URL("http://www.example.com/success"));
request.setReturnFailureUrl(new URL("http://www.example.com/failure"));
// Threeds V2 Params
request.setThreedsThreedsMethod("{"callback_url"=>"https://www.example.com/threeds/threeds_method/callback"}");
request.setThreedsControl("{"device_type"=>"browser", "challenge_window_size"=>"full_screen", "challenge_indicator"=>"preference"}");
request.setThreedsPurchase("{"category"=>"service"}");
request.setThreedsRecurring("{"expiration_date"=>"17-07-2025", "frequency"=>30}");
request.setThreedsMerchantRisk("{"shipping_indicator"=>"verified_address", "delivery_timeframe"=>"electronic", "reorder_items_indicator"=>"reordered", "pre_order_purchase_indicator"=>"merchandise_available", "pre_order_date"=>"17-02-2025", "gift_card"=>"true", "gift_card_count"=>"2"}");
request.setThreedsCardHolderAccount("{"creation_date"=>"17-01-2024", "update_indicator"=>"more_than_60days", "last_change_date"=>"17-10-2024", "password_change_indicator"=>"no_change", "password_change_date"=>"02-01-2025", "shipping_address_usage_indicator"=>"current_transaction", "shipping_address_date_first_used"=>"12-01-2025", "transactions_activity_last_24_hours"=>"2", "transactions_activity_previous_year"=>"10", "provision_attempts_last_24_hours"=>"1", "purchases_count_last_6_months"=>"5", "suspicious_activity_indicator"=>"no_suspicious_observed", "registration_indicator"=>"30_to_60_days", "registration_date"=>"17-01-2023"}");
request.setThreedsBrowser("{"accept_header"=>"*/*", "java_enabled"=>"false", "language"=>"en-GB", "color_depth"=>"24", "screen_height"=>"900", "screen_width"=>"1440", "time_zone_offset"=>"-120", "user_agent"=>"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"}");
request.setThreedsSdk("{"interface"=>"native", "ui_types"=>{"ui_type"=>"multi_select"}, "application_id"=>"fc1650c0-5778-0138-8205-2cbc32a32d65", "encrypted_data"=>"encrypted-data-here", "ephemeral_public_key_pair"=>"public-key-pair", "max_timeout"=>"10", "reference_number"=>"sdk-reference-number-here"}");
// Sca Params
request.setScaExemption("low_risk");
request.setRecurringCategory("subscription");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.init_recurring_sale3d(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "4938730000000001",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"notification_url": "https://www.example.com/notification",
"return_success_url": "http://www.example.com/success",
"return_failure_url": "http://www.example.com/failure",
"threeds_v2_params": {
"threeds_method": {
"callback_url": "https://www.example.com/threeds/threeds_method/callback"
},
"control": {
"device_type": "browser",
"challenge_window_size": "full_screen",
"challenge_indicator": "preference"
},
"purchase": {
"category": "service"
},
"recurring": {
"expiration_date": "17-07-2025",
"frequency": 30
},
"merchant_risk": {
"shipping_indicator": "verified_address",
"delivery_timeframe": "electronic",
"reorder_items_indicator": "reordered",
"pre_order_purchase_indicator": "merchandise_available",
"pre_order_date": "17-02-2025",
"gift_card": "true",
"gift_card_count": "2"
},
"card_holder_account": {
"creation_date": "17-01-2024",
"update_indicator": "more_than_60days",
"last_change_date": "17-10-2024",
"password_change_indicator": "no_change",
"password_change_date": "02-01-2025",
"shipping_address_usage_indicator": "current_transaction",
"shipping_address_date_first_used": "12-01-2025",
"transactions_activity_last_24_hours": "2",
"transactions_activity_previous_year": "10",
"provision_attempts_last_24_hours": "1",
"purchases_count_last_6_months": "5",
"suspicious_activity_indicator": "no_suspicious_observed",
"registration_indicator": "30_to_60_days",
"registration_date": "17-01-2023"
},
"browser": {
"accept_header": "*/*",
"java_enabled": "false",
"language": "en-GB",
"color_depth": "24",
"screen_height": "900",
"screen_width": "1440",
"time_zone_offset": "-120",
"user_agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"
},
"sdk": {
"interface": "native",
"ui_types": {
"ui_type": "multi_select"
},
"application_id": "fc1650c0-5778-0138-8205-2cbc32a32d65",
"encrypted_data": "encrypted-data-here",
"ephemeral_public_key_pair": "public-key-pair",
"max_timeout": "10",
"reference_number": "sdk-reference-number-here"
}
},
"sca_params": {
"exemption": "low_risk"
},
"recurring_category": "subscription"
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>init_recurring_sale3d</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4938730000000001</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<notification_url>https://www.example.com/notification</notification_url>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<threeds_v2_params>
<threeds_method>
<callback_url>https://www.example.com/threeds/threeds_method/callback</callback_url>
</threeds_method>
<control>
<device_type>browser</device_type>
<challenge_window_size>full_screen</challenge_window_size>
<challenge_indicator>preference</challenge_indicator>
</control>
<purchase>
<category>service</category>
</purchase>
<recurring>
<expiration_date>17-07-2025</expiration_date>
<frequency>30</frequency>
</recurring>
<merchant_risk>
<shipping_indicator>verified_address</shipping_indicator>
<delivery_timeframe>electronic</delivery_timeframe>
<reorder_items_indicator>reordered</reorder_items_indicator>
<pre_order_purchase_indicator>merchandise_available</pre_order_purchase_indicator>
<pre_order_date>17-02-2025</pre_order_date>
<gift_card>true</gift_card>
<gift_card_count>2</gift_card_count>
</merchant_risk>
<card_holder_account>
<creation_date>17-01-2024</creation_date>
<update_indicator>more_than_60days</update_indicator>
<last_change_date>17-10-2024</last_change_date>
<password_change_indicator>no_change</password_change_indicator>
<password_change_date>02-01-2025</password_change_date>
<shipping_address_usage_indicator>current_transaction</shipping_address_usage_indicator>
<shipping_address_date_first_used>12-01-2025</shipping_address_date_first_used>
<transactions_activity_last_24_hours>2</transactions_activity_last_24_hours>
<transactions_activity_previous_year>10</transactions_activity_previous_year>
<provision_attempts_last_24_hours>1</provision_attempts_last_24_hours>
<purchases_count_last_6_months>5</purchases_count_last_6_months>
<suspicious_activity_indicator>no_suspicious_observed</suspicious_activity_indicator>
<registration_indicator>30_to_60_days</registration_indicator>
<registration_date>17-01-2023</registration_date>
</card_holder_account>
<browser>
<accept_header>*/*</accept_header>
<java_enabled>false</java_enabled>
<language>en-GB</language>
<color_depth>24</color_depth>
<screen_height>900</screen_height>
<screen_width>1440</screen_width>
<time_zone_offset>-120</time_zone_offset>
<user_agent>Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36</user_agent>
</browser>
<sdk>
<interface>native</interface>
<ui_types>
<ui_type>multi_select</ui_type>
</ui_types>
<application_id>fc1650c0-5778-0138-8205-2cbc32a32d65</application_id>
<encrypted_data>encrypted-data-here</encrypted_data>
<ephemeral_public_key_pair>public-key-pair</ephemeral_public_key_pair>
<max_timeout>10</max_timeout>
<reference_number>sdk-reference-number-here</reference_number>
</sdk>
</threeds_v2_params>
<sca_params>
<exemption>low_risk</exemption>
</sca_params>
<recurring_category>subscription</recurring_category>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: init_recurring_sale3d |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | required* | string(255) | Description of the transaction for later use. |
moto | optional | "true" | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech-support@emerchantpay.com for more details |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
notification_url | required1 | url | URL at merchant where gateway sends outcome of transaction. |
return_success_url | required1 | url | URL where customer is sent to after successful payment |
return_failure_url | required1 | url | URL where customer is sent to after unsuccessful payment |
amount | required | integer >= 0 | Transaction amount in minor currency unit, see Currency and Amount Handling for details. In certain cases, it is possible to submit a transaction with a zero-value amount in order not to charge the consumer with the initial recurring, but with the followed RecurringSale transactions only. For more information regarding the use cases and scenario, Contact tech-support@emerchantpay.com for more details. |
currency | required | string(3) | Currency code in ISO 4217 |
card_holder | required | string(45) | Full name of customer as printed on credit card (first name and last name at least). Note, for async 3DSv2 transactions, the card holder name must NOT contain more than 45 chars. Otherwise, the rest will be truncated in the authentication request. |
card_number | required | 13 to 16 digits | Complete cc number of customer |
cvv | required* | 3 to 4 digits | cvv of cc, requirement is based on terminal configuration |
expiration_month | required | MM | Expiration month as printed on credit card |
expiration_year | required | YYYY | Expiration year as printed on credit card |
token | optional | string(36) | See Tokenization for more details. If present, the cardholder parameters can be omitted. Cannot be set together with remember_card |
remember_card | optional | "true" | See Tokenize. Tokenizes cardholder parameters. Cannot be set together with token |
consumer_id | optional | string(10) | See Consumers and Tokenization. Combine with remember_card to tokenize or with token to use token |
recurring_category | optional | string | Specifies whether the recurring transaction is a subscription(fixed amount, fixed intervals)or if it is a standing order(varying amount, fixed intervals). The allowed values aresubscription and standing_order . The default value is subscription |
scheme_tokenized | required* | "true" | Required when the card_number is DPAN instead of Funding Primary Account Number, see Tokenized e-commerce for details |
credential_on_file | required* | See Credential On File (COF) for more details | |
initial_customer_initiated | required* | string(18) | Initial transaction initiated by customer. Required for external tokenization, and optional for gateway-based tokenization |
subsequent_customer_initiated | required* | string(18) | Subsequent transaction initiated by customer. Required for external tokenization, and optional for gateway-based tokenization |
merchant_unscheduled | optional | string(20) | Transaction is initiated by the merchant |
customer_email | required* | e-mail address | Must contain valid e-mail of customer |
customer_phone | required* | string(16) | Must contain а valid international phone number of the customer as per the ITU-T E.164. It's recommended to not submit a customer phone number containing more than 15 digits or less than 7 digits. Note, for async 3DS transactions that are using the 3DSv2 authentication protocol, it will be shortened up to 15 digits and a prefix + for international phone number will be added if missing. |
birth_date | required* | dd-mm-yyyy | Required when MCC is a Financial Services one (e.g. MCC 6012) and either card brand is Visa or Mastercard/Maestro with UK-based merchant, UK-based bin (domestic), and DEBIT card type |
document_id | required* | string(255) | Document ID value. |
fx_rate_id | optional | integer | See Get rates for FX Service. Offers the option to use a specific FX rate to convert the transaction processing amount. Used FX rate should have the same source currency as the processing currency. Contact tech-support@emerchantpay.com for more details |
business_attributes | required* | Check business attributes section. | |
event_start_date | required* | dd-mm-yyyy | The date when event starts in format dd-mm-yyyy |
event_end_date | required* | dd-mm-yyyy | The date when event ends in format dd-mm-yyyy |
event_organizer_id | required* | string | |
event_id | required* | string | |
date_of_order | required* | dd-mm-yyyy | The date when order was placed in format dd-mm-yyyy |
delivery_date | required* | dd-mm-yyyy | Date of the expected delivery in format dd-mm-yyyy |
name_of_the_supplier | required* | string | |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(150) | Primary address. The field length is limited to 150 chars only for async 3DS transactions that are using the 3DSv2 authentication protocol. |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string(16) | The field that holds the zip code is limited to 16 chars only for async 3DS transactions that are using the 3DSv2 authentication protocol. |
city | required* | string(50) | The field that holds the city is limited to 50 chars only for async 3DS transactions that are using the 3DSv2 authentication protocol. |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(3) | The field that holds the country state is limited to 3 chars only for async 3DS transactions that are using the 3DSv2 authentication protocol. Note: The value should be the country subdivision code defined in ISO 3166-2. Invalid values submitted NOT as per the ISO might lead to data integrity issues. |
country | required* | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(150) | Primary address. The field length is limited to 150 chars only for async 3DS transactions that are using the 3DSv2 authentication protocol. |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string(16) | The field that holds the zip code is limited to 16 chars only for async 3DS transactions that are using the 3DSv2 authentication protocol. |
city | optional | string(50) | The field that holds the city is limited to 50 chars only for async 3DS transactions that are using the 3DSv2 authentication protocol. |
neighborhood | optional | string(255) | Neighborhood |
state | optional | string(3) | The field that holds the country state is limited to 3 chars only for async 3DS transactions that are using the 3DSv2 authentication protocol. Note: The value should be the country subdivision code defined in ISO 3166-2. Invalid values submitted NOT as per the ISO might lead to data integrity issues. |
country | optional | string(2) | Country code in ISO 3166 |
mpi_params | required2 | ||
cavv | required3 | string(255) | Verification Id of the authentication. Please note this can be the CAVV for Visa Card or UCAF to identify MasterCard. |
eci | required3 | string(255) | See Electronic Commerce Indicator as returned from the MPI for details |
protocol_version | required4 | string | The used 3DS protocol version. |
protocol_sub_version | required4 | string | The used 3DS protocol sub-version. |
directory_server_id | required4 | string | The Directory Server ID used for 3DSecure transactions through the 3DSv2 authentication protocol. |
acs_transaction_id | optional | string | The ACS Transaction ID and is optional for 3DS transactions, but highly recommended for increasing the approval ratio. |
threeds_challenge_indicator | optional | string | The 3DS challenge indicator that represents the exact indicator used during the authentication request to the MPI provider for synchronous 3DS transactions. It is optional but highly recommended for increasing the approval ratio. It can only contain one of the following values no_preference, no_challenge_requested, preference and mandate. The default value is no_preference. Check 3DS Challenge Indicators for more details. |
sca_params | optional | SCA params | |
exemption | optional | string | The exemption that the transaction should take advantage of. Note that the requested exemption may not be accepted due to internal risk validations. Check SCA exemption values. |
visa_merchant_id | required5 | string(8) | VMID assigned by Visa if participating in Trusted merchant program. |
funding | optional | Funding Transaction Params | |
identifier_type | required* | string | This is only required in case of Mastercard. Type of Funding Transaction. Please check Identifier Types |
business_application_identifier | required* | string | This is only required in case of VISA. Type of VISA Funding Transaction. Please check BAI |
receiver | optional | Funding Transaction Receiver details | |
first_name | required* | string | First name of the receiver |
last_name | required* | string | Last name of the receiver |
country | required* | string(2) | Country code in ISO 3166 |
account_number | required* | string | Receiver account number. Mandatory for Mastercard. If Sender Reference Number is provided then it becomes optional for VISA |
account_number_type | required* | string | This is only required in case of Mastercard. Receiver account number type. Please check Receiver Account Types |
address | required* | string | Receiver address. Only required in case of VISA and Canadian cards |
state | required* | string | Receiver state. Only required in case of VISA and Canadian cards |
city | required* | string | Receiver city. Only required in case of VISA and Canadian cards |
sender | optional | Funding Transaction Sender details | |
name | required* | string | Sender name. Only required in case of VISA |
reference_number | required* | string | Sender Reference Number. Only required in case of VISA. This is option if Receiver Account Number is provided |
country | required* | string | Sender country. Only required in case of VISA. If not provided billing address is used |
address | required* | string | Sender address. Only required in case of VISA. If not provided billing address is used |
state | required* | string | Sender state. Only required in case of VISA and Canadian card. If not provided billing address is used |
city | required* | string | Sender city. Only required in case of VISA. If not provided billing address is used |
threeds_v2_params | required* | 3DSv2 async parameters. They must be submitted in order to use the 3DSv2 authentication protocol in asynchronous workflow | |
threeds_method | optional | 3DS-Method related parameters for any callbacks and notifications. | |
callback_url | optional | url | Specific 3DS-Method callback URL after the 3DS-Method completes. The actual status will be provided via HTTP POST to that URL. For more information, go to 3DSv2 method params |
control | required* | General params for preferences in authentication flow and providing device interface information. | |
device_type | required* | string | Identifies the device channel of the consumer, required in the 3DSv2 authentication protocol. For more information, go to 3DSv2 control params |
challenge_window_size | required* | string | Identifies the size of the challenge window for the consumer. For more information, go to 3DSv2 control params |
challenge_indicator | optional | string | The value has weight and might impact the decision whether a challenge will be required for the transaction or not. If not provided, it will be interpreted as no_preference. For more information, go to 3DSv2 control params |
purchase | optional | Purchase related params providing with additional information regarding the order. | |
category | optional | string | Identifies the type of transaction being authenticated. This field is required in some markets.Accepted values are: goods, service, check_acceptance, account_funding, quasi_cash, prepaid_activation, loan. |
merchant_risk | recommended | Merchant risk assessment params. They are all optional, but recommended. | |
shipping_indicator | optional | string(16) | Indicator code that most accurately describes the shipping method for the cardholder specific transaction. If one or more items are included in the sale, use the Shipping Indicator code for the physical goods. If all digital goods, use the code that describes the most expensive item. Accepted values are: same_as_billing, stored_address, verified_address, pick_up, digital_goods, travel, event_tickets, other. |
delivery_timeframe | optional | string(11) | Indicates the merchandise delivery timeframe. Accepted values are: electronic, same_day, over_night, another_day. |
reorder_items_indicator | optional | string(10) | Indicates whether the cardholder is reordering previously purchased merchandise. Accepted values are: first_time, reordered. |
pre_order_purchase_indicator | optional | string(21) | Indicates whether cardholder is placing an order for merchandise with a future-availability or release date. Accepted values are: merchandise_available, future_availability. |
pre_order_date | optional | dd-mm-yyyy | For a pre-ordered purchase, the expected date that the merchandise will be available. |
gift_card | optional | 'true' | Prepaid or gift card purchase. |
gift_card_count | optional | integer | For prepaid or gift card purchase, total count of individual prepaid or gift cards/codes purchased. The value is limited to 99. |
card_holder_account | recommended | Cardholder account additional information. They are all optional, but recommended, because they have a significant impact on approval rates | |
creation_date | optional | dd-mm-yyyy | Date that the cardholder opened the account with the 3DS Requester. |
update_indicator | optional | string(19) | Length of time since the cardholder’s account information with the 3DS Requestor was last changed. Includes Billing or Shipping address, new payment account, or new user(s) added. Accepted values are: current_transaction, less_than_30days, 30_to_60_days, more_than_60days. |
last_change_date | optional | dd-mm-yyyy | Date that the cardholder’s account with the 3DS Requestor was last changed. Including Billing or Shipping address, new payment accout, or new user(s) added. |
password_change_indicator | optional | string(18) | Length of time since the cardholder account with the 3DS Requestor had a password change or account reset. Accepted values are: no_change, during_transaction, less_than_30days, 30_to_60_days, more_than_60days. |
password_change_date | optional | dd-mm-yyyy | Date that cardholder’s account with the 3DS Requestor had a password change or account reset. |
shipping_address_usage_indicator | optional | string(19) | Indicates when the shipping address used for this transaction was first used with the 3DS Requestor. Accepted values are: current_transaction, less_than_30days, 30_to_60_days, more_than_60days. |
shipping_address_date_first_used | optional | dd-mm-yyyy | Date when the shipping address used for this transaction was first used with the 3DS Requestor. |
transactions_activity_last_24_hours | optional | integer | Number of transactions (successful and abandoned) for this cardholder account with the 3DS Requestor across all payment accounts in the previous 24 hours. |
transactions_activity_previous_year | optional | integer | Number of transactions (successful and abandoned) for this cardholder account with the 3DS Requestor across all payment accounts in the previous year. |
provision_attempts_last_24_hours | optional | integer | Number of Add Card attempts in the last 24 hours. |
purchases_count_last_6_months | optional | integer | Number of purchases with this cardholder account during the previous six months. |
suspicious_activity_indicator | optional | string(22) | Indicates whether the 3DS Requestor has experienced suspicious activity (including previous fraud) on the cardholder account. Accepted values are: no_suspicious_observed, suspicious_observed. |
registration_indicator | optional | string(19) | Indicates the length of time that the payment account was enrolled in the cardholder’s account with the 3DS Requester. Accepted values are: guest_checkout, current_transaction, less_than_30days, 30_to_60_days, more_than_60days. |
registration_date | optional | dd-mm-yyyy | Date that the payment account was enrolled in the cardholder’s account with the 3DS Requestor. |
browser | required* | For browser-based transactions. They are all required in case the device_type is set to browser | |
accept_header | required* | string(2048) | The exact content of the HTTP ACCEPT header as sent to the 3DS Requester from the Cardholder browser. Any other header different than the ACCEPT header will be rejected. Example: application/json,text/plain,text/html,*/* . |
java_enabled | required* | boolean | Boolean that represents the ability of the cardholder browser to execute Java. The value can be retrieved by accessing a property of the navigator with JavaScript, navigator.javaEnabled . |
language | required* | string(8) | Value representing the browser language as defined in IETF BCP47. Note that only one browser language tag is about to be submitted as per the above IETF BCP47. Numeric chars are also allowed in the subtag and will represent the region.Example: en-GB , zh-guoyu , fil-PH , gsw , es-419 , de-1996 , etc. The value can be retrieved by accessing a property of the navigator with JavaScript, navigator.language . |
color_depth | required* | integer | Value representing the bit depth of the colour palette for displaying images, in bits per pixel. Obtained from Cardholder browser using the screen.colorDepth property. The value as per EMVCo specs can be one of 1, 4, 8, 15, 16, 24, 32, 48. In case, an unsupported color_depth is determined, the nearest supported value that is less than the actual one needs to be submitted. For example, if the obtained value is 30, which is not supported as per EMVCo specs, 24 has to be submitted. |
screen_height | required* | integer | Total height of the Cardholder's screen in pixels. Value is returned from the screen.height property. |
screen_width | required* | integer | Total width of the Cardholder's screen in pixels. Value is returned from the screen.width property. |
time_zone_offset | required* | string(5) | Time difference between UTC time and the Cardholder browser local time, in minutes. Note that the offset is positive if the local time zone is behind UTC and negative if it is ahead. If UTC -5 hours then submit 300 or +300 , If UTC +2 hours then -120 . The value can be retrieved using Javascript getTimezoneOffset() method over Date object. |
user_agent | required* | string(2048) | Exact content of the HTTP user-agent header. |
sdk | required* | For application-based transactions. They are all required in case the device_type is set to application | |
interface | required* | string(6) | SDK Interface types that the device of the consumer supports for displaying specific challenge interfaces within the SDK. Accepted values are: native, html, both. |
ui_types | required* | Lists all UI types that the device of the consumer supports for displaying specific challenge interfaces within the SDK. | |
ui_type | required* | string(13) | UI type that the device of the consumer supports for displaying specific challenge interface. Accepted values are: text, single_select, multi_select, out_of_bag, other_html. |
application_id | required* | string(36) | Universally unique ID created upon all installations and updates of the 3DS Requestor APp on a Customer Device. This will be newly generated and stored by the 3DS SDK for each installation or update. The field is limited to 36 characters and it shall have a canonical format as defined in IETF RFC 4122. |
encrypted_data | required* | string(64000) | JWE Object as defined Section 6.2.2.1 containing data encrypted by the SDK for the DS to decrypt. The data will be present when sending to DS, but not present from DS to ACS. |
ephemeral_public_key_pair | required* | string(256) | Public key component of the ephemeral key pair generated by the 3DS SDK and used to establish session keys between the 3DS SDK and ACS. In AReq, this data element is contained within the ACS Signed Content JWS Object. The field is limited to maximum 256 characters. |
max_timeout | required* | integer | Indicates the maximum amount of time (in minutes) for all exchanges. The field shall have value greater or equals than 05. |
reference_number | required* | string(32) | Identifies the vendor and version of the 3DS SDK that is integrated in a 3DS Requestor App, assigned by EMVCo when the 3DS SDK is approved. The field is limited to 32 characters. |
recurring | optional | Additional recurring details. | |
expiration_date | optional | dd-mm-yyyy | A future date indicating the end date for any further subsequent transactions. For more information, go to 3DSv2 recurring params |
frequency | optional | integer | Indicates the minimum number of days between subsequent transactions. An empty value indicates the payment frequency is not set.For more information, go to 3DSv2 recurring params |
dynamic_descriptor_params | optional | ||
merchant_name | optional | string(25) | Allows to dynamically override the charge descriptor |
merchant_city | optional | string(13) | Allows to dynamically override the merchant phone number |
sub_merchant_id | optional | string(15) | Allows to dynamically override the sub-merchant ID. |
merchant_country | optional | string(3) | Allows to dynamically override the merchant country. |
merchant_state | optional | string(3) | Allows to dynamically override the merchant subdivision code. |
merchant_zip_code | optional | string(10) | Allows to dynamically override the merchant zip/postal code. Required for VISA OCT transactions with Australian and Canadian card bins. |
merchant_address | optional | string(48) | Allows to dynamically override the merchant address. |
merchant_url | optional | string(60) | Allows to dynamically override the merchant URL |
merchant_phone | optional | string(16) | Allows to dynamically override the merchant phone number. |
merchant_service_city | optional | string(13) | Allows to dynamically override the merchant service city. |
merchant_service_country | optional | string(3) | Allows to dynamically override the merchant service country. |
merchant_service_state | optional | string(3) | Allows to dynamically override the merchant service subdivision code. |
merchant_service_zip_code | optional | string(10) | Allows to dynamically override the merchant service zip/postal code. |
merchant_service_phone | optional | string(16) | Allows to dynamically override the merchant service phone number. |
merchant_geo_coordinates | optional | string(20) | Allows to dynamically override the merchant geographic coordinates. |
merchant_service_geo_coordinates | optional | string(20) | Allows to dynamically override the merchant service geographic coordinates. |
required* = conditionally required
1 - Required if mpi_params
is not present, the transaction will be handled asynchronously. Not required if configured on Terminal or Merchant level. Contact Tech Support for more details.
2 - Required if transaction should be handled synchronous.
3 - eci
is always required if mpi_params
is present.
cavv
is not required for the 3D attempted only workflow, but it is strongly recommended in a combination with the Directory Server ID in order to be in the scope of the 3DSv2 authentication protocol.
4 - protocol_version
is required due to the only one 3DSv2 authentication protocol that is currently supported.
directory_server_id
is mandatory when protocol_version is 2. May be omitted for scheme tokenized transactions.
5 - visa_merchant_id
is required when exemption value is trusted_merchant
.
Frictionless / Challenge Response
stdClass Object
(
[transaction_type] => init_recurring_sale3d
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[consumer_id] => 123456
[token] => ee946db8-d7db-4bb7-b608-b65b153e127d
[threeds_method_url] => https://staging.gate.emerchantpay.net/threeds/threeds_method
[threeds_method_continue_url] => https://staging.gate.emerchantpay.net/threeds/threeds_method/44177a21403427eb96664a6d7e5d5d48
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:50.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => false
[reason_for_not_honoring_exemption] => 8A01
[sca_exemption_result] => 13
)
<payment_response content=[
<transaction_type content=[init_recurring_sale3d]>
<status content=[pending_async]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<consumer_id content=[123456]>
<token content=[ee946db8-d7db-4bb7-b608-b65b153e127d]>
<threeds_method_url content=[https://staging.gate.emerchantpay.net/threeds/threeds_method]>
<threeds_method_continue_url content=[https://staging.gate.emerchantpay.net/threeds/threeds_method/44177a21403427eb96664a6d7e5d5d48]>
<timestamp content=[2025-01-16T10:23:50Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[false]>
<reason_for_not_honoring_exemption content=[8A01]>
<sca_exemption_result content=[13]>
]>
{
transaction_type: "init_recurring_sale3d",
status: "pending_async",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
consumer_id: "123456",
token: "ee946db8-d7db-4bb7-b608-b65b153e127d",
threeds_method_url: "https://staging.gate.emerchantpay.net/threeds/threeds_method",
threeds_method_continue_url: "https://staging.gate.emerchantpay.net/threeds/threeds_method/44177a21403427eb96664a6d7e5d5d48",
timestamp: "2025-01-16T10:23:50Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "false",
reason_for_not_honoring_exemption: "8A01",
sca_exemption_result: "13",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>init_recurring_sale3d</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<consumer_id>123456</consumer_id>
<token>ee946db8-d7db-4bb7-b608-b65b153e127d</token>
<threeds_method_url>https://staging.gate.emerchantpay.net/threeds/threeds_method</threeds_method_url>
<threeds_method_continue_url>https://staging.gate.emerchantpay.net/threeds/threeds_method/44177a21403427eb96664a6d7e5d5d48</threeds_method_continue_url>
<timestamp>2025-01-16T10:23:50Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>false</sent_to_acquirer>
<reason_for_not_honoring_exemption>8A01</reason_for_not_honoring_exemption>
<sca_exemption_result>13</sca_exemption_result>
</payment_response>
Challenge Without 3 Ds Mеthod Response
stdClass Object
(
[transaction_type] => init_recurring_sale3d
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[consumer_id] => 123456
[token] => ee946db8-d7db-4bb7-b608-b65b153e127d
[redirect_url] => https://staging.gate.emerchantpay.net/threeds/authentication/44177a21403427eb96664a6d7e5d5d48
[redirect_url_type] => 3ds_v2_challenge
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:50.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => false
[reason_for_not_honoring_exemption] => 8A01
[sca_exemption_result] => 13
)
<payment_response content=[
<transaction_type content=[init_recurring_sale3d]>
<status content=[pending_async]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<consumer_id content=[123456]>
<token content=[ee946db8-d7db-4bb7-b608-b65b153e127d]>
<redirect_url content=[https://staging.gate.emerchantpay.net/threeds/authentication/44177a21403427eb96664a6d7e5d5d48]>
<redirect_url_type content=[3ds_v2_challenge]>
<timestamp content=[2025-01-16T10:23:50Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[false]>
<reason_for_not_honoring_exemption content=[8A01]>
<sca_exemption_result content=[13]>
]>
{
transaction_type: "init_recurring_sale3d",
status: "pending_async",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
consumer_id: "123456",
token: "ee946db8-d7db-4bb7-b608-b65b153e127d",
redirect_url: "https://staging.gate.emerchantpay.net/threeds/authentication/44177a21403427eb96664a6d7e5d5d48",
redirect_url_type: "3ds_v2_challenge",
timestamp: "2025-01-16T10:23:50Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "false",
reason_for_not_honoring_exemption: "8A01",
sca_exemption_result: "13",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>init_recurring_sale3d</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<consumer_id>123456</consumer_id>
<token>ee946db8-d7db-4bb7-b608-b65b153e127d</token>
<redirect_url>https://staging.gate.emerchantpay.net/threeds/authentication/44177a21403427eb96664a6d7e5d5d48</redirect_url>
<redirect_url_type>3ds_v2_challenge</redirect_url_type>
<timestamp>2025-01-16T10:23:50Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>false</sent_to_acquirer>
<reason_for_not_honoring_exemption>8A01</reason_for_not_honoring_exemption>
<sca_exemption_result>13</sca_exemption_result>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
consumer_id | string(10) | Consumer unique reference. See Consumers |
token | string(36) | Plain-text token value. See Tokenization |
gaming | 'true' | Signifies whether a gaming transaction is performed. Gaming transactions usually use MCC 7995, contact tech support for more details. |
moto | 'true' | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech support for more details. |
avs_response_code | string(255) | Generated by the card network on trying to match the billing address when performing the address verification. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
avs_response_text | string(255) | Gives the human response text for the AVS response code above. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
cvv_result_code | string(1) | Card Verification Value response code. Optional, returned only if acquirer supports it |
authorization_code | string(6) | Generated by the card network when an authorisation has occurred, used to identify that auth. Consists of 6 alphanumeric chars |
retrieval_reference_number | string(255) | A reference number used for tracking all messages related to a given cardholder transaction returned by some acquirers. |
payment_account_reference | string(255) | Payment Account Reference value returned from the schemes. Links tokenized and PAN-based transactions. |
response_code | string(2) | Defines the result of a transaction with the acquirer, the status of a message or some action taken or required. Contact tech-support@emerchantpay.com for more details. |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where the consumer has to be redirected to complete the payment process unless a 3DSecure Method is required. This redirect_url will not be included in the response if a 3DS-Method submission is required. For more information, to go 3DSv2 authentication flows |
redirect_url_type | string(64) | The type of the redirect URL in the 3DS scope. It will be present only for asynchronous 3D transactions when an interaction between consumer and issuer is required. This type identifies what kind of redirect url is returned, namely 3DSv2 Challenge. For more information, to go 3DSv2 authentication flows |
threeds_method_url | url | 3DSecure Method URL. It will be present only then 3DS-Method is required for 3D transaction. A 3DS-Method submission inside an iframe is required to be submitted using HTTP POST. For more information, to go 3DSv2 authentication flows |
threeds_method_continue_url | url | This is an API endpoint that accepts HTTP PUT & HTTP PATCH requests. It will be present when the threeds_method_url is included in the response. An HTTP PUT request must be submitted to that endpoint together with the proper signature to determine what the next step in the authentication is. For more information, to go 3DSv2 authentication flows |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
partial_approval | string(4) | Optional, set to ’true’ if partial approval happened. Partially approved amount is then in the amount field. Check Partial Approvals for details |
sent_to_acquirer | string(255) | "true" or "false" |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
scheme_transaction_identifier | string(32) | Id defined by card schemes. Corresponds to NETWORK DATA (field 63) for MasterCard or TRANS ID (field 62.2/125) for VISA. |
scheme_transaction_link_id | string(22) | The transaction unique identifier returned from the schemes. Corresponds to ADDITIONAL SERVICE DATA (field 65, MasterCard Transaction Link Id [TLID]). |
scheme_pan_indicator | string(1) | The account number indicator in scheme-tokenized transactions. See Account number indicator codes for details. |
scheme_pan_tail | string(4) | The tail of the PAN number tail associated with the token in scheme-tokenized transactions. Returned in conjunction with scheme_pan_indicator . |
scheme_max_settlement_date | string(10) | The final date an authorization could be captured which is returned from the card scheme. See Scheme Maximum Settlement Date for more details. |
scheme_authentication_data_quality | boolean | The Authentication Data Quality Indicator returned by the card scheme is used to indicate whether a transaction meets the authentication data quality requirements. The value can be either true or false . |
scheme_settlement_date | string(4) | MasterCard settlement date in MMDD format (e.g. 0117). Corresponds to NETWORK DATA (field 15). |
reason_for_not_honoring_exemption | string | Reason for not honoring exemption. Check SCA Reason For Not Honoring Exemption Values. |
sca_exemption_result | string | SCA exemption result. Check SCA Exemption Result Values. |
threeds | ||
eci | string(2) | See Electronic Commerce Indicator as returned from the MPI for details |
Error Response
stdClass Object
(
[transaction_type] => init_recurring_sale3d
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[response_code] => 57
[code] => 340
[technical_message] => expiration_year is invalid
[message] => expiration_year is invalid
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:50.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => false
)
<payment_response content=[
<transaction_type content=[init_recurring_sale3d]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<response_code content=[57]>
<code content=[340]>
<technical_message content=[expiration_year is invalid]>
<message content=[expiration_year is invalid]>
<timestamp content=[2025-01-16T10:23:50Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[false]>
]>
{
transaction_type: "init_recurring_sale3d",
status: "error",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
response_code: "57",
code: "340",
technical_message: "expiration_year is invalid",
message: "expiration_year is invalid",
timestamp: "2025-01-16T10:23:50Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "false",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>init_recurring_sale3d</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<response_code>57</response_code>
<code>340</code>
<technical_message>expiration_year is invalid</technical_message>
<message>expiration_year is invalid</message>
<timestamp>2025-01-16T10:23:50Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
moto | 'true' | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech support for more details. |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
threeds | ||
authentication | ||
status_reason_code | string(2) | See 3DS Authentication Status Reason Codes for details. |
Error Response
stdClass Object
(
[transaction_type] => init_recurring_sale3d
[status] => declined
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 600
[technical_message] => Cardholder not participating 3DS.
[message] => Transaction failed, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:50.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
[threeds] => {"eci"=>"06", "authentication"=>{"status_reason_code"=>"08"}}
)
<payment_response content=[
<transaction_type content=[init_recurring_sale3d]>
<status content=[declined]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<code content=[600]>
<technical_message content=[Cardholder not participating 3DS.]>
<message content=[Transaction failed, please contact support!]>
<timestamp content=[2025-01-16T10:23:50Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[true]>
<threeds content=[{"eci"=>"06", "authentication"=>{"status_reason_code"=>"08"}}]>
]>
{
transaction_type: "init_recurring_sale3d",
status: "declined",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
code: "600",
technical_message: "Cardholder not participating 3DS.",
message: "Transaction failed, please contact support!",
timestamp: "2025-01-16T10:23:50Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "true",
threeds: "{"eci"=>"06", "authentication"=>{"status_reason_code"=>"08"}}",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>init_recurring_sale3d</transaction_type>
<status>declined</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>600</code>
<technical_message>Cardholder not participating 3DS.</technical_message>
<message>Transaction failed, please contact support!</message>
<timestamp>2025-01-16T10:23:50Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
<threeds>
<eci>06</eci>
<authentication>
<status_reason_code>08</status_reason_code>
</authentication>
</threeds>
</payment_response>
Notification for Asynchronous Payments
When using asynchronous payments like 3D-Secure transactions, the transaction might depend on user input. Therefore, the outcome of the transaction is not available immediately after sending the request.
The gateway will send a notification to the merchant’s server as soon as the payment has been completed (either approved or declined).
If the user cancels the payment (or the user has not completed the payment within the given time frame, e.g. 2 hours), the transaction will time out and a notification will be sent.
The notification will be sent as an HTTP POST to the notification_url
specified in the transaction request XML.
See Notifications for the HTTP POST-Data and format.
The Notification will be pure HTTP or HTTPS-based, depending on the URL given by the merchant in the notification_url
.
In case it is a HTTPS-based notification, no SSL verification of the merchant SSL certificate will be performed.
Until a notification echo is rendered by the merchant, there will be up to 10 notifications sent, each with a timeout of 15 minutes.
Note, the originated IP address of a notification will be one of the following per environment:
- Staging - 80.82.206.228, 52.208.124.201, 52.30.134.55
- Production - 80.82.206.228, 5.179.225.28, 52.49.192.214, 34.242.204.253
Please, make sure IP addresses above are whitelisted respectively.
The notifications are delivered to either port 80 (HTTP notification) or port 443 (HTTPS notification), so
make sure the correct notification_url
is submitted in the transaction request within the first place.
Also see 3-D secure workflow.
Wallets
Neteller
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Wallets\Neteller');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setNotificationUrl('https://www.example.com/notification')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setAmount('100')
->setCurrency('USD')
->setCustomerAccount('453501020503')
->setAccountPassword('908379')
->setCustomerEmail('travis@example.com')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.wallets.NetellerRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
NetellerRequest request = new NetellerRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setNotificationUrl(new URL("https://www.example.com/notification"));
request.setReturnSuccessUrl(new URL("http://www.example.com/success"));
request.setReturnFailureUrl(new URL("http://www.example.com/failure"));
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCustomerAccount("453501020503");
request.setAccountPassword("908379");
request.setCustomerEmail("travis@example.com");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.neteller(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"notification_url": "https://www.example.com/notification",
"return_success_url": "http://www.example.com/success",
"return_failure_url": "http://www.example.com/failure",
"amount": "100",
"currency": "USD",
"customer_account": "453501020503",
"account_password": "908379",
"customer_email": "travis@example.com",
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>neteller</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<notification_url>https://www.example.com/notification</notification_url>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<amount>100</amount>
<currency>USD</currency>
<customer_account>453501020503</customer_account>
<account_password>908379</account_password>
<customer_email>travis@example.com</customer_email>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: neteller |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
customer_email | required | e-mail address | Must contain valid e-mail of customer |
customer_phone | required* | string(32) | Must contain valid phone number of customer |
customer_account | required | string(100) | Customer email/id of neteller account |
account_password | required | string(6) | Account secret password |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
neighborhood | optional | string(255) | Neighborhood |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Successful Response
stdClass Object
(
[transaction_type] => neteller
[status] => approved
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:50.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[neteller]>
<status content=[approved]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<timestamp content=[2025-01-16T10:23:50Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "neteller",
status: "approved",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
technical_message: "Transaction successful!",
message: "Transaction successful!",
timestamp: "2025-01-16T10:23:50Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>neteller</transaction_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:50Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => neteller
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 110
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:50.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => false
)
<payment_response content=[
<transaction_type content=[neteller]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<code content=[110]>
<message content=[Something went wrong, please contact support!]>
<timestamp content=[2025-01-16T10:23:50Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[false]>
]>
{
transaction_type: "neteller",
status: "error",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
code: "110",
message: "Something went wrong, please contact support!",
timestamp: "2025-01-16T10:23:50Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "false",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>neteller</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:50Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
PayPal
The following payment types are supported:
Payment type | Description |
---|---|
authorize | Creates an order that should be captured later. |
sale | Captures the created order immediately after the buyer confirms the payment. |
express | Creates an Express Checkout PayPal payment. Express Checkout eliminates one of the major causes of checkout abandonment by giving buyers all the transaction details at once, including order details, shipping options, insurance choices, and tax totals. |
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>pay_pal</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<payment_type>authorize</payment_type>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<business_attributes>
<event_start_date>17-02-2025</event_start_date>
<event_end_date>26-02-2025</event_end_date>
<event_organizer_id>20192375</event_organizer_id>
<event_id>1912</event_id>
</business_attributes>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: pay_pal |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
payment_type | required | string | Use either authorize for Authorize or sale for Sale transactions |
usage | optional | string(255) | Description of the transaction for later use. |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
customer_email | required* | e-mail address | Must contain valid e-mail of customer |
customer_phone | required* | string(32) | Must contain valid phone number of customer |
birth_date | required* | dd-mm-yyyy | Required for Visa only when MCC is a Financial Services one (e.g. MCC 6012) |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
document_id | required* | string(255) | Document ID value. |
business_attributes | required* | Check business attributes section. | |
event_start_date | required* | dd-mm-yyyy | The date when event starts in format dd-mm-yyyy |
event_end_date | required* | dd-mm-yyyy | The date when event ends in format dd-mm-yyyy |
event_organizer_id | required* | string | |
event_id | required* | string | |
date_of_order | required* | dd-mm-yyyy | The date when order was placed in format dd-mm-yyyy |
delivery_date | required* | dd-mm-yyyy | Date of the expected delivery in format dd-mm-yyyy |
name_of_the_supplier | required* | string | |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required* | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
neighborhood | optional | string(255) | Neighborhood |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>pay_pal</transaction_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<consumer_id>123456</consumer_id>
<avs_response_code>5I</avs_response_code>
<avs_response_text>Response provided by issuer processor; Address information not verified</avs_response_text>
<authorization_code>345678</authorization_code>
<response_code>00</response_code>
<timestamp>2025-01-16T10:23:50Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
<scheme_transaction_identifier>019091214161031</scheme_transaction_identifier>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
consumer_id | string(10) | Consumer unique reference. See Consumers |
gaming | 'true' | Signifies whether a gaming transaction is performed. Gaming transactions usually use MCC 7995, contact tech support for more details. |
avs_response_code | string(255) | Generated by the card network on trying to match the billing address when performing the address verification. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
avs_response_text | string(255) | Gives the human response text for the AVS response code above. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
authorization_code | string(6) | Generated by the card network when an authorisation has occurred, used to identify that auth. Consists of 6 alphanumeric chars |
response_code | string(2) | Defines the result of a transaction with the acquirer, the status of a message or some action taken or required. Contact tech-support@emerchantpay.com for more details. |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
partial_approval | string(4) | Optional, set to ’true’ if partial approval happened. Partially approved amount is then in the amount field. Check Partial Approvals for details |
sent_to_acquirer | string(255) | "true" or "false" |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
scheme_transaction_identifier | string(32) | Id defined by card schemes. Corresponds to NETWORK DATA (field 63) for MasterCard or TRANS ID (field 62.2/125) for VISA. |
Error Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>pay_pal</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>340</code>
<technical_message>expiration_year is invalid</technical_message>
<message>expiration_year is invalid</message>
<timestamp>2025-01-16T10:23:50Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
gaming | 'true' | Signifies whether a gaming transaction is performed. Gaming transactions usually use MCC 7995, contact tech support for more details. |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
WebMoney
Auth Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Wallets\WebMoney');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setCustomerPhone('+1987987987987')
->setCustomerEmail('travis@example.com')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.wallets.WebMoneyRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
WebMoneyRequest request = new WebMoneyRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setReturnSuccessUrl(new URL("http://www.example.com/success"));
request.setReturnFailureUrl(new URL("http://www.example.com/failure"));
request.setCustomerPhone("+1987987987987");
request.setCustomerEmail("travis@example.com");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.webmoney(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"return_success_url": "http://www.example.com/success",
"return_failure_url": "http://www.example.com/failure",
"customer_phone": "+1987987987987",
"customer_email": "travis@example.com",
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>webmoney</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<customer_phone>+1987987987987</customer_phone>
<customer_email>travis@example.com</customer_email>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
</payment_transaction>'
Payout Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Wallets\WebMoney');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setIsPayout('true')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setCustomerPhone('+1987987987987')
->setCustomerEmail('travis@example.com')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.wallets.WebMoneyRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
WebMoneyRequest request = new WebMoneyRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setIsPayout("true");
request.setReturnSuccessUrl(new URL("http://www.example.com/success"));
request.setReturnFailureUrl(new URL("http://www.example.com/failure"));
request.setCustomerPhone("+1987987987987");
request.setCustomerEmail("travis@example.com");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.webmoney(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"is_payout": "true",
"return_success_url": "http://www.example.com/success",
"return_failure_url": "http://www.example.com/failure",
"customer_phone": "+1987987987987",
"customer_email": "travis@example.com",
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>webmoney</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<is_payout>true</is_payout>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<customer_phone>+1987987987987</customer_phone>
<customer_email>travis@example.com</customer_email>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: webmoney |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
is_payout | required* | string | Value:true/false Flag for payout transaction |
customer_account_id | required* | string(12) | Webmoney account ID (WMID). This field is required if is payout is set to "true" |
customer_email | required | e-mail address | Must contain valid e-mail of customer |
customer_phone | required* | string(32) | Must contain valid phone number of customer |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
neighborhood | optional | string(255) | Neighborhood |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Auth Response
stdClass Object
(
[transaction_type] => webmoney
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:50.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[webmoney]>
<status content=[pending_async]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<redirect_url content=[https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61]>
<timestamp content=[2025-01-16T10:23:50Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "webmoney",
status: "pending_async",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
technical_message: "Transaction successful!",
message: "Transaction successful!",
redirect_url: "https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61",
timestamp: "2025-01-16T10:23:50Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>webmoney</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<timestamp>2025-01-16T10:23:50Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Payout Response
stdClass Object
(
[transaction_type] => webmoney
[status] => approved
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:50.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[webmoney]>
<status content=[approved]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<timestamp content=[2025-01-16T10:23:50Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "webmoney",
status: "approved",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
technical_message: "Transaction successful!",
message: "Transaction successful!",
timestamp: "2025-01-16T10:23:50Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>webmoney</transaction_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:50Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => webmoney
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 110
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:50.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => false
)
<payment_response content=[
<transaction_type content=[webmoney]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<code content=[110]>
<message content=[Something went wrong, please contact support!]>
<timestamp content=[2025-01-16T10:23:50Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[false]>
]>
{
transaction_type: "webmoney",
status: "error",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
code: "110",
message: "Something went wrong, please contact support!",
timestamp: "2025-01-16T10:23:50Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "false",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>webmoney</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:50Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Supported countries: All countries are supported
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\OnlineBankingPayments\WeChat');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setNotificationUrl('https://www.example.com/notification')
->setReturnUrl('https://staging.gate.emerchantpay.net/redirect/to_acquirer/a55ab44d242f')
->setAmount('100')
->setCurrency('USD')
->setProductCode('product-code')
->setProductNum('1234')
->setProductDesc('Product description')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.oBeP.WechatRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
WechatRequest request = new WechatRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setNotificationUrl(new URL("https://www.example.com/notification"));
request.setReturnUrl(new URL("https://staging.gate.emerchantpay.net/redirect/to_acquirer/a55ab44d242f"));
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setProductCode("product-code");
request.setProductNum("1234");
request.setProductDesc("Product description");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.wechat(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"notification_url": "https://www.example.com/notification",
"return_url": "https://staging.gate.emerchantpay.net/redirect/to_acquirer/a55ab44d242f",
"amount": "100",
"currency": "USD",
"product_code": "product-code",
"product_num": "1234",
"product_desc": "Product description",
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>wechat</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<notification_url>https://www.example.com/notification</notification_url>
<return_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/a55ab44d242f</return_url>
<amount>100</amount>
<currency>USD</currency>
<product_code>product-code</product_code>
<product_num>1234</product_num>
<product_desc>Product description</product_desc>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: wechat |
transaction_id | required | string(30) | Unique transaction id defined by merchant |
usage | required | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
notification_url | required | url | URL at merchant where gateway sends outcome of transaction. |
return_url | required | url | URL where consumer is sent to after payment |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details Max amount in minor currency unit: 999999 |
currency | required | string(3) | Currency code in ISO 4217 |
product_code | optional | string(60) | Product code |
product_num | optional | integer(10) | Product number |
product_desc | optional | string(255) | Product description |
customer_email | required* | e-mail address | Must contain valid e-mail of customer |
customer_phone | required* | string(32) | Must contain valid phone number of customer |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
required* = conditionally required
Successful Response
stdClass Object
(
[transaction_type] => wechat
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:50.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[wechat]>
<status content=[pending_async]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<redirect_url content=[https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61]>
<timestamp content=[2025-01-16T10:23:50Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "wechat",
status: "pending_async",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
technical_message: "Transaction successful!",
message: "Transaction successful!",
redirect_url: "https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61",
timestamp: "2025-01-16T10:23:50Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>wechat</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<timestamp>2025-01-16T10:23:50Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(30) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => wechat
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 110
[message] => Please check input data for errors!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:50.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[wechat]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<code content=[110]>
<message content=[Please check input data for errors!]>
<timestamp content=[2025-01-16T10:23:50Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "wechat",
status: "error",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
code: "110",
message: "Please check input data for errors!",
timestamp: "2025-01-16T10:23:50Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>wechat</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<message>Please check input data for errors!</message>
<timestamp>2025-01-16T10:23:50Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(30) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Alipay
Alipay is an oBeP-style alternative payment method that allows you to pay directly with your ebank account.
After initiating a transaction Alipay will redirect you to their page.
There you will see a picture of a QR code, which you will have to scan with your Alipay mobile application.
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\OnlineBankingPayments\Alipay');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setNotificationUrl('https://www.example.com/notification')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setAmount('100')
->setCurrency('CNY')
->setCustomerEmail('travis@example.com')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.oBeP.AlipayRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
AlipayRequest request = new AlipayRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setNotificationUrl(new URL("https://www.example.com/notification"));
request.setReturnSuccessUrl(new URL("http://www.example.com/success"));
request.setReturnFailureUrl(new URL("http://www.example.com/failure"));
request.setAmount(new BigDecimal(100));
request.setCurrency("CNY");
request.setCustomerEmail("travis@example.com");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.alipay(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"notification_url": "https://www.example.com/notification",
"return_success_url": "http://www.example.com/success",
"return_failure_url": "http://www.example.com/failure",
"amount": "100",
"currency": "CNY",
"customer_email": "travis@example.com",
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>alipay</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<notification_url>https://www.example.com/notification</notification_url>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<amount>100</amount>
<currency>CNY</currency>
<customer_email>travis@example.com</customer_email>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: alipay |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
customer_email | optional | e-mail address | Must contain valid e-mail of customer |
customer_phone | optional | string(32) | Must contain valid phone number of customer |
birth_date | optional | dd-mm-yyyy | Required for Visa only when MCC is a Financial Services one (e.g. MCC 6012) |
billing_address | optional | See Required vs Optional API params for details | |
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
neighborhood | optional | string(255) | Neighborhood |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported currencies
Currency name | Currency code |
---|---|
China yen | CNY |
Euro | EUR |
Successful Response
stdClass Object
(
[transaction_type] => alipay
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:50.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => CNY
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[alipay]>
<status content=[pending_async]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<redirect_url content=[https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61]>
<timestamp content=[2025-01-16T10:23:50Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[CNY]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "alipay",
status: "pending_async",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
technical_message: "Transaction successful!",
message: "Transaction successful!",
redirect_url: "https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61",
timestamp: "2025-01-16T10:23:50Z",
descriptor: "Descriptor one",
amount: "100",
currency: "CNY",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>alipay</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<timestamp>2025-01-16T10:23:50Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>CNY</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => alipay
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 110
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:50.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => CNY
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[alipay]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<code content=[110]>
<message content=[Something went wrong, please contact support!]>
<timestamp content=[2025-01-16T10:23:50Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[CNY]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "alipay",
status: "error",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
code: "110",
message: "Something went wrong, please contact support!",
timestamp: "2025-01-16T10:23:50Z",
descriptor: "Descriptor one",
amount: "100",
currency: "CNY",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>alipay</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:50Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>CNY</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
eZeeWallet
eZeeWallet is a comprehensive digital wallet, connecting multiple payment methods simultaneously. It has the highest level of security, offering you a unique way to make secure and quick online payments. Consumers can upload funds to your account using P24, Trustly, Invoice (Sofort), iDeal, eps, NeoSurf and bank transfer and pay fast for goods and services with their available eZeeWallet balances.
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Wallets\eZeeWallet');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setNotificationUrl('https://www.example.com/notification')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setSourceWalletId('john@example.com')
->setSourceWalletPwd('UDBydsDBrYWxAQA==\n')
->setAmount('100')
->setCurrency('USD');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.wallets.EzeewalletRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
EzeewalletRequest request = new EzeewalletRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setNotificationUrl(new URL("https://www.example.com/notification"));
request.setReturnSuccessUrl(new URL("http://www.example.com/success"));
request.setReturnFailureUrl(new URL("http://www.example.com/failure"));
request.setSourceWalletId("john@example.com");
request.setSourceWalletPwd("UDBydsDBrYWxAQA==\n");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.ezeewallet(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"notification_url": "https://www.example.com/notification",
"return_success_url": "http://www.example.com/success",
"return_failure_url": "http://www.example.com/failure",
"source_wallet_id": "john@example.com",
"source_wallet_pwd": "UDBydsDBrYWxAQA==\\n",
"amount": "100",
"currency": "USD"
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>ezeewallet</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<notification_url>https://www.example.com/notification</notification_url>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<source_wallet_id>john@example.com</source_wallet_id>
<source_wallet_pwd>UDBydsDBrYWxAQA==\n</source_wallet_pwd>
<amount>100</amount>
<currency>USD</currency>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: ezeewallet |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
source_wallet_id | required | string(255) | Email address of consumer who owns the wallet |
source_wallet_pwd | required | string(255) | Password of consumer who owns the wallet, in Base64 encoded form |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
notification_url | optional | url | URL at merchant where gateway sends outcome of transaction. |
merchant_website | required | url | Website URL of the merchant initiating the wallet transfer |
required* = conditionally required
Successful Response
stdClass Object
(
[transaction_type] => ezeewallet
[status] => approved
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:51.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[ezeewallet]>
<status content=[approved]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<timestamp content=[2025-01-16T10:23:51Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "ezeewallet",
status: "approved",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
technical_message: "Transaction successful!",
message: "Transaction successful!",
timestamp: "2025-01-16T10:23:51Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>ezeewallet</transaction_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:51Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Pending Response
stdClass Object
(
[transaction_type] => ezeewallet
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:51.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[ezeewallet]>
<status content=[pending_async]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<redirect_url content=[https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61]>
<timestamp content=[2025-01-16T10:23:51Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "ezeewallet",
status: "pending_async",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
technical_message: "Transaction successful!",
message: "Transaction successful!",
redirect_url: "https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61",
timestamp: "2025-01-16T10:23:51Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>ezeewallet</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<timestamp>2025-01-16T10:23:51Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Pending Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => ezeewallet
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 930
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:51.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => false
)
<payment_response content=[
<transaction_type content=[ezeewallet]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<code content=[930]>
<message content=[Something went wrong, please contact support!]>
<timestamp content=[2025-01-16T10:23:51Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[false]>
]>
{
transaction_type: "ezeewallet",
status: "error",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
code: "930",
message: "Something went wrong, please contact support!",
timestamp: "2025-01-16T10:23:51Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "false",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>ezeewallet</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>930</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:51Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
eWallet
eWallet transaction that handles different e-wallet providers
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Wallets\EWallet');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setPaymentType('Free Charge')
->setRemoteIp('245.253.2.12')
->setNotificationUrl('https://www.example.com/notification')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setAmount('50000')
->setCurrency('INR')
->setCustomerEmail('travis@example.com')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>e_wallet</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<payment_type>Free Charge</payment_type>
<remote_ip>245.253.2.12</remote_ip>
<notification_url>https://www.example.com/notification</notification_url>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<amount>50000</amount>
<currency>INR</currency>
<customer_email>travis@example.com</customer_email>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: e_wallet |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
payment_type | required | string | eWallet provider name that can be one of Airtel Money, Amazon pay, Free Charge, Jio Money, Ola Money, Paytm, Payzapp, PhonePe.Note, the list with the supported providers might be restricted based on the gateway configuration and currency. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
customer_email | required* | e-mail address | Must contain valid e-mail of customer |
customer_phone | required* | string(32) | Must contain valid phone number of customer |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported currencies
Currency name | Currency code |
---|---|
Indian rupee | INR |
Successful Response
stdClass Object
(
[transaction_type] => e_wallet
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:51.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 50000
[currency] => INR
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>e_wallet</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<timestamp>2025-01-16T10:23:51Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>50000</amount>
<currency>INR</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => e_wallet
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 110
[technical_message] => amount is missing
[message] => Please check input data for errors!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:51.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 50000
[currency] => INR
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>e_wallet</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<technical_message>amount is missing</technical_message>
<message>Please check input data for errors!</message>
<timestamp>2025-01-16T10:23:51Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>50000</amount>
<currency>INR</currency>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
Vouchers
CashU
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Vouchers\CashU');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setAmount('100')
->setCurrency('EUR')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.apm.CashURequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
CashURequest request = new CashURequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setReturnSuccessUrl(new URL("http://www.example.com/success"));
request.setReturnFailureUrl(new URL("http://www.example.com/failure"));
request.setAmount(new BigDecimal(100));
request.setCurrency("EUR");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.cashu(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"return_success_url": "http://www.example.com/success",
"return_failure_url": "http://www.example.com/failure",
"amount": "100",
"currency": "EUR",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>cashu</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<amount>100</amount>
<currency>EUR</currency>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: cashu |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
customer_email | required | e-mail address | Must contain valid e-mail of customer |
customer_phone | required* | string(32) | Must contain valid phone number of customer |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
neighborhood | optional | string(255) | Neighborhood |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported countries
Country name | Country code |
---|---|
Algeria | DZ |
Bahrain | BH |
Egypt | EG |
Gambia | GM |
Ghana | GH |
India | IN |
Iran | IR |
Iraq | IQ |
Israel | IL |
Jordan | JO |
Kenya | KE |
Korea | KP |
Kuwait | KW |
Lebanon | LB |
Libya | LY |
Malaysia | MY |
Mauritania | MR |
Morocco | MA |
Nigeria | NG |
Oman | OM |
Pakistan | PK |
Palestine | PS |
Qatar | QA |
Saudi Arabia | SA |
Sierra Leone | SL |
Sudan | SD |
Syria | SY |
Tanzania | TZ |
Tunisia | TN |
Turkey | TR |
United Arab Emirates | AE |
United States | US |
Yemen | YE |
Supported currencies
Currency name | Currency code |
---|---|
Algerian Dinar | DZD |
AmericanDollar | USD |
EgyptianPound | EGP |
Euro | EUR |
JordanianDinar | JOD |
LebanesePound | LBP |
MoroccanDirham | MAD |
Qatar Riyal | QAR |
Saudi Riyal | SAR |
Turkish Lira | TRY |
UAE Dirham | AED |
Successful Response
stdClass Object
(
[transaction_type] => cashu
[status] => approved
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:51.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => EUR
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[cashu]>
<status content=[approved]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<redirect_url content=[https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61]>
<timestamp content=[2025-01-16T10:23:51Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[EUR]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "cashu",
status: "approved",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
technical_message: "Transaction successful!",
message: "Transaction successful!",
redirect_url: "https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61",
timestamp: "2025-01-16T10:23:51Z",
descriptor: "Descriptor one",
amount: "100",
currency: "EUR",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>cashu</transaction_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<timestamp>2025-01-16T10:23:51Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>EUR</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => cashu
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 110
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:51.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => EUR
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[cashu]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<code content=[110]>
<message content=[Something went wrong, please contact support!]>
<timestamp content=[2025-01-16T10:23:51Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[EUR]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "cashu",
status: "error",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
code: "110",
message: "Something went wrong, please contact support!",
timestamp: "2025-01-16T10:23:51Z",
descriptor: "Descriptor one",
amount: "100",
currency: "EUR",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>cashu</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:51Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>EUR</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Neosurf
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Vouchers\Neosurf');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('EUR')
->setVoucherNumber('Vo23')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Barney')
->setBillingLastName('Rubble')
->setBillingAddress1('23, Doestreet')
->setBillingZipCode('11923')
->setBillingCity('New York City')
->setBillingNeighborhood('Manhattan')
->setBillingCountry('DE');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>neosurf</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>EUR</currency>
<voucher_number>Vo23</voucher_number>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<billing_address>
<first_name>Barney</first_name>
<last_name>Rubble</last_name>
<address1>23, Doestreet</address1>
<zip_code>11923</zip_code>
<city>New York City</city>
<neighborhood>Manhattan</neighborhood>
<country>DE</country>
</billing_address>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: neosurf |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
voucher_number | required* | string(10) | Voucher number. Alphanumeric maximum 10 characters |
customer_email | required* | e-mail address | Must contain valid e-mail of customer |
customer_phone | required* | string(32) | Must contain valid phone number of customer |
return_success_url | required* | url | URL where customer is sent to after successful payment. It might be required depending on the gateway, it is strongly recommended for the URL to be set in order to avoid any invalidated transactions. |
return_failure_url | required* | url | URL where customer is sent to after unsuccessful payment. It might be required depending on the gateway, it is strongly recommended for the URL to be set in order to avoid any invalidated transactions. |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
neighborhood | optional | string(255) | Neighborhood |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported countries
Country Name | Country code |
---|---|
Austria | AT |
Algeria | DZ |
Australia | AU |
Burundi | BI |
Burkina Faso | BF |
Benin | BJ |
Belgium | BE |
Cape Verde | CV |
Cyprus | CY |
Canada | CA |
Central African Republic | CF |
Chad | TD |
Colombia | CO |
Congo | CG |
Cameroon | CM |
Democratic Republic of Congo | CD |
Denmark | DK |
Equatorial Guinea | GQ |
France | FR |
Gambia | GM |
Germany | DE |
Gabon | GA |
Guinea | GN |
Ghana | GH |
Guinea-Bissau | GW |
Hong Kong | HK |
Ireland | IE |
Italy | IT |
Ivory Coast | CI |
Kenya | KE |
Luxembourg | LU |
Malawi | MW |
Mozambique | MZ |
Morocco | MA |
Mauritania | MR |
Mali | ML |
Niger | NE |
Nigeria | NG |
Netherlands | NL |
New Zealand | NZ |
Norway | NO |
Poland | PL |
Portugal | PT |
Rwanda | RW |
Russia | RU |
Romania | RO |
Sweden | SE |
Spain | ES |
Sierra Leone | SL |
Senegal | SN |
Sao Tome and Principe | ST |
Switzerland | CH |
Serbia | RS |
Turkey | TR |
Togo | TG |
Tunisia | TN |
United Kingdom | GB |
United Republic of Tanzania | TZ |
Uganda | UG |
Zimbabwe | ZW |
Zambia | ZM |
Supported currencies
Currency name | Currency code |
---|---|
Australian dollar | AUD |
Bulgarian lev | BGN |
Brazilian real | BRL |
Canadian dollar | CAD |
Swiss franc | CHF |
Chinese yuan | CNY |
Czech koruna | CZK |
Danish krone | DKK |
Euro | EUR |
Pound sterling | GBP |
Hong Kong dollar | HKD |
Croatian kuna | HRK |
Hungarian forint | HUF |
Indonesian rupiah | IDR |
Israeli new shekel | ILS |
Indian rupee | INR |
Japanese yen | JPY |
South Korean won | KRW |
Mexican peso | MXN |
Malaysian ringgit | MYR |
Norwegian krone | NOK |
New Zealand dollar | NZD |
Philippine peso | PHP |
Polish złoty | PLN |
Romanian leu | RON |
Russian ruble | RUB |
Swedish kronor | SEK |
Singapore dollar | SGD |
Thai baht | THB |
Turkish lira | TRY |
United States dollar | USD |
CFA franc BCEAO | XOF |
South African rand | ZAR |
Successful Response
stdClass Object
(
[transaction_type] => neosurf
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[technical_message] => Transaction successful!
[message] => Transaction successful!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:51.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => EUR
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>neosurf</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:51Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>EUR</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => neosurf
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 110
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:51.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => EUR
[sent_to_acquirer] => false
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>neosurf</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:51Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>EUR</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Paysafecard
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Vouchers\Paysafecard');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setAmount('100')
->setCurrency('USD')
->setCustomerId('3192481752123')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.apm.PaySafeCardRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
PaySafeCardRequest request = new PaySafeCardRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setReturnSuccessUrl(new URL("http://www.example.com/success"));
request.setReturnFailureUrl(new URL("http://www.example.com/failure"));
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCustomerId("3192481752123");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.paysafecard(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"return_success_url": "http://www.example.com/success",
"return_failure_url": "http://www.example.com/failure",
"amount": "100",
"currency": "USD",
"customer_id": "3192481752123",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>paysafecard</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<amount>100</amount>
<currency>USD</currency>
<customer_id>3192481752123</customer_id>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: paysafecard |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
customer_id | required | string(32) | A value that uniquely identifies the end user (customer) and is disconnected from any personal information, it should be the same for all transactions of the customer. |
customer_email | required | e-mail address | Must contain valid e-mail of customer |
customer_phone | required* | string(32) | Must contain valid phone number of customer |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
neighborhood | optional | string(255) | Neighborhood |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported countries:
Country name | Country code |
---|---|
Australia | AU |
Austria | AT |
Belgium | BE |
Bulgaria | BG |
Canada | CA |
Croatia | HR |
Cyprus | CY |
Czech Republic | CZ |
Denmark | DK |
Finland | FI |
France | FR |
Georgia | GE |
Germany | DE |
Gibraltar | GI |
Greece | GR |
Hungary | HU |
Iceland | IS |
Ireland | IE |
Italy | IT |
Kuwait | KW |
Latvia | LV |
Liechtenstein | LI |
Lithuania | LT |
Luxembourg | LU |
Malta | MT |
Mexico | MX |
Moldova | MD |
Montenegro | ME |
Netherlands | NL |
New Zealand | NZ |
Norway | NO |
Paraguay | PY |
Peru | PE |
Poland | PL |
Portugal | PT |
Romania | RO |
Saudi Arabia | SA |
Slovakia | SK |
Slovenia | SI |
Spain | ES |
Sweden | SE |
Switzerland | CH |
Turkey | TR |
United Arab Emirates | AE |
United Kingdom | GB |
United States of America | US |
Uruguay | UY |
Successful Response
stdClass Object
(
[transaction_type] => paysafecard
[status] => approved
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:51.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[paysafecard]>
<status content=[approved]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<redirect_url content=[https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61]>
<timestamp content=[2025-01-16T10:23:51Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "paysafecard",
status: "approved",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
technical_message: "Transaction successful!",
message: "Transaction successful!",
redirect_url: "https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61",
timestamp: "2025-01-16T10:23:51Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>paysafecard</transaction_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<timestamp>2025-01-16T10:23:51Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => paysafecard
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 110
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:51.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => false
)
<payment_response content=[
<transaction_type content=[paysafecard]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<code content=[110]>
<message content=[Something went wrong, please contact support!]>
<timestamp content=[2025-01-16T10:23:51Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[false]>
]>
{
transaction_type: "paysafecard",
status: "error",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
code: "110",
message: "Something went wrong, please contact support!",
timestamp: "2025-01-16T10:23:51Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "false",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>paysafecard</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:51Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Online Banking ePayments (oBeP)
Online Banking ePayments refer to payment methods that are used as an alternative to credit card payments allowing consumers to pay online with their bank account.
Banco do Brasil
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\OnlineBankingPayments\BancoDoBrasil');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setReturnPendingUrl('http://www.example.com/pending')
->setAmount('100')
->setCurrency('USD')
->setConsumerReference('barney_rubble')
->setNationalId('8812128812')
->setBirthDate('30-12-1992')
->setCustomerEmail('travis@example.com')
// Billing Address
->setBillingFirstName('Barney')
->setBillingLastName('Rubble')
->setBillingAddress1('14, Nerazdelni str')
->setBillingZipCode('1407')
->setBillingCity('Natal')
->setBillingCountry('BR')
// Risk Params
->setRiskUserId('123456');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>banco_do_brasil</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<return_pending_url>http://www.example.com/pending</return_pending_url>
<amount>100</amount>
<currency>USD</currency>
<consumer_reference>barney_rubble</consumer_reference>
<national_id>8812128812</national_id>
<birth_date>30-12-1992</birth_date>
<customer_email>travis@example.com</customer_email>
<billing_address>
<first_name>Barney</first_name>
<last_name>Rubble</last_name>
<address1>14, Nerazdelni str</address1>
<zip_code>1407</zip_code>
<city>Natal</city>
<country>BR</country>
</billing_address>
<risk_params>
<user_id>123456</user_id>
</risk_params>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: banco_do_brasil |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
return_pending_url | optional | url | URL where customer is sent to when asynchronous payment is pending confirmation |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
consumer_reference | required | string(20) | Consumer reference is a unique consumer identifier |
national_id | required | string(20) | National ID of the consumer. See Document ID Parameter for more details. |
birth_date | optional | string(20) | Birth date of the customer |
customer_email | required | e-mail address | Must contain valid e-mail of customer |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported countries:
Country |
---|
BR |
Successful Response
stdClass Object
(
[transaction_type] => banco_do_brasil
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:51.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>banco_do_brasil</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<timestamp>2025-01-16T10:23:51Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => banco_do_brasil
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 110
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:51.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>banco_do_brasil</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:51Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Bancomer
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\OnlineBankingPayments\Bancomer');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setReturnPendingUrl('http://www.example.com/pending')
->setAmount('100')
->setCurrency('USD')
->setConsumerReference('barney_rubble')
->setNationalId('8812128812')
->setBirthDate('30-12-1992')
->setCustomerEmail('travis@example.com')
// Billing Address
->setBillingFirstName('Barney')
->setBillingLastName('Rubble')
->setBillingAddress1('14, Nerazdelni str')
->setBillingZipCode('1407')
->setBillingCity('Mexico City')
->setBillingCountry('MX')
// Risk Params
->setRiskUserId('123456');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>bancomer</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<return_pending_url>http://www.example.com/pending</return_pending_url>
<amount>100</amount>
<currency>USD</currency>
<consumer_reference>barney_rubble</consumer_reference>
<national_id>8812128812</national_id>
<birth_date>30-12-1992</birth_date>
<customer_email>travis@example.com</customer_email>
<billing_address>
<first_name>Barney</first_name>
<last_name>Rubble</last_name>
<address1>14, Nerazdelni str</address1>
<zip_code>1407</zip_code>
<city>Mexico City</city>
<country>MX</country>
</billing_address>
<risk_params>
<user_id>123456</user_id>
</risk_params>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: bancomer |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
return_pending_url | optional | url | URL where customer is sent to when asynchronous payment is pending confirmation |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
consumer_reference | required | string(20) | Consumer reference is a unique consumer identifier |
national_id | required | string(20) | National ID of the consumer. See Document ID Parameter for more details. |
birth_date | optional | string(20) | Birth date of the customer |
customer_email | required | e-mail address | Must contain valid e-mail of customer |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported countries:
Country |
---|
MX |
Successful Response
stdClass Object
(
[transaction_type] => bancomer
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:51.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>bancomer</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<timestamp>2025-01-16T10:23:51Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => bancomer
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 110
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:51.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>bancomer</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:51Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Bradesco
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\OnlineBankingPayments\Bradesco');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setReturnPendingUrl('http://www.example.com/pending')
->setAmount('100')
->setCurrency('USD')
->setConsumerReference('barney_rubble')
->setNationalId('8812128812')
->setBirthDate('30-12-1992')
->setCustomerEmail('travis@example.com')
// Billing Address
->setBillingFirstName('Barney')
->setBillingLastName('Rubble')
->setBillingAddress1('14, Nerazdelni str')
->setBillingZipCode('1407')
->setBillingCity('Rio de Janeiro')
->setBillingCountry('BR')
// Risk Params
->setRiskUserId('123456');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>bradesco</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<return_pending_url>http://www.example.com/pending</return_pending_url>
<amount>100</amount>
<currency>USD</currency>
<consumer_reference>barney_rubble</consumer_reference>
<national_id>8812128812</national_id>
<birth_date>30-12-1992</birth_date>
<customer_email>travis@example.com</customer_email>
<billing_address>
<first_name>Barney</first_name>
<last_name>Rubble</last_name>
<address1>14, Nerazdelni str</address1>
<zip_code>1407</zip_code>
<city>Rio de Janeiro</city>
<country>BR</country>
</billing_address>
<risk_params>
<user_id>123456</user_id>
</risk_params>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: bradesco |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
return_pending_url | optional | url | URL where customer is sent to when asynchronous payment is pending confirmation |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
consumer_reference | required | string(20) | Consumer reference is a unique consumer identifier |
national_id | required | string(20) | National ID of the consumer. See Document ID Parameter for more details. |
birth_date | optional | string(20) | Birth date of the customer |
customer_email | required | e-mail address | Must contain valid e-mail of customer |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported countries:
Country |
---|
BR |
Successful Response
stdClass Object
(
[transaction_type] => bradesco
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:51.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>bradesco</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<timestamp>2025-01-16T10:23:51Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => bradesco
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 110
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:51.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>bradesco</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:51Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
EPS
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>eps</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<return_pending_url>http://www.example.com/pending</return_pending_url>
<amount>100</amount>
<currency>EUR</currency>
<billing_address>
<first_name>Barney</first_name>
<last_name>Rubble</last_name>
<address1>14, Nerazdelni str</address1>
<zip_code>1407</zip_code>
<city>Vienna</city>
<country>AT</country>
</billing_address>
</payment_transaction>'
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Alternatives\PPRO');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setPaymentType('eps')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setAmount('100')
->setCurrency('EUR')
// Billing Address
->setBillingFirstName('Barney')
->setBillingLastName('Rubble')
->setBillingAddress1('14, Nerazdelni str')
->setBillingZipCode('1407')
->setBillingCity('Vienna')
->setBillingCountry('AT');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.apm.PProRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
PProRequest request = new PProRequest();
request.setTransactionId("119643250547501c79d8295");
request.setPaymentType("eps");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setReturnSuccessUrl(new URL("http://www.example.com/success"));
request.setReturnFailureUrl(new URL("http://www.example.com/failure"));
request.setAmount(new BigDecimal(100));
request.setCurrency("EUR");
// Billing Address
request.setBillingFirstname("Barney");
request.setBillingLastname("Rubble");
request.setBillingPrimaryAddress("14, Nerazdelni str");
request.setBillingZipCode("1407");
request.setBillingCity("Vienna");
request.setBillingCountry("AT");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.ppro(
{
"transaction_id": "119643250547501c79d8295",
"payment_type": "eps",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"return_success_url": "http://www.example.com/success",
"return_failure_url": "http://www.example.com/failure",
"amount": "100",
"currency": "EUR",
"billing_address": {
"first_name": "Barney",
"last_name": "Rubble",
"address1": "14, Nerazdelni str",
"zip_code": "1407",
"city": "Vienna",
"country": "AT"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>ppro</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<payment_type>eps</payment_type>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<amount>100</amount>
<currency>EUR</currency>
<billing_address>
<first_name>Barney</first_name>
<last_name>Rubble</last_name>
<address1>14, Nerazdelni str</address1>
<zip_code>1407</zip_code>
<city>Vienna</city>
<country>AT</country>
</billing_address>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | ppro or eps. Contact tech support at tech-support@emerchantpay.com for more details. |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
payment_type | required1 | eps | EPS. Contact tech support for more details. |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
return_pending_url | optional | url | URL where customer is sent to when asynchronous payment is pending confirmation |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
1 - payment_type must be submitted only when the transaction type is set to ppro
Supported countries and countries
Currency code | Country code |
---|---|
EUR | AT |
Successful Response
stdClass Object
(
[transaction_type] => ppro
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:52.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => EUR
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[ppro]>
<status content=[pending_async]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<redirect_url content=[https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61]>
<timestamp content=[2025-01-16T10:23:52Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[EUR]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "ppro",
status: "pending_async",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
technical_message: "Transaction successful!",
message: "Transaction successful!",
redirect_url: "https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61",
timestamp: "2025-01-16T10:23:52Z",
descriptor: "Descriptor one",
amount: "100",
currency: "EUR",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>ppro</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<timestamp>2025-01-16T10:23:52Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>EUR</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => ppro
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 110
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:52.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => EUR
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[ppro]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<code content=[110]>
<message content=[Something went wrong, please contact support!]>
<timestamp content=[2025-01-16T10:23:52Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[EUR]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "ppro",
status: "error",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
code: "110",
message: "Something went wrong, please contact support!",
timestamp: "2025-01-16T10:23:52Z",
descriptor: "Descriptor one",
amount: "100",
currency: "EUR",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>ppro</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:52Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>EUR</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
iDebit
Supported countries
Country name | Country code |
---|---|
Canada | CA |
iDebit is available only for Canadian merchants and consumers.
Payin
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\OnlineBankingPayments\iDebit\Payin');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setCustomerAccountId('1534537')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setNotificationUrl('https://www.example.com/notification')
->setReturnUrl('https://staging.gate.emerchantpay.net/redirect/to_acquirer/a55ab44d242f')
->setAmount('100')
->setCurrency('CAD')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('46 Donora Dr')
->setBillingZipCode('M4B1B3')
->setBillingCity('Toronto')
->setBillingState('ON')
->setBillingCountry('CA');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.oBeP.IDebitPayInRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
IDebitPayInRequest request = new IDebitPayInRequest();
request.setTransactionId("119643250547501c79d8295");
request.setCustomerAccountId("1534537");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setNotificationUrl(new URL("https://www.example.com/notification"));
request.setReturnUrl(new URL("https://staging.gate.emerchantpay.net/redirect/to_acquirer/a55ab44d242f"));
request.setAmount(new BigDecimal(100));
request.setCurrency("CAD");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("46 Donora Dr");
request.setBillingZipCode("M4B1B3");
request.setBillingCity("Toronto");
request.setBillingState("ON");
request.setBillingCountry("CA");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.idebit_payin(
{
"transaction_id": "119643250547501c79d8295",
"customer_account_id": "1534537",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"notification_url": "https://www.example.com/notification",
"return_url": "https://staging.gate.emerchantpay.net/redirect/to_acquirer/a55ab44d242f",
"amount": "100",
"currency": "CAD",
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "46 Donora Dr",
"zip_code": "M4B1B3",
"city": "Toronto",
"state": "ON",
"country": "CA"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>idebit_payin</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<customer_account_id>1534537</customer_account_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<notification_url>https://www.example.com/notification</notification_url>
<return_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/a55ab44d242f</return_url>
<amount>100</amount>
<currency>CAD</currency>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>46 Donora Dr</address1>
<zip_code>M4B1B3</zip_code>
<city>Toronto</city>
<state>ON</state>
<country>CA</country>
</billing_address>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: idebit_payin |
transaction_id | required | string(30) | Unique transaction id defined by merchant |
usage | required* | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
customer_account_id | required | string(20) | Unique consumer account ID |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
customer_email | required* | e-mail address | Must contain valid e-mail of customer |
customer_phone | required* | string(32) | Must contain valid phone number of customer |
birth_date | required* | dd-mm-yyyy | Required for Visa only when MCC is a Financial Services one (e.g. MCC 6012) |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
required* = conditionally required
Successful Response
stdClass Object
(
[transaction_type] => idebit_payin
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:52.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => CAD
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[idebit_payin]>
<status content=[pending_async]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<redirect_url content=[https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61]>
<timestamp content=[2025-01-16T10:23:52Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[CAD]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "idebit_payin",
status: "pending_async",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
technical_message: "Transaction successful!",
message: "Transaction successful!",
redirect_url: "https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61",
timestamp: "2025-01-16T10:23:52Z",
descriptor: "Descriptor one",
amount: "100",
currency: "CAD",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>idebit_payin</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<timestamp>2025-01-16T10:23:52Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>CAD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(30) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => idebit_payin
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 320
[message] => amount is missing!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:52.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => CAD
[sent_to_acquirer] => false
)
<payment_response content=[
<transaction_type content=[idebit_payin]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<code content=[320]>
<message content=[amount is missing!]>
<timestamp content=[2025-01-16T10:23:52Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[CAD]>
<sent_to_acquirer content=[false]>
]>
{
transaction_type: "idebit_payin",
status: "error",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
code: "320",
message: "amount is missing!",
timestamp: "2025-01-16T10:23:52Z",
descriptor: "Descriptor one",
amount: "100",
currency: "CAD",
sent_to_acquirer: "false",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>idebit_payin</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>320</code>
<message>amount is missing!</message>
<timestamp>2025-01-16T10:23:52Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>CAD</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(30) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Payout
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\OnlineBankingPayments\iDebit\Payout');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setReferenceId('43672')
->setAmount('100')
->setCurrency('CAD');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.oBeP.IDebitPayOutRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
IDebitPayOutRequest request = new IDebitPayOutRequest();
request.setTransactionId("119643250547501c79d8295");
request.setReferenceId("43672");
request.setAmount(new BigDecimal(100));
request.setCurrency("CAD");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.idebit_payout(
{
"transaction_id": "119643250547501c79d8295",
"reference_id": "43672",
"amount": "100",
"currency": "CAD"
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>idebit_payout</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<reference_id>43672</reference_id>
<amount>100</amount>
<currency>CAD</currency>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: idebit_payout |
transaction_id | required | string(30) | Unique transaction id defined by merchant |
reference_id | required | string(32) | Unique id returned by corresponding transaction |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
required* = conditionally required
Successful Response
stdClass Object
(
[transaction_type] => idebit_payout
[status] => approved
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:52.000000
[timezone_type] => 2
[timezone] => Z
)
[amount] => 100
[currency] => CAD
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[idebit_payout]>
<status content=[approved]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<timestamp content=[2025-01-16T10:23:52Z]>
<amount content=[100]>
<currency content=[CAD]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "idebit_payout",
status: "approved",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
technical_message: "Transaction successful!",
message: "Transaction successful!",
timestamp: "2025-01-16T10:23:52Z",
amount: "100",
currency: "CAD",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>idebit_payout</transaction_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:52Z</timestamp>
<amount>100</amount>
<currency>CAD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(30) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => idebit_payout
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 110
[technical_message] => amount is missing!
[message] => Please check input data for errors!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:52.000000
[timezone_type] => 2
[timezone] => Z
)
[amount] => 100
[currency] => CAD
[sent_to_acquirer] => false
)
<payment_response content=[
<transaction_type content=[idebit_payout]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<code content=[110]>
<technical_message content=[amount is missing!]>
<message content=[Please check input data for errors!]>
<timestamp content=[2025-01-16T10:23:52Z]>
<amount content=[100]>
<currency content=[CAD]>
<sent_to_acquirer content=[false]>
]>
{
transaction_type: "idebit_payout",
status: "error",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
code: "110",
technical_message: "amount is missing!",
message: "Please check input data for errors!",
timestamp: "2025-01-16T10:23:52Z",
amount: "100",
currency: "CAD",
sent_to_acquirer: "false",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>idebit_payout</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<technical_message>amount is missing!</technical_message>
<message>Please check input data for errors!</message>
<timestamp>2025-01-16T10:23:52Z</timestamp>
<amount>100</amount>
<currency>CAD</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(30) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
iDeal
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>ideal</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<payment_transaction>payment_type</payment_transaction>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<notification_url>https://www.example.com/notification</notification_url>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<amount>100</amount>
<currency>EUR</currency>
<billing_address>
<first_name>Barney</first_name>
<last_name>Rubble</last_name>
<address1>14, Nerazdelni str</address1>
<zip_code>1407</zip_code>
<city>Amsterdam</city>
<country>NL</country>
</billing_address>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: ideal |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
bic | optional | string(11) | SWIFT/BIC code of the customer’s bank. If BIC is not provided, the consumer is redirected to a bank selection page. Get BIC list |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
notification_url | optional | url | URL at merchant where gateway sends outcome of transaction. |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
return_pending_url | optional | url | URL where customer is sent to when asynchronous payment is pending confirmation |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported currencies and countries
Currency code | Country code |
---|---|
EUR | NL |
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>ideal</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<timestamp>2025-01-16T10:23:52Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>EUR</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>ideal</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:52Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>EUR</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Bank Name | BIC |
---|---|
Rabobank | RABONL2U |
ABN AMRO | ABNANL2A |
Van Lanschot Bankiers | FVLBNL22 |
Triodos Bank | TRIONL2U |
ING Bank | INGBNL2A |
SNS Bank | SNSBNL2A |
ASN | ASNBNL21 |
RegioBank | RBRBNL21 |
Knab | KNABNL2H |
Bunq | BUNQNL2A |
Handelsbanken | HANDNL2A |
Revolut | REVOLT21 |
InstaDebit
Supported countries
Country name | Country code |
---|---|
Canada | CA |
InstaDebit is available only for Canadian merchants and consumers.
Payin
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\OnlineBankingPayments\InstaDebit\Payin');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setCustomerAccountId('118221674199')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setNotificationUrl('https://www.example.com/notification')
->setReturnUrl('https://staging.gate.emerchantpay.net/redirect/to_acquirer/a55ab44d242f')
->setAmount('100')
->setCurrency('CAD')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('46 Donora Dr')
->setBillingZipCode('M4B1B3')
->setBillingCity('Toronto')
->setBillingState('ON')
->setBillingCountry('CA');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.oBeP.InstaDebitPayInRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
InstaDebitPayInRequest request = new InstaDebitPayInRequest();
request.setTransactionId("119643250547501c79d8295");
request.setCustomerAccountId("118221674199");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setNotificationUrl(new URL("https://www.example.com/notification"));
request.setReturnUrl(new URL("https://staging.gate.emerchantpay.net/redirect/to_acquirer/a55ab44d242f"));
request.setAmount(new BigDecimal(100));
request.setCurrency("CAD");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("46 Donora Dr");
request.setBillingZipCode("M4B1B3");
request.setBillingCity("Toronto");
request.setBillingState("ON");
request.setBillingCountry("CA");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.insta_debit_payin(
{
"transaction_id": "119643250547501c79d8295",
"customer_account_id": "118221674199",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"notification_url": "https://www.example.com/notification",
"return_url": "https://staging.gate.emerchantpay.net/redirect/to_acquirer/a55ab44d242f",
"amount": "100",
"currency": "CAD",
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "46 Donora Dr",
"zip_code": "M4B1B3",
"city": "Toronto",
"state": "ON",
"country": "CA"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>insta_debit_payin</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<customer_account_id>118221674199</customer_account_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<notification_url>https://www.example.com/notification</notification_url>
<return_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/a55ab44d242f</return_url>
<amount>100</amount>
<currency>CAD</currency>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>46 Donora Dr</address1>
<zip_code>M4B1B3</zip_code>
<city>Toronto</city>
<state>ON</state>
<country>CA</country>
</billing_address>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: insta_debit_payin |
transaction_id | required | string(30) | Unique transaction id defined by merchant |
customer_account_id | required | string(20) | Unique consumer account ID |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_url | required | url | URL where consumer is sent to after payment |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
customer_email | required* | e-mail address | Must contain valid e-mail of customer |
customer_phone | required* | string(32) | Must contain valid phone number of customer |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
required* = conditionally required
Successful Response
stdClass Object
(
[transaction_type] => insta_debit_payin
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:52.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => CAD
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[insta_debit_payin]>
<status content=[pending_async]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<redirect_url content=[https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61]>
<timestamp content=[2025-01-16T10:23:52Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[CAD]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "insta_debit_payin",
status: "pending_async",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
technical_message: "Transaction successful!",
message: "Transaction successful!",
redirect_url: "https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61",
timestamp: "2025-01-16T10:23:52Z",
descriptor: "Descriptor one",
amount: "100",
currency: "CAD",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>insta_debit_payin</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<timestamp>2025-01-16T10:23:52Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>CAD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(30) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => insta_debit_payin
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[message] => Please check input data for errors!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:52.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => CAD
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[insta_debit_payin]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<message content=[Please check input data for errors!]>
<timestamp content=[2025-01-16T10:23:52Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[CAD]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "insta_debit_payin",
status: "error",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
message: "Please check input data for errors!",
timestamp: "2025-01-16T10:23:52Z",
descriptor: "Descriptor one",
amount: "100",
currency: "CAD",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>insta_debit_payin</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<message>Please check input data for errors!</message>
<timestamp>2025-01-16T10:23:52Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>CAD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(30) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Payout
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\OnlineBankingPayments\InstaDebit\Payout');
$request = $genesis->request();
$request
->setReferenceId('43672')
->setAmount('100')
->setCurrency('CAD');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.oBeP.InstaDebitPayOutRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
InstaDebitPayOutRequest request = new InstaDebitPayOutRequest();
request.setReferenceId("43672");
request.setAmount(new BigDecimal(100));
request.setCurrency("CAD");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.insta_debit_payout(
{
"reference_id": "43672",
"amount": "100",
"currency": "CAD"
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<reference_id>43672</reference_id>
<amount>100</amount>
<currency>CAD</currency>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: insta_debit_payout |
transaction_id | required | string(30) | Unique transaction id defined by merchant |
reference_id | required | string(32) | unique id of approved InstaDebit Payin transaction. See InstaDebit Payin Response, unique id |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details Max amount in minor currency unit: 999999 |
currency | required | string(3) | Currency code in ISO 4217 |
required* = conditionally required
Successful Response
stdClass Object
(
[transaction_type] => insta_debit_payout
[status] => approved
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:52.000000
[timezone_type] => 2
[timezone] => Z
)
[amount] => 100
[currency] => CAD
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[insta_debit_payout]>
<status content=[approved]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<timestamp content=[2025-01-16T10:23:52Z]>
<amount content=[100]>
<currency content=[CAD]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "insta_debit_payout",
status: "approved",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
technical_message: "Transaction successful!",
message: "Transaction successful!",
timestamp: "2025-01-16T10:23:52Z",
amount: "100",
currency: "CAD",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>insta_debit_payout</transaction_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:52Z</timestamp>
<amount>100</amount>
<currency>CAD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(30) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => insta_debit_payout
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 320
[technical_message] => amount is missing!
[message] => Please check input data for errors!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:52.000000
[timezone_type] => 2
[timezone] => Z
)
[amount] => 100
[currency] => CAD
[sent_to_acquirer] => false
)
<payment_response content=[
<transaction_type content=[insta_debit_payout]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<code content=[320]>
<technical_message content=[amount is missing!]>
<message content=[Please check input data for errors!]>
<timestamp content=[2025-01-16T10:23:52Z]>
<amount content=[100]>
<currency content=[CAD]>
<sent_to_acquirer content=[false]>
]>
{
transaction_type: "insta_debit_payout",
status: "error",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
code: "320",
technical_message: "amount is missing!",
message: "Please check input data for errors!",
timestamp: "2025-01-16T10:23:52Z",
amount: "100",
currency: "CAD",
sent_to_acquirer: "false",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>insta_debit_payout</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>320</code>
<technical_message>amount is missing!</technical_message>
<message>Please check input data for errors!</message>
<timestamp>2025-01-16T10:23:52Z</timestamp>
<amount>100</amount>
<currency>CAD</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(30) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Itau
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\OnlineBankingPayments\Itau');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setReturnPendingUrl('http://www.example.com/pending')
->setAmount('100')
->setCurrency('USD')
->setConsumerReference('barney_rubble')
->setNationalId('8812128812')
->setBirthDate('30-12-1992')
->setCustomerEmail('travis@example.com')
// Billing Address
->setBillingFirstName('Barney')
->setBillingLastName('Rubble')
->setBillingAddress1('14, Nerazdelni str')
->setBillingZipCode('1407')
->setBillingCity('Rio de Janeiro')
->setBillingCountry('BR')
// Risk Params
->setRiskUserId('123456');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>itau</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<return_pending_url>http://www.example.com/pending</return_pending_url>
<amount>100</amount>
<currency>USD</currency>
<consumer_reference>barney_rubble</consumer_reference>
<national_id>8812128812</national_id>
<birth_date>30-12-1992</birth_date>
<customer_email>travis@example.com</customer_email>
<billing_address>
<first_name>Barney</first_name>
<last_name>Rubble</last_name>
<address1>14, Nerazdelni str</address1>
<zip_code>1407</zip_code>
<city>Rio de Janeiro</city>
<country>BR</country>
</billing_address>
<risk_params>
<user_id>123456</user_id>
</risk_params>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: itau |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
return_pending_url | optional | url | URL where customer is sent to when asynchronous payment is pending confirmation |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
consumer_reference | required | string(20) | Consumer reference is a unique consumer identifier |
national_id | required | string(20) | National ID of the consumer. See Document ID Parameter for more details. |
birth_date | optional | string(20) | Birth date of the customer |
customer_email | required | e-mail address | Must contain valid e-mail of customer |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported countries:
Country |
---|
BR |
Successful Response
stdClass Object
(
[transaction_type] => itau
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:52.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>itau</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<timestamp>2025-01-16T10:23:52Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => itau
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 110
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:52.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>itau</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:52Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Multibanco
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\OnlineBankingPayments\Multibanco');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setReturnPendingUrl('http://www.example.com/pending')
->setAmount('100')
->setCurrency('EUR')
->setCustomerEmail('travis@example.com')
// Billing Address
->setBillingFirstName('Barney')
->setBillingLastName('Rubble')
->setBillingAddress1('14, Nerazdelni str')
->setBillingZipCode('1407')
->setBillingCity('Porto')
->setBillingCountry('PT')
// Risk Params
->setRiskUserId('123456');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>multibanco</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<return_pending_url>http://www.example.com/pending</return_pending_url>
<amount>100</amount>
<currency>EUR</currency>
<customer_email>travis@example.com</customer_email>
<billing_address>
<first_name>Barney</first_name>
<last_name>Rubble</last_name>
<address1>14, Nerazdelni str</address1>
<zip_code>1407</zip_code>
<city>Porto</city>
<country>PT</country>
</billing_address>
<risk_params>
<user_id>123456</user_id>
</risk_params>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: multibanco |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
return_pending_url | optional | url | URL where customer is sent to when asynchronous payment is pending confirmation |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
customer_email | optional | e-mail address | Must contain valid e-mail of customer |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported countries:
Country code |
---|
PT |
Successful Response
stdClass Object
(
[transaction_type] => multibanco
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:52.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => EUR
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>multibanco</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<timestamp>2025-01-16T10:23:52Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>EUR</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => multibanco
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 110
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:52.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => EUR
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>multibanco</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:52Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>EUR</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
MyBank
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>my_bank</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<return_pending_url>http://www.example.com/pending</return_pending_url>
<amount>100</amount>
<currency>EUR</currency>
<customer_phone>+1987987987987</customer_phone>
<billing_address>
<first_name>Barney</first_name>
<last_name>Rubble</last_name>
<address1>14, Nerazdelni str</address1>
<zip_code>1407</zip_code>
<city>Rome</city>
<country>IT</country>
</billing_address>
</payment_transaction>'
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Alternatives\PPRO');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setPaymentType('mybank')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setAmount('100')
->setCurrency('EUR')
// Billing Address
->setBillingFirstName('Barney')
->setBillingLastName('Rubble')
->setBillingAddress1('14, Nerazdelni str')
->setBillingZipCode('1407')
->setBillingCity('Rome')
->setBillingCountry('IT');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.apm.PProRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
PProRequest request = new PProRequest();
request.setTransactionId("119643250547501c79d8295");
request.setPaymentType("mybank");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setReturnSuccessUrl(new URL("http://www.example.com/success"));
request.setReturnFailureUrl(new URL("http://www.example.com/failure"));
request.setAmount(new BigDecimal(100));
request.setCurrency("EUR");
// Billing Address
request.setBillingFirstname("Barney");
request.setBillingLastname("Rubble");
request.setBillingPrimaryAddress("14, Nerazdelni str");
request.setBillingZipCode("1407");
request.setBillingCity("Rome");
request.setBillingCountry("IT");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.ppro(
{
"transaction_id": "119643250547501c79d8295",
"payment_type": "mybank",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"return_success_url": "http://www.example.com/success",
"return_failure_url": "http://www.example.com/failure",
"amount": "100",
"currency": "EUR",
"billing_address": {
"first_name": "Barney",
"last_name": "Rubble",
"address1": "14, Nerazdelni str",
"zip_code": "1407",
"city": "Rome",
"country": "IT"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>ppro</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<payment_type>mybank</payment_type>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<amount>100</amount>
<currency>EUR</currency>
<billing_address>
<first_name>Barney</first_name>
<last_name>Rubble</last_name>
<address1>14, Nerazdelni str</address1>
<zip_code>1407</zip_code>
<city>Rome</city>
<country>IT</country>
</billing_address>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | ppro or my_bank. Contact tech support at tech-support@emerchantpay.com for more details. |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
payment_type | required1 | ppro | MyBank. Contact tech support at tech-support@emerchantpay.com for more details. |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
return_pending_url | optional | url | URL where customer is sent to when asynchronous payment is pending confirmation |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
1 - payment_type must be submitted only when the transaction type is set to ppro
Supported currencies and countries
Currency code | Country code |
---|---|
EUR | IT |
EUR | BE |
EUR | PT |
EUR | ES |
Successful Response
stdClass Object
(
[transaction_type] => ppro
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:53.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => EUR
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[ppro]>
<status content=[pending_async]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<redirect_url content=[https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61]>
<timestamp content=[2025-01-16T10:23:53Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[EUR]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "ppro",
status: "pending_async",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
technical_message: "Transaction successful!",
message: "Transaction successful!",
redirect_url: "https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61",
timestamp: "2025-01-16T10:23:53Z",
descriptor: "Descriptor one",
amount: "100",
currency: "EUR",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>ppro</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<timestamp>2025-01-16T10:23:53Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>EUR</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => ppro
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 110
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:53.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => EUR
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[ppro]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<code content=[110]>
<message content=[Something went wrong, please contact support!]>
<timestamp content=[2025-01-16T10:23:53Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[EUR]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "ppro",
status: "error",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
code: "110",
message: "Something went wrong, please contact support!",
timestamp: "2025-01-16T10:23:53Z",
descriptor: "Descriptor one",
amount: "100",
currency: "EUR",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>ppro</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:53Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>EUR</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Online Banking
Online Banking is an oBeP-style alternative payment method that allows you to pay directly with your ebank account. After initiating a transaction, the online banking will redirect you to their page. There you will find a list with available banks to finish the payment.
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\OnlineBankingPayments\OnlineBanking\Payin');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setNotificationUrl('https://www.example.com/notification')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setAmount('50000')
->setCurrency('CNY')
->setCustomerEmail('travis@example.com')
->setBankCode('CITIC')
->setConsumerReference('Consumer Reference')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>online_banking</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<notification_url>https://www.example.com/notification</notification_url>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<amount>50000</amount>
<currency>CNY</currency>
<customer_email>travis@example.com</customer_email>
<bank_code>CITIC</bank_code>
<consumer_reference>Consumer Reference</consumer_reference>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: online_banking |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
customer_email | required* | e-mail address | Must contain valid e-mail of customer |
customer_phone | required* | string(32) | Must contain valid phone number of customer |
bank_code | required | bank code | Must contain Bank code |
document_id | required* | string(255) | Document ID value. |
payment_type | required* | string | The payment type describes the type of online banking used to process the transaction. Must contain one of the allowed Payment types, but they may vary based on the specific setup. If omitted, transaction will be processed with online_banking payment_type if online_banking is a supported payment type. Otherwise, the transaction will be processed with the first available supported payment type. |
virtual_payment_address | required* | string | Virtual Payment Address (VPA) of the customer, format: someone@bank |
consumer_reference | required* | string | Consumer reference identifier of the customer. |
user_category | required* | string | User category. If missing, 'default' will be used. |
auth_code | required* | string | 6-digit code used to authenticate the consumer within BLIK. It is required only for that bank. |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported currencies
Currency name | Currency code |
---|---|
Australian Dollar | AUD |
China yen | CNY |
Chilean Peso | CLP |
Colombian Peso | COP |
Indian rupee | INR |
Indonesian rupiah | IDR |
Malaysian ringgit | MYR |
New Zealand dollar | NZD |
Paraguayan Guarani | PYG |
Philippine peso | PHP |
Polish zloty | PLN |
Singapore dollar | SGD |
Thai baht | THB |
Uruguayan Peso | UYU |
Vietnamese dong | VND |
Mexican Peso | MXN |
Payment Types
Payment Type Name | Payment Type Code |
---|---|
Online banking | online_banking |
Quick payment | quick_payment |
Qr payment | qr_payment |
Netbanking | netbanking |
Alipay QR | alipay_qr |
Bancomer | bancomer |
Scotiabank | scotiabank |
Bank Codes
For AUD currency:
Bank Name | Bank Code |
---|---|
PayID | PID |
For BRL currency:
Bank Name | Bank Code |
---|---|
Caixa | CA |
For CAD currency:
Bank Name | Bank Code |
---|---|
Interac Combined Pay-in | CPI |
For CHF currency:
Bank Name | Bank Code |
---|---|
Post Finance | PF |
For CLP currency:
Bank Name | Bank Code |
---|---|
Servipag | SP |
For CNY currency
Bank Name | Bank Code |
---|---|
Agricultural Bank of China | ABC |
Bank of Beijing | BOB |
Bank of China | BOC |
Bank of Communications | BOCO |
China Construction Bank | CCB |
Bank for economic construction | CCD |
China Everbright Bank | CEB |
Industrial Bank | CIB |
China Merchants Bank | CMB |
China Minsheng Bank | CMBC |
China Citic Bank | CITIC |
Industrial and Commercial Bank of China | ICBC |
China Guangfa Bank | GDB |
Huaxia Bank | HXB |
Pingan Bank | PINGANBANK |
China Postal Savings Bank | PSBC |
China Union Pay | QUICKPAY |
Shanghai Bank | SHB |
Shengzhen Ping An Bank | SPABANK |
Shanghai Pudong Development Bank | SPDB |
Yinlian Bank | YLB |
For EUR currency:
Bank Name | Bank Code |
---|---|
Post Finance | PF |
Bancontact | BCT |
TrueLayer | TRL |
For GBP currency:
Bank Name | Bank Code |
---|---|
TrueLayer | TRL |
For IDR currency:
Bank Name | Bank Code |
---|---|
Bank Central Asia | DK_BCA_IB |
Bank Rakyat Indonesia | DK_BRI_IB |
CIMB Clicks Indonesia | DK_CIMBCLICKS_IB |
Danamon Bank | DK_DANAMON_IB |
Permata Bank | DK_PERMATANET_IB |
For INR currency:
Bank Name | Bank Code |
---|---|
Aditya Birla Idea Payments Bank | ABPB |
Airtel Payments Bank | AIRP |
Allahabad Bank | ALLA |
Andhra Bank | ANDB |
Bank of Baroda - Retail Banking | BARB_R |
Bank of Bahrein and Kuwait | BBKM |
Dena Bank | BKDN |
Bank of India | BKID |
Central Bank of India | CBIN |
City Union Bank | CIUB |
Canara Bank | CNRB |
Corporation Bank | CORP |
Cosmos Co-operative Bank | COSB |
Catholic Syrian Bank | CSBK |
Development Bank of Singapore | DBSS |
DCB Bank | DCBL |
Deutsche Bank | DEUT |
Dhanlaxmi Bank | DLXB |
Equitas Small Finance Bank | ESFB |
Federal Bank | FDRL |
HDFC Bank | HDFC |
IDBI | IBKL |
ICICI Bank | ICIC |
IDFC FIRST Bank | IDFB |
Indian Bank | IDIB |
Indusind Bank | INDB |
Indian Overseas Bank | IOBA |
Jammu and Kashmir Bank | JAKA |
Janata Sahakari Bank (Pune) | JSBP |
Karnataka Bank | KARB |
Kotak Mahindra Bank | KKBK |
Karur Vysya Bank | KVBL |
Lakshmi Vilas Bank - Corporate Banking | LAVB_C |
Lakshmi Vilas Bank - Retail Banking | LAVB_R |
Bank of Maharashtra | MAHB |
NKGSB Co-operative Bank | NKGS |
Oriental Bank of Commerce | ORBC |
Punjab & Maharashtra Co-operative Bank | PMCB |
Punjab & Sind Bank | PSIB |
Punjab National Bank - Retail Banking | PUNB_R |
RBL Bank | RATN |
State Bank of Bikaner and Jaipur | SBBJ |
State Bank of Hyderabad | SBHY |
State Bank of India | SBIN |
State Bank of Mysore | SBMY |
State Bank of Travancore | SBTR |
Standard Chartered Bank | SCBL |
South Indian Bank | SIBL |
Saraswat Co-operative Bank | SRCB |
State Bank of Patiala | STBP |
Shamrao Vithal Co-operative Bank | SVCB |
Syndicate Bank | SYNB |
Tamilnadu Mercantile Bank | TMBL |
Tamilnadu State Apex Co-operative Bank | TNSC |
Union Bank of India | UBIN |
UCO Bank | UCBA |
United Bank of India | UTBI |
Axis Bank | UTIB |
Vijaya Bank | VIJB |
Yes Bank | YESB |
For MXN currency:
Bank Name | Bank Code |
---|---|
Spei | SE |
Banorte | BQ |
For MYR currency:
Bank Name | Bank Code |
---|---|
Affin Bank | FPX_ABB |
Alliance Bank | FPX_ABMB |
Am Online | FPX_AMB |
Bank Islam | FPX_BIMB |
Bank Muamalat | FPX_BMMB |
Bank Rakyat | FPX_BKRM |
Bank Simpanan Nasional | FPX_BSN |
CIMB Clicks Bank | FPX_CIMBCLICKS |
HLB Connect | FPX_HLB |
Kuwait Finance House | FPX_KFH |
Maybank2u | FPX_MB2U |
OCBC Bank | FPX_OCBC |
PBeBank | FPX_PBB |
RHB Now | FPX_RHB |
Stand Chart Bank | FPX_SCB |
UOB Bank | FPX_UOB |
For NZD currency:
Bank Name | Bank Code |
---|---|
Latipay | POLI |
For PEN currency:
Bank Name | Bank Code |
---|---|
BCP | BC |
Interbank | IB |
Pago Efectivo | EF |
BBVA | BP |
For PLN currency:
Bank Name | Bank Code |
---|---|
BLIK | BLК |
For PYG currency:
Bank Name | Bank Code |
---|---|
PagoExpress | PE |
For THB currency:
Bank Name | Bank Code |
---|---|
Bangkok Bank | BBL_IB_U |
Kasikornbank PAYPLUS | KBANK_PAYPLUS |
Bank of Ayudhya (Krungsri) | BAY_IB_U |
Krung Thai Bank | KTB_IB_U |
Siam Commercial Bank | SCB_IB_U |
For USD currency:
Bank Name | Bank Code |
---|---|
Santander | SN |
Itau | IT |
Bradesco | BR |
Banco do Brasil | BB |
Webpay | WP |
Bancomer | BN |
PSE | PS |
Banco de Occidente | BO |
For UYU currency:
Bank Name | Bank Code |
---|---|
Abitab | AI |
For PHP currency:
Bank Name | Bank Code |
---|---|
Dragonpay | DRAGONPAY |
For SGD currency:
Bank Name | Bank Code |
---|---|
DBS | ENETS-D_DBS |
UOB | ENETS-D_UOB |
OCBC | ENETS-D_OCBC |
SCB | ENETS-D_SCB |
For VND currency:
Bank Name | Bank Code |
---|---|
VTC-Pay VPBank | VTCP_VPBANK |
VTC-Pay ABBANK | VTCP_ABBANK |
VTC-Pay ACB | VTCP_ACB |
VTC-Pay Agribank | VTCP_AGRIBANK |
VTC-Pay BACABANK | VTCP_BACABANK |
VTC-Pay BIDV | VTCP_BIDV |
VTC-Pay BVB | VTCP_BVB |
VTC-Pay DongABank | VTCP_DONGABANK |
VTC-Pay Eximbank | VTCP_EXIMBANK |
VTC-Pay GPBank | VTCP_GPBANK |
VTC-Pay HDBank | VTCP_HDBANK |
VTC-Pay LienVietPostBank | VTCP_LVPB |
VTC-Pay MB | VTCP_MB |
VTC-Pay MaritimeBank | VTCP_MARITIMEBANK |
VTC-Pay NamABank | VTCP_NAMABANK |
VTC-Pay Navibank | VTCP_NAVIBANK |
VTC-Pay Oceanbank | VTCP_OCEANBANK |
VTC-Pay PGBank | VTCP_PGBANK |
VTC-Pay PHUONGDONG | VTCP_PHUONGDONG |
VTC-Pay SHB | VTCP_SHB |
VTC-Pay Sacombank | VTCP_SACOMBANK |
VTC-Pay SaigonBank | VTCP-SAIGONBANK |
VTC-Pay SeaABank | VTCP_SEAABANK |
VTC-Pay Techcombank | VTCP_TECHCOMBANK |
VTC-Pay TienPhong Bank | VTCP_TIENPHONGBANK |
VTC-Pay VIB | VTCP_VIB |
VTC-Pay VietABank | VTCP_VIETABANK |
VTC-Pay Vietcombank | VTCP_VIETCOMBANK |
VTC-Pay Vietinbank | VTCP_VIETINBANK |
Successful Response
stdClass Object
(
[transaction_type] => online_banking
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:53.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 50000
[currency] => CNY
[sent_to_acquirer] => true
[bank_code] => CITIC
[payment_type] => online_banking
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>online_banking</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<timestamp>2025-01-16T10:23:53Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>50000</amount>
<currency>CNY</currency>
<sent_to_acquirer>true</sent_to_acquirer>
<bank_code>CITIC</bank_code>
<payment_type>online_banking</payment_type>
</payment_response>
Successful Response
stdClass Object
(
[transaction_type] => online_banking
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:53.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 50000
[currency] => MXN
[sent_to_acquirer] =>
[bank_code] => SE
[payment_type] =>
[account_details] => {"reference_number"=>"1000210", "account_number"=>"646180320000000006"}
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>online_banking</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:53Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>50000</amount>
<currency>MXN</currency>
<payment_response>sent_to_acquirer</payment_response>
<bank_code>SE</bank_code>
<payment_response>payment_type</payment_response>
<account_details>
<reference_number>1000210</reference_number>
<account_number>646180320000000006</account_number>
</account_details>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | The redirect url is to be included, but also depend on the bank code and might not be returned for SE bank code when it is processed through the provider for the direct integration. |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
bank_code | bank code | The bank code used to process the transaction, see Bank codes. |
payment_type | string | The payment type describes the type of online banking used to process the transaction, see Payment types. |
account_details | ||
reference_number | string(7) | The reference number of the transaction to be used for the payment. |
account_number | string(18) | The account number that the payment is expected to be transferred/done to. |
Error Response
stdClass Object
(
[transaction_type] => online_banking
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 110
[technical_message] => amount is missing
[message] => Please check input data for errors!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:53.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 50000
[currency] => CNY
[sent_to_acquirer] => true
[bank_code] => CITIC
[payment_type] => online_banking
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>online_banking</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<technical_message>amount is missing</technical_message>
<message>Please check input data for errors!</message>
<timestamp>2025-01-16T10:23:53Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>50000</amount>
<currency>CNY</currency>
<sent_to_acquirer>true</sent_to_acquirer>
<bank_code>CITIC</bank_code>
<payment_type>online_banking</payment_type>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
bank_code | bank code | The bank code used to process the transaction, see Bank codes. |
payment_type | string | The payment type describes the type of online banking used to process the transaction, see Payment types. |
P24
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Alternatives\P24');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setAmount('100')
->setCurrency('USD')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
->setBankCode('')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.apm.P24Request;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
P24Request request = new P24Request();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setReturnSuccessUrl(new URL("http://www.example.com/success"));
request.setReturnFailureUrl(new URL("http://www.example.com/failure"));
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
request.setBankCode("");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.p24(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"return_success_url": "http://www.example.com/success",
"return_failure_url": "http://www.example.com/failure",
"amount": "100",
"currency": "USD",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"bank_code": null,
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>p24</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<amount>100</amount>
<currency>USD</currency>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<payment_transaction>bank_code</payment_transaction>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: p24 |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | required* | string(255) | Description of the transaction for later use. |
remote_ip | required | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
customer_email | required | e-mail address | Must contain valid e-mail of customer |
customer_phone | required* | string(32) | Must contain valid phone number of customer |
bank_code | optional | integer | Must be one of the supported Bank codes |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Bank Codes
For EUR and PLN currencies:
Bank Name | Bank Code |
---|---|
BLIK - PSP | 154 |
EuroBank | 94 |
Przekaz tradycyjny | 178 |
Przekaz/Przelew tradycyjny | 1000 |
Płac ̨e z IKO | 135 |
Płac ̨e z Orange | 146 |
Raiffeisen Bank PBL | 102 |
U ̇zyj przedpłaty | 177 |
mBank-mTransfer | 25 |
Successful Response
stdClass Object
(
[transaction_type] => p24
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:53.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[p24]>
<status content=[pending_async]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<redirect_url content=[https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61]>
<timestamp content=[2025-01-16T10:23:53Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "p24",
status: "pending_async",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
technical_message: "Transaction successful!",
message: "Transaction successful!",
redirect_url: "https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61",
timestamp: "2025-01-16T10:23:53Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>p24</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<timestamp>2025-01-16T10:23:53Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => p24
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 110
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:53.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[p24]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<code content=[110]>
<message content=[Something went wrong, please contact support!]>
<timestamp content=[2025-01-16T10:23:53Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "p24",
status: "error",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
code: "110",
message: "Something went wrong, please contact support!",
timestamp: "2025-01-16T10:23:53Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>p24</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:53Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
PayU
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\OnlineBankingPayments\PayU');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setReturnPendingUrl('http://www.example.com/pending')
->setAmount('100')
->setCurrency('PLN')
->setCustomerEmail('travis@example.com')
// Billing Address
->setBillingFirstName('Barney')
->setBillingLastName('Rubble')
->setBillingAddress1('14, Nerazdelni str')
->setBillingZipCode('1407')
->setBillingCity('Krakov')
->setBillingCountry('PL')
// Risk Params
->setRiskUserId('123456');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>payu</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<return_pending_url>http://www.example.com/pending</return_pending_url>
<amount>100</amount>
<currency>PLN</currency>
<customer_email>travis@example.com</customer_email>
<billing_address>
<first_name>Barney</first_name>
<last_name>Rubble</last_name>
<address1>14, Nerazdelni str</address1>
<zip_code>1407</zip_code>
<city>Krakov</city>
<country>PL</country>
</billing_address>
<risk_params>
<user_id>123456</user_id>
</risk_params>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: payu |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
return_pending_url | optional | url | URL where customer is sent to when asynchronous payment is pending confirmation |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
customer_email | optional | e-mail address | Must contain valid e-mail of customer |
billing_address | required | See Required vs Optional API params for details | |
first_name | required | string(255) | Customer first name |
last_name | required | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported currencies and countries:
Currency code | Country code |
---|---|
CZK | CZ |
PLN | PL |
Successful Response
stdClass Object
(
[transaction_type] => payu
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:53.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => PLN
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>payu</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<timestamp>2025-01-16T10:23:53Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>PLN</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => payu
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 110
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:53.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => PLN
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>payu</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:53Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>PLN</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
POLi
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Alternatives\POLi');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setNotificationUrl('https://www.example.com/notification')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setAmount('100')
->setCurrency('AUD')
// Billing Address
->setBillingFirstName('Barney')
->setBillingLastName('Rubble')
->setBillingAddress1('14, Nerazdelni str')
->setBillingZipCode('1407')
->setBillingCity('Sofia')
->setBillingCountry('AU')
->setBillingState('AC');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.apm.POLiRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
POLiRequest request = new POLiRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setNotificationUrl(new URL("https://www.example.com/notification"));
request.setReturnSuccessUrl(new URL("http://www.example.com/success"));
request.setReturnFailureUrl(new URL("http://www.example.com/failure"));
request.setAmount(new BigDecimal(100));
request.setCurrency("AUD");
// Billing Address
request.setBillingFirstname("Barney");
request.setBillingLastname("Rubble");
request.setBillingPrimaryAddress("14, Nerazdelni str");
request.setBillingZipCode("1407");
request.setBillingCity("Sofia");
request.setBillingCountry("AU");
request.setBillingState("AC");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.poli(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"notification_url": "https://www.example.com/notification",
"return_success_url": "http://www.example.com/success",
"return_failure_url": "http://www.example.com/failure",
"amount": "100",
"currency": "AUD",
"billing_address": {
"first_name": "Barney",
"last_name": "Rubble",
"address1": "14, Nerazdelni str",
"zip_code": "1407",
"city": "Sofia",
"country": "AU",
"state": "AC"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>poli</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<notification_url>https://www.example.com/notification</notification_url>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<amount>100</amount>
<currency>AUD</currency>
<billing_address>
<first_name>Barney</first_name>
<last_name>Rubble</last_name>
<address1>14, Nerazdelni str</address1>
<zip_code>1407</zip_code>
<city>Sofia</city>
<country>AU</country>
<state>AC</state>
</billing_address>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: poli |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
customer_email | required | e-mail address | Must contain valid e-mail of customer |
customer_phone | required* | string(32) | Must contain valid phone number of customer |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported bank countries:
Country name | Country code |
---|---|
Australia | AU |
New Zealand | NZ |
Supported currencies:
Currency name | Currency code |
---|---|
Australian dollar | AUD |
New Zealand dollar | NZD |
Successful Response
stdClass Object
(
[transaction_type] => poli
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:53.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => AUD
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[poli]>
<status content=[pending_async]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<redirect_url content=[https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61]>
<timestamp content=[2025-01-16T10:23:53Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[AUD]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "poli",
status: "pending_async",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
technical_message: "Transaction successful!",
message: "Transaction successful!",
redirect_url: "https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61",
timestamp: "2025-01-16T10:23:53Z",
descriptor: "Descriptor one",
amount: "100",
currency: "AUD",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>poli</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<timestamp>2025-01-16T10:23:53Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>AUD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => poli
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 110
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:53.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => AUD
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[poli]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<code content=[110]>
<message content=[Something went wrong, please contact support!]>
<timestamp content=[2025-01-16T10:23:53Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[AUD]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "poli",
status: "error",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
code: "110",
message: "Something went wrong, please contact support!",
timestamp: "2025-01-16T10:23:53Z",
descriptor: "Descriptor one",
amount: "100",
currency: "AUD",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>poli</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:53Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>AUD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
PSE (Pagos Seguros en Linea)
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\OnlineBankingPayments\Pse');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setReturnPendingUrl('http://www.example.com/pending')
->setAmount('100')
->setCurrency('USD')
->setConsumerReference('barney_rumble')
->setNationalId('8812128812')
->setBirthDate('30-12-1992')
// Billing Address
->setBillingFirstName('Barney')
->setBillingLastName('Rubble')
->setBillingAddress1('14, Nerazdelni str')
->setBillingZipCode('1407')
->setBillingCity('Bogota')
->setBillingCountry('CO')
// Risk Params
->setRiskUserId('123456');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>pse</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<return_pending_url>http://www.example.com/pending</return_pending_url>
<amount>100</amount>
<currency>USD</currency>
<consumer_reference>barney_rumble</consumer_reference>
<national_id>8812128812</national_id>
<birth_date>30-12-1992</birth_date>
<billing_address>
<first_name>Barney</first_name>
<last_name>Rubble</last_name>
<address1>14, Nerazdelni str</address1>
<zip_code>1407</zip_code>
<city>Bogota</city>
<country>CO</country>
</billing_address>
<risk_params>
<user_id>123456</user_id>
</risk_params>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: pse |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
return_pending_url | optional | url | URL where customer is sent to when asynchronous payment is pending confirmation |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
consumer_reference | required | string(20) | Consumer reference is a unique consumer identifier |
national_id | required | string(20) | National ID of the consumer. See Document ID Parameter for more details. |
birth_date | optional | dd-mm-yyyy | Required for Visa only when MCC is a Financial Services one (e.g. MCC 6012) |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported countries:
Country |
---|
CO |
Successful Response
stdClass Object
(
[transaction_type] => pse
[status] => pending_async
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[technical_message] => Transaction successful!
[message] => Transaction successful!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:53.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>pse</transaction_type>
<status>pending_async</status>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:53Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => pse
[status] => error
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 110
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:53.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>pse</transaction_type>
<status>error</status>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:53Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Post Finance
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>post_finance</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<return_pending_url>http://www.example.com/pending</return_pending_url>
<amount>100</amount>
<currency>EUR</currency>
<billing_address>
<first_name>Barney</first_name>
<last_name>Rubble</last_name>
<address1>14, Nerazdelni str</address1>
<zip_code>1407</zip_code>
<city>Graz</city>
<country>AT</country>
</billing_address>
<risk_params>
<user_id>123456</user_id>
</risk_params>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: post_finance |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | required* | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
return_pending_url | optional | url | URL where customer is sent to when asynchronous payment is pending confirmation |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported currencies and countries:
Currency code | Country code |
---|---|
EUR | CH |
CHF | CH |
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>post_finance</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<timestamp>2025-01-16T10:23:53Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>EUR</currency>
<sent_to_acquirer>true</sent_to_acquirer>
<post_finance_transaction_id>438</post_finance_transaction_id>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
post_finance_transaction_id | string(255) | The Post Finance transaction ID |
Error Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<payment_response>transaction_type</payment_response>
<payment_response>status</payment_response>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<payment_response>code</payment_response>
<payment_response>message</payment_response>
<timestamp>2025-01-16T10:23:53Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<payment_response>sent_to_acquirer</payment_response>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
RapiPago
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\OnlineBankingPayments\Rapipago');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setReturnPendingUrl('http://www.example.com/pending')
->setAmount('100')
->setCurrency('USD')
->setConsumerReference('barney_rumble')
->setNationalId('8812128812')
->setBirthDate('30-12-1992')
// Billing Address
->setBillingFirstName('Barney')
->setBillingLastName('Rubble')
->setBillingAddress1('14, Nerazdelni str')
->setBillingZipCode('1407')
->setBillingCity('Buenos Aires')
->setBillingCountry('AR')
// Risk Params
->setRiskUserId('123456');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>rapi_pago</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<return_pending_url>http://www.example.com/pending</return_pending_url>
<amount>100</amount>
<currency>USD</currency>
<consumer_reference>barney_rumble</consumer_reference>
<national_id>8812128812</national_id>
<birth_date>30-12-1992</birth_date>
<billing_address>
<first_name>Barney</first_name>
<last_name>Rubble</last_name>
<address1>14, Nerazdelni str</address1>
<zip_code>1407</zip_code>
<city>Buenos Aires</city>
<country>AR</country>
</billing_address>
<risk_params>
<user_id>123456</user_id>
</risk_params>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: rapi_pago |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
return_pending_url | optional | url | URL where customer is sent to when asynchronous payment is pending confirmation |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
consumer_reference | required | string(20) | Consumer reference is a unique consumer identifier |
national_id | required | string(20) | National ID of the consumer. See Document ID Parameter for more details. |
birth_date | optional | dd-mm-yyyy | Required for Visa only when MCC is a Financial Services one (e.g. MCC 6012) |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported countries:
Country |
---|
AR |
Successful Response
stdClass Object
(
[transaction_type] => rapi_pago
[status] => pending_async
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[technical_message] => Transaction successful!
[message] => Transaction successful!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:53.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>rapi_pago</transaction_type>
<status>pending_async</status>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:53Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => rapi_pago
[status] => error
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 110
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:54.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>rapi_pago</transaction_type>
<status>error</status>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:54Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
SafetyPay
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\OnlineBankingPayments\SafetyPay');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setPaymentType('safetypay')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setReturnPendingUrl('http://www.example.com/pending')
->setAmount('100')
->setCurrency('USD')
->setConsumerReference('')
->setNationalId('')
->setBirthDate('')
->setCustomerEmail('travis@example.com')
// Billing Address
->setBillingFirstName('Barney')
->setBillingLastName('Rubble')
->setBillingAddress1('14, Nerazdelni str')
->setBillingZipCode('1407')
->setBillingCity('Tampico')
->setBillingCountry('MX')
// Risk Params
->setRiskUserId('123456');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>safetypay</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<payment_type>safetypay</payment_type>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<return_pending_url>http://www.example.com/pending</return_pending_url>
<amount>100</amount>
<currency>USD</currency>
<payment_transaction>consumer_reference</payment_transaction>
<payment_transaction>national_id</payment_transaction>
<payment_transaction>birth_date</payment_transaction>
<customer_email>travis@example.com</customer_email>
<billing_address>
<first_name>Barney</first_name>
<last_name>Rubble</last_name>
<address1>14, Nerazdelni str</address1>
<zip_code>1407</zip_code>
<city>Tampico</city>
<country>MX</country>
</billing_address>
<risk_params>
<user_id>123456</user_id>
</risk_params>
</payment_transaction>'
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Alternatives\PPRO');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setPaymentType('safetypay')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setAmount('100')
->setCurrency('USD')
->setConsumerReference('')
->setNationalId('')
->setBirthDate('')
->setCustomerEmail('travis@example.com')
// Billing Address
->setBillingFirstName('Barney')
->setBillingLastName('Rubble')
->setBillingAddress1('14, Nerazdelni str')
->setBillingZipCode('1407')
->setBillingCity('Tampico')
->setBillingCountry('MX')
// Risk Params
->setRiskUserId('123456');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.apm.PProRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
PProRequest request = new PProRequest();
request.setTransactionId("119643250547501c79d8295");
request.setPaymentType("safetypay");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setReturnSuccessUrl(new URL("http://www.example.com/success"));
request.setReturnFailureUrl(new URL("http://www.example.com/failure"));
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setConsumerReference("");
request.setNationalId("");
request.setBirthDate("");
request.setCustomerEmail("travis@example.com");
// Billing Address
request.setBillingFirstname("Barney");
request.setBillingLastname("Rubble");
request.setBillingPrimaryAddress("14, Nerazdelni str");
request.setBillingZipCode("1407");
request.setBillingCity("Tampico");
request.setBillingCountry("MX");
// Risk Params
request.setRiskUserId("123456");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.ppro(
{
"transaction_id": "119643250547501c79d8295",
"payment_type": "safetypay",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"return_success_url": "http://www.example.com/success",
"return_failure_url": "http://www.example.com/failure",
"amount": "100",
"currency": "USD",
"consumer_reference": null,
"national_id": null,
"birth_date": null,
"customer_email": "travis@example.com",
"billing_address": {
"first_name": "Barney",
"last_name": "Rubble",
"address1": "14, Nerazdelni str",
"zip_code": "1407",
"city": "Tampico",
"country": "MX"
},
"risk_params": {
"user_id": "123456"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>ppro</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<payment_type>safetypay</payment_type>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<amount>100</amount>
<currency>USD</currency>
<payment_transaction>consumer_reference</payment_transaction>
<payment_transaction>national_id</payment_transaction>
<payment_transaction>birth_date</payment_transaction>
<customer_email>travis@example.com</customer_email>
<billing_address>
<first_name>Barney</first_name>
<last_name>Rubble</last_name>
<address1>14, Nerazdelni str</address1>
<zip_code>1407</zip_code>
<city>Tampico</city>
<country>MX</country>
</billing_address>
<risk_params>
<user_id>123456</user_id>
</risk_params>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | ppro or safetypay. Contact tech support at tech-support@emerchantpay.com for more details. |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
payment_type | required1 | safetypay | SafetyPay. Contact tech support for more details |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
return_pending_url | optional | url | URL where customer is sent to when asynchronous payment is pending confirmation |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
customer_email | required | e-mail address | Must contain valid e-mail of customer |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
1 - payment_type must be submitted only when the transaction type is set to ppro
Supported countries:
Country |
---|
AT |
BE |
BR |
CL |
CO |
DE |
EC |
ES |
MX |
NL |
PE |
PR |
Supported currencies:
Currency Code |
---|
EUR |
USD |
Successful Response
stdClass Object
(
[transaction_type] => safetypay
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:54.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>safetypay</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<timestamp>2025-01-16T10:23:54Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response
stdClass Object
(
[transaction_type] => ppro
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:54.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[ppro]>
<status content=[pending_async]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<redirect_url content=[https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61]>
<timestamp content=[2025-01-16T10:23:54Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "ppro",
status: "pending_async",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
technical_message: "Transaction successful!",
message: "Transaction successful!",
redirect_url: "https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61",
timestamp: "2025-01-16T10:23:54Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>ppro</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<timestamp>2025-01-16T10:23:54Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>ppro/safetypay</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:54Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Santander
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\OnlineBankingPayments\Santander');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setReturnPendingUrl('http://www.example.com/pending')
->setAmount('100')
->setCurrency('USD')
->setConsumerReference('barney_rubble')
->setNationalId('8812128812')
->setBirthDate('30-12-1992')
->setCustomerEmail('travis@example.com')
// Billing Address
->setBillingFirstName('Barney')
->setBillingLastName('Rubble')
->setBillingAddress1('14, Nerazdelni str')
->setBillingZipCode('1407')
->setBillingCity('Rio de Janeiro')
->setBillingCountry('BR')
// Risk Params
->setRiskUserId('123456');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>santander</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<return_pending_url>http://www.example.com/pending</return_pending_url>
<amount>100</amount>
<currency>USD</currency>
<consumer_reference>barney_rubble</consumer_reference>
<national_id>8812128812</national_id>
<birth_date>30-12-1992</birth_date>
<customer_email>travis@example.com</customer_email>
<billing_address>
<first_name>Barney</first_name>
<last_name>Rubble</last_name>
<address1>14, Nerazdelni str</address1>
<zip_code>1407</zip_code>
<city>Rio de Janeiro</city>
<country>BR</country>
</billing_address>
<risk_params>
<user_id>123456</user_id>
</risk_params>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: santander |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
return_pending_url | optional | url | URL where customer is sent to when asynchronous payment is pending confirmation |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
consumer_reference | required | string(20) | Consumer reference is a unique consumer identifier |
national_id | required | string(20) | National ID of the consumer. See Document ID Parameter for more details. |
birth_date | optional | string(20) | Birth date of the customer |
customer_email | required | e-mail address | Must contain valid e-mail of customer |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported countries:
Country |
---|
AR |
BR |
MX |
CL |
Successful Response
stdClass Object
(
[transaction_type] => santander
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:54.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>santander</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<timestamp>2025-01-16T10:23:54Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => santander
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 110
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:54.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>santander</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:54Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
SDD Init Recurring Sale
An SddInitRecurringSale transaction initializes a recurring payment and is equal to a normal SddSaleTransaction except that it can be referenced as ”initial” transaction in a SddRecurringSale transaction.
Note that if an SddInitRecurringSale is fully refunded, the recurring series is stopped and no more SddRecurringSales can be performed for that recurring series.
If an SddInitRecurringSale is partially refunded, the recurring series can continue with more SddRecurringSales.
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\SDD\Recurring\InitRecurringSale');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnPendingUrl('http://www.example.com/pending')
->setReturnFailureUrl('http://www.example.com/failure')
->setAmount('100')
->setCurrency('EUR')
->setIban('DE09100100101234567891')
->setBic('PBNKDEFFXXX')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingCountry('DE');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.sdd.SDDInitRecurringSaleRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
SDDInitRecurringSaleRequest request = new SDDInitRecurringSaleRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setReturnSuccessUrl(new URL("http://www.example.com/success"));
request.setReturnPendingUrl(new URL("http://www.example.com/pending"));
request.setReturnFailureUrl(new URL("http://www.example.com/failure"));
request.setAmount(new BigDecimal(100));
request.setCurrency("EUR");
request.setIban("DE09100100101234567891");
request.setBic("PBNKDEFFXXX");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingCountry("DE");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.sdd_init_recurring_sale(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"return_success_url": "http://www.example.com/success",
"return_pending_url": "http://www.example.com/pending",
"return_failure_url": "http://www.example.com/failure",
"amount": "100",
"currency": "EUR",
"iban": "DE09100100101234567891",
"bic": "PBNKDEFFXXX",
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"country": "DE"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>sdd_init_recurring_sale</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_pending_url>http://www.example.com/pending</return_pending_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<amount>100</amount>
<currency>EUR</currency>
<iban>DE09100100101234567891</iban>
<bic>PBNKDEFFXXX</bic>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<country>DE</country>
</billing_address>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: sdd_init_recurring_sale |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | required | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required* | url | URL where customer is sent to after successful payment |
return_pending_url | required* | url | URL where customer is sent to when asynchronous payment is pending confirmation |
return_failure_url | required* | url | URL where customer is sent to after unsuccessful payment |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
iban | required | string(34) | Customer’s IBAN number |
bic | optional | string(11) | SWIFT/BIC code of the customer’s bank |
customer_email | required* | e-mail address | Must contain valid e-mail of customer |
customer_phone | required* | string(32) | Must contain valid phone number of customer |
billing_address | required | See Required vs Optional API params for details | |
first_name | required | string(255) | Customer first name |
last_name | required | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
neighborhood | optional | string(255) | Neighborhood |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported countries:
Country Name | Country Code |
---|---|
Austria | AT |
Belgium | BE |
Cyprus | CY |
Estonia | EE |
Finland | FI |
France | FR |
Germany | DE |
Greece | GR |
Ireland | IE |
Italy | IT |
Latvia | LV |
Lithuania | LT |
Luxembourg | LU |
Malta | MT |
Monaco | MC |
Netherlands | NL |
Portugal | PT |
Slovakia | SK |
San Marino | SM |
Slovenia | SI |
Spain | ES |
Successful Response
stdClass Object
(
[transaction_type] => sdd_init_recurring_sale
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:54.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => EUR
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[sdd_init_recurring_sale]>
<status content=[pending_async]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<redirect_url content=[https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61]>
<timestamp content=[2025-01-16T10:23:54Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[EUR]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "sdd_init_recurring_sale",
status: "pending_async",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
technical_message: "Transaction successful!",
message: "Transaction successful!",
redirect_url: "https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61",
timestamp: "2025-01-16T10:23:54Z",
descriptor: "Descriptor one",
amount: "100",
currency: "EUR",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>sdd_init_recurring_sale</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<timestamp>2025-01-16T10:23:54Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>EUR</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => sdd_init_recurring_sale
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 110
[message] => Please check input data for errors!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:54.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => EUR
[sent_to_acquirer] => false
)
<payment_response content=[
<transaction_type content=[sdd_init_recurring_sale]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<code content=[110]>
<message content=[Please check input data for errors!]>
<timestamp content=[2025-01-16T10:23:54Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[EUR]>
<sent_to_acquirer content=[false]>
]>
{
transaction_type: "sdd_init_recurring_sale",
status: "error",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
code: "110",
message: "Please check input data for errors!",
timestamp: "2025-01-16T10:23:54Z",
descriptor: "Descriptor one",
amount: "100",
currency: "EUR",
sent_to_acquirer: "false",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>sdd_init_recurring_sale</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<message>Please check input data for errors!</message>
<timestamp>2025-01-16T10:23:54Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>EUR</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
SDD Recurring Sale
A SddRecurringSale transaction is a ”repeated” transaction which follows and references a SddInitRecurringSale transaction.
The bank account data is omitted.
Note that SddRecurringSales can be partially or fully refunded if configuration allows it, and this will not stop the sdd recurring series.
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\SDD\Recurring\RecurringSale');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('EUR')
->setReferenceId('2ee4287e67971380ef7f97d5743bb523');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.sdd.SDDRecurringSaleRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
SDDRecurringSaleRequest request = new SDDRecurringSaleRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("EUR");
request.setReferenceId("2ee4287e67971380ef7f97d5743bb523");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.sdd_recurring_sale(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "EUR",
"reference_id": "2ee4287e67971380ef7f97d5743bb523"
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>sdd_recurring_sale</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>EUR</currency>
<reference_id>2ee4287e67971380ef7f97d5743bb523</reference_id>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: sdd_recurring_sale |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | required | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
reference_id | required | string(32) | Unique id returned by corresponding transaction |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
required* = conditionally required
Successful Response
stdClass Object
(
[transaction_type] => sdd_recurring_sale
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:54.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => EUR
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[sdd_recurring_sale]>
<status content=[pending_async]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<timestamp content=[2025-01-16T10:23:54Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[EUR]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "sdd_recurring_sale",
status: "pending_async",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
technical_message: "Transaction successful!",
message: "Transaction successful!",
timestamp: "2025-01-16T10:23:54Z",
descriptor: "Descriptor one",
amount: "100",
currency: "EUR",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>sdd_recurring_sale</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:54Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>EUR</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => sdd_recurring_sale
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 320
[technical_message] => amount is missing!
[message] => Please check input data for errors!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:54.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => EUR
)
<payment_response content=[
<transaction_type content=[sdd_recurring_sale]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<code content=[320]>
<technical_message content=[amount is missing!]>
<message content=[Please check input data for errors!]>
<timestamp content=[2025-01-16T10:23:54Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[EUR]>
]>
{
transaction_type: "sdd_recurring_sale",
status: "error",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
code: "320",
technical_message: "amount is missing!",
message: "Please check input data for errors!",
timestamp: "2025-01-16T10:23:54Z",
descriptor: "Descriptor one",
amount: "100",
currency: "EUR",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>sdd_recurring_sale</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>320</code>
<technical_message>amount is missing!</technical_message>
<message>Please check input data for errors!</message>
<timestamp>2025-01-16T10:23:54Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>EUR</currency>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
SDD Refund
SddRefunds allow to return already billed amounts to customers.
The amount can be fully refunded only, no partial refunds are allowed. Note that SDD refunds can only be done on former approved SDD transactions
Therefore, the reference_id for the corresponding transaction is mandatory.
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\SDD\Refund');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setAmount('100')
->setCurrency('EUR')
->setReferenceId('2ee4287e67971380ef7f97d5743bb523');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.sdd.SDDRefundRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
SDDRefundRequest request = new SDDRefundRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setAmount(new BigDecimal(100));
request.setCurrency("EUR");
request.setReferenceId("2ee4287e67971380ef7f97d5743bb523");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.sdd_refund(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"amount": "100",
"currency": "EUR",
"reference_id": "2ee4287e67971380ef7f97d5743bb523"
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>sdd_refund</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<amount>100</amount>
<currency>EUR</currency>
<reference_id>2ee4287e67971380ef7f97d5743bb523</reference_id>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: sdd_refund |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | required | string(255) | Description of the transaction for later use. |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
reference_id | required | string(32) | Unique id returned by corresponding transaction |
required* = conditionally required
Successful Response
stdClass Object
(
[transaction_type] => sdd_refund
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:54.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => EUR
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[sdd_refund]>
<status content=[pending_async]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<timestamp content=[2025-01-16T10:23:54Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[EUR]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "sdd_refund",
status: "pending_async",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
technical_message: "Transaction successful!",
message: "Transaction successful!",
timestamp: "2025-01-16T10:23:54Z",
descriptor: "Descriptor one",
amount: "100",
currency: "EUR",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>sdd_refund</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:54Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>EUR</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => sdd_refund
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 320
[technical_message] => amount is missing!
[message] => Please check input data for errors!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:54.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => EUR
[sent_to_acquirer] => false
)
<payment_response content=[
<transaction_type content=[sdd_refund]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<code content=[320]>
<technical_message content=[amount is missing!]>
<message content=[Please check input data for errors!]>
<timestamp content=[2025-01-16T10:23:54Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[EUR]>
<sent_to_acquirer content=[false]>
]>
{
transaction_type: "sdd_refund",
status: "error",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
code: "320",
technical_message: "amount is missing!",
message: "Please check input data for errors!",
timestamp: "2025-01-16T10:23:54Z",
descriptor: "Descriptor one",
amount: "100",
currency: "EUR",
sent_to_acquirer: "false",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>sdd_refund</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>320</code>
<technical_message>amount is missing!</technical_message>
<message>Please check input data for errors!</message>
<timestamp>2025-01-16T10:23:54Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>EUR</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
SDD Sale
The status of Sepa Direct Debit transactions is not available right after a transaction is made. Merchants receive the status of SDD transaction at 8:30 am (CET), 10:30 am (CET), 3:30 pm (CET) and 7:30 pm (CET). The merchant should have enabled notifications
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\SDD\Sale');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnPendingUrl('http://www.example.com/pending')
->setReturnFailureUrl('http://www.example.com/failure')
->setAmount('100')
->setCurrency('EUR')
->setIban('DE09100100101234567891')
->setBic('PBNKDEFFXXX')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingCountry('DE');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.sdd.SDDSaleRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
SDDSaleRequest request = new SDDSaleRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setReturnSuccessUrl(new URL("http://www.example.com/success"));
request.setReturnPendingUrl(new URL("http://www.example.com/pending"));
request.setReturnFailureUrl(new URL("http://www.example.com/failure"));
request.setAmount(new BigDecimal(100));
request.setCurrency("EUR");
request.setIban("DE09100100101234567891");
request.setBic("PBNKDEFFXXX");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingCountry("DE");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.sdd_sale(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"return_success_url": "http://www.example.com/success",
"return_pending_url": "http://www.example.com/pending",
"return_failure_url": "http://www.example.com/failure",
"amount": "100",
"currency": "EUR",
"iban": "DE09100100101234567891",
"bic": "PBNKDEFFXXX",
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"country": "DE"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>sdd_sale</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_pending_url>http://www.example.com/pending</return_pending_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<amount>100</amount>
<currency>EUR</currency>
<iban>DE09100100101234567891</iban>
<bic>PBNKDEFFXXX</bic>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<country>DE</country>
</billing_address>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: sdd_sale |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | required | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required* | url | URL where customer is sent to after successful payment |
return_pending_url | required* | url | URL where customer is sent to when asynchronous payment is pending confirmation |
return_failure_url | required* | url | URL where customer is sent to after unsuccessful payment |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
iban | required | string(34) | Customer’s IBAN number |
bic | optional | string(11) | SWIFT/BIC code of the customer’s bank |
company_name | optional | string(255) | Name of the company. |
mandate_reference | optional | string(255) | Reference which contains the SEPAExpress paper mandate. |
billing_address | required | See Required vs Optional API params for details | |
first_name | required | string(255) | Customer first name |
last_name | required | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
neighborhood | optional | string(255) | Neighborhood |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
*Supported countries: *
The supported countries are the same as SDD Init Recurring Sale.
Successful Response
stdClass Object
(
[transaction_type] => sdd_sale
[status] => approved
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:54.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => EUR
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[sdd_sale]>
<status content=[approved]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<redirect_url content=[https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61]>
<timestamp content=[2025-01-16T10:23:54Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[EUR]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "sdd_sale",
status: "approved",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
technical_message: "Transaction successful!",
message: "Transaction successful!",
redirect_url: "https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61",
timestamp: "2025-01-16T10:23:54Z",
descriptor: "Descriptor one",
amount: "100",
currency: "EUR",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>sdd_sale</transaction_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<timestamp>2025-01-16T10:23:54Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>EUR</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => sdd_sale
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 340
[message] => expiration_year is invalid
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:54.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => EUR
[sent_to_acquirer] => false
)
<payment_response content=[
<transaction_type content=[sdd_sale]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<code content=[340]>
<message content=[expiration_year is invalid]>
<timestamp content=[2025-01-16T10:23:54Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[EUR]>
<sent_to_acquirer content=[false]>
]>
{
transaction_type: "sdd_sale",
status: "error",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
code: "340",
message: "expiration_year is invalid",
timestamp: "2025-01-16T10:23:54Z",
descriptor: "Descriptor one",
amount: "100",
currency: "EUR",
sent_to_acquirer: "false",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>sdd_sale</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>340</code>
<message>expiration_year is invalid</message>
<timestamp>2025-01-16T10:23:54Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>EUR</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
Sofort
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Alternatives\Sofort');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setNotificationUrl('https://www.example.com/notification')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setReturnPendingUrl('http://www.example.com/pending')
->setAmount('100')
->setCurrency('EUR')
->setCustomerEmail('travis@example.com')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Berlin')
->setBillingCountry('DE');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.apm.SofortRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
SofortRequest request = new SofortRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setNotificationUrl(new URL("https://www.example.com/notification"));
request.setReturnSuccessUrl(new URL("http://www.example.com/success"));
request.setReturnFailureUrl(new URL("http://www.example.com/failure"));
request.setReturnPendingUrl(new URL("http://www.example.com/pending"));
request.setAmount(new BigDecimal(100));
request.setCurrency("EUR");
request.setCustomerEmail("travis@example.com");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Berlin");
request.setBillingCountry("DE");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.sofort(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"notification_url": "https://www.example.com/notification",
"return_success_url": "http://www.example.com/success",
"return_failure_url": "http://www.example.com/failure",
"return_pending_url": "http://www.example.com/pending",
"amount": "100",
"currency": "EUR",
"customer_email": "travis@example.com",
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Berlin",
"country": "DE"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>sofort</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<notification_url>https://www.example.com/notification</notification_url>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<return_pending_url>http://www.example.com/pending</return_pending_url>
<amount>100</amount>
<currency>EUR</currency>
<customer_email>travis@example.com</customer_email>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Berlin</city>
<country>DE</country>
</billing_address>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: sofort |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
notification_url | optional | url | URL at merchant where gateway sends outcome of transaction. |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
return_pending_url | optional | url | URL where customer is sent to when asynchronous payment is pending confirmation |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
customer_email | required | e-mail address | Must contain valid e-mail of customer |
customer_phone | required* | string(32) | Must contain valid phone number of customer |
iban | optional | string(24) | International bank account number of the customer |
bic | optional | string(12) | Bank Identifier Code |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported countries:
Country name | Country code |
---|---|
Austria | AT |
Belgium | BE |
Germany | DE |
Italy | IT |
Netherlands | NL |
Poland | PL |
Spain | ES |
Switzerland | CH |
Successful Response
stdClass Object
(
[transaction_type] => sofort
[status] => approved
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:54.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => EUR
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[sofort]>
<status content=[approved]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<redirect_url content=[https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61]>
<timestamp content=[2025-01-16T10:23:54Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[EUR]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "sofort",
status: "approved",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
technical_message: "Transaction successful!",
message: "Transaction successful!",
redirect_url: "https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61",
timestamp: "2025-01-16T10:23:54Z",
descriptor: "Descriptor one",
amount: "100",
currency: "EUR",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>sofort</transaction_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<timestamp>2025-01-16T10:23:54Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>EUR</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => sofort
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 110
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:54.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => EUR
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[sofort]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<code content=[110]>
<message content=[Something went wrong, please contact support!]>
<timestamp content=[2025-01-16T10:23:54Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[EUR]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "sofort",
status: "error",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
code: "110",
message: "Something went wrong, please contact support!",
timestamp: "2025-01-16T10:23:54Z",
descriptor: "Descriptor one",
amount: "100",
currency: "EUR",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>sofort</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:54Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>EUR</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Trustly Sale
Trustly is an oBeP-style alternative payment method that allows you to pay directly with your ebank account.
After initiating a transaction, Trustly will redirect the consumer to Trustly bank page. There the consumer will have to select his/her bank and log in with the regular access codes, choose the account and complete payment.
Account_ID parameter will be returned to the merchant notification url. Account_ID identifies each user’s bank account once it is processed through Trustly system, it can be stored by the merchant and further used as a reference on the Bank-Pay-out call.
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Alternatives\Trustly\Sale');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setPaymentType('')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setNotificationUrl('https://www.example.com/notification')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setReturnSuccessUrlTarget('self')
->setAmount('100')
->setCurrency('EUR')
->setCustomerEmail('travis@example.com')
// Billing Address
->setBillingFirstName('Max')
->setBillingLastName('Mustermann')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Berlin')
->setBillingCountry('DE')
->setUserId('')
->setAccountId('');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.apm.TrustlySaleRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
TrustlySaleRequest request = new TrustlySaleRequest();
request.setTransactionId("119643250547501c79d8295");
request.setPaymentType("");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setNotificationUrl(new URL("https://www.example.com/notification"));
request.setReturnSuccessUrl(new URL("http://www.example.com/success"));
request.setReturnFailureUrl(new URL("http://www.example.com/failure"));
request.setReturnSuccessUrlTarget("self");
request.setAmount(new BigDecimal(100));
request.setCurrency("EUR");
request.setCustomerEmail("travis@example.com");
// Billing Address
request.setBillingFirstname("Max");
request.setBillingLastname("Mustermann");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Berlin");
request.setBillingCountry("DE");
request.setUserId("");
request.setAccountId("");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.trustly_sale(
{
"transaction_id": "119643250547501c79d8295",
"payment_type": null,
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"notification_url": "https://www.example.com/notification",
"return_success_url": "http://www.example.com/success",
"return_failure_url": "http://www.example.com/failure",
"return_success_url_target": "self",
"amount": "100",
"currency": "EUR",
"customer_email": "travis@example.com",
"billing_address": {
"first_name": "Max",
"last_name": "Mustermann",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Berlin",
"country": "DE"
},
"business_attributes": {
"event_start_date": "17-02-2025",
"event_end_date": "26-02-2025",
"event_organizer_id": "20192375",
"event_id": "1912"
},
"user_id": null,
"account_id": null
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>trustly_sale</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<payment_transaction>payment_type</payment_transaction>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<notification_url>https://www.example.com/notification</notification_url>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<return_success_url_target>self</return_success_url_target>
<amount>100</amount>
<currency>EUR</currency>
<customer_email>travis@example.com</customer_email>
<billing_address>
<first_name>Max</first_name>
<last_name>Mustermann</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Berlin</city>
<country>DE</country>
</billing_address>
<business_attributes>
<event_start_date>17-02-2025</event_start_date>
<event_end_date>26-02-2025</event_end_date>
<event_organizer_id>20192375</event_organizer_id>
<event_id>1912</event_id>
</business_attributes>
<payment_transaction>user_id</payment_transaction>
<payment_transaction>account_id</payment_transaction>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: trustly_sale |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
return_success_url_target | optional | string(255) | URL target for successful payment in Trustly iFrame. Possible values: self, parent, top. |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
customer_email | required | e-mail address | Must contain valid e-mail of customer |
customer_phone | required* | string(32) | Must contain valid phone number of customer |
user_id | required* | string(255) | Unique user identifier defined by merchant in their own system. ID, username, hash or anything uniquely identifying the consumer requesting the deposit. Must be static per each consumer for any type of transaction where this consumer is involved (trustly_sale, bank pay_out, register_account, select account). |
birth_date | optional | dd-mm-yyyy | Date of birth of the beneficiary, or organisational number for the organisation. |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
business_attributes | required* | Check business attributes section. | |
event_start_date | required* | dd-mm-yyyy | The date when event starts in format dd-mm-yyyy |
event_end_date | required* | dd-mm-yyyy | The date when event ends in format dd-mm-yyyy |
event_organizer_id | required* | string | |
event_id | required* | string | |
date_of_order | required* | dd-mm-yyyy | The date when order was placed in format dd-mm-yyyy |
delivery_date | required* | dd-mm-yyyy | Date of the expected delivery in format dd-mm-yyyy |
name_of_the_supplier | required* | string | |
account_id | required | string(255) | Unique user Account identifier at Trustly system, which is used to process a Bank Pay-out call to the consumer, without reference to initial deposit transaction. You will receive this after Trustly_Sale and Select Account call on your notification URL. You will receive this as a response on Trustly Register Account option. |
required* = conditionally required
Supported countries:
Country name | Country code |
---|---|
Austria | AT |
Belgium | BE |
Czech Republic | CZ |
Denmark | DK |
Estonia | EE |
Finland | FI |
Germany | DE |
Latvia | LV |
Lithuania | LT |
Netherlands | NL |
Norway | NO |
Poland | PL |
Slovakia | SK |
Spain | ES |
Sweden | SE |
United Kingdom | GB |
Successful Response
stdClass Object
(
[transaction_type] => trustly_sale
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:55.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => EUR
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[trustly_sale]>
<status content=[pending_async]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<redirect_url content=[https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61]>
<timestamp content=[2025-01-16T10:23:55Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[EUR]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "trustly_sale",
status: "pending_async",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
technical_message: "Transaction successful!",
message: "Transaction successful!",
redirect_url: "https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61",
timestamp: "2025-01-16T10:23:55Z",
descriptor: "Descriptor one",
amount: "100",
currency: "EUR",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>trustly_sale</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<timestamp>2025-01-16T10:23:55Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>EUR</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => trustly_sale
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 110
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:55.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => EUR
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[trustly_sale]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<code content=[110]>
<message content=[Something went wrong, please contact support!]>
<timestamp content=[2025-01-16T10:23:55Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[EUR]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "trustly_sale",
status: "error",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
code: "110",
message: "Something went wrong, please contact support!",
timestamp: "2025-01-16T10:23:55Z",
descriptor: "Descriptor one",
amount: "100",
currency: "EUR",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>trustly_sale</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:55Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>EUR</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
UPI
UPI (Unified Payment Interface) transaction is an alternative payment method which allows users to transfer money between bank accounts.
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>upi</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<notification_url>https://www.example.com/notification</notification_url>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<amount>50000</amount>
<currency>INR</currency>
<customer_email>travis@example.com</customer_email>
<virtual_payment_address>someone@bank</virtual_payment_address>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: upi |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | required* | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
customer_email | required* | e-mail address | Must contain valid e-mail of customer |
customer_phone | required* | string(32) | Must contain valid phone number of customer |
document_id | required* | string(255) | Document ID value. |
virtual_payment_address | required* | string(255) | Virtual Payment Address (VPA) of the customer, format: someone@bank |
user_category | required* | string | User category. If missing, 'default' will be used. |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported currencies
Currency name | Currency code |
---|---|
Indian rupee | INR |
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>upi</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<timestamp>2025-01-16T10:23:55Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>50000</amount>
<currency>INR</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>upi</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<technical_message>amount is missing</technical_message>
<message>Please check input data for errors!</message>
<timestamp>2025-01-16T10:23:55Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>50000</amount>
<currency>INR</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Webpay
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\OnlineBankingPayments\Webpay');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setReturnPendingUrl('http://www.example.com/pending')
->setAmount('100')
->setCurrency('USD')
->setConsumerReference('john_doe')
->setNationalId('8812128812')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Barney')
->setBillingLastName('Rubble')
->setBillingAddress1('14, Nerazdelni str')
->setBillingZipCode('1407')
->setBillingCity('Santiago')
->setBillingCountry('CL');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>webpay</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<return_pending_url>http://www.example.com/pending</return_pending_url>
<amount>100</amount>
<currency>USD</currency>
<consumer_reference>john_doe</consumer_reference>
<national_id>8812128812</national_id>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<billing_address>
<first_name>Barney</first_name>
<last_name>Rubble</last_name>
<address1>14, Nerazdelni str</address1>
<zip_code>1407</zip_code>
<city>Santiago</city>
<country>CL</country>
</billing_address>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: webpay |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
return_pending_url | optional | url | URL where customer is sent to when asynchronous payment is pending confirmation |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
consumer_reference | required | string(20) | Consumer reference is a unique consumer identifier |
national_id | required | string(20) | National ID of the consumer. See Document ID Parameter for more details. |
birth_date | optional | dd-mm-yyyy | Required for Visa only when MCC is a Financial Services one (e.g. MCC 6012) |
customer_email | required | e-mail address | Must contain valid e-mail of customer |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported countries
Country Name | Country code |
---|---|
Chile | CL |
Successful Response
stdClass Object
(
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[technical_message] => Transaction successful!
[message] => Transaction successful!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:55.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:55Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[status] => error
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 110
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:55.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => false
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<status>error</status>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:55Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Davivienda
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\OnlineBankingPayments\Davivienda');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setReturnPendingUrl('http://www.example.com/pending')
->setAmount('100')
->setCurrency('USD')
->setConsumerReference('barney_rumble')
->setNationalId('8812128812')
->setBirthDate('30-12-1992')
->setCustomerEmail('barney@example.com')
// Billing Address
->setBillingFirstName('Barney')
->setBillingLastName('Rubble')
->setBillingAddress1('14, Nerazdelni str')
->setBillingZipCode('1407')
->setBillingCity('Bogota')
->setBillingCountry('CO')
// Risk Params
->setRiskUserId('123456');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>davivienda</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<return_pending_url>http://www.example.com/pending</return_pending_url>
<amount>100</amount>
<currency>USD</currency>
<consumer_reference>barney_rumble</consumer_reference>
<national_id>8812128812</national_id>
<birth_date>30-12-1992</birth_date>
<customer_email>barney@example.com</customer_email>
<billing_address>
<first_name>Barney</first_name>
<last_name>Rubble</last_name>
<address1>14, Nerazdelni str</address1>
<zip_code>1407</zip_code>
<city>Bogota</city>
<country>CO</country>
</billing_address>
<risk_params>
<user_id>123456</user_id>
</risk_params>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: davivienda |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
return_pending_url | optional | url | URL where customer is sent to when asynchronous payment is pending confirmation |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
consumer_reference | required | string(20) | Consumer reference is a unique consumer identifier |
national_id | required | string(20) | National ID of the consumer. See Document ID Parameter for more details. |
birth_date | optional | dd-mm-yyyy | Required for Visa only when MCC is a Financial Services one (e.g. MCC 6012) |
customer_email | required | e-mail address | Must contain valid e-mail of customer |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported countries:
Country |
---|
CO |
Successful Response
stdClass Object
(
[transaction_type] => davivienda
[status] => pending_async
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[technical_message] => Transaction successful!
[message] => Transaction successful!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:55.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>davivienda</transaction_type>
<status>pending_async</status>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:55Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => davivienda
[status] => error
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 110
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:55.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>davivienda</transaction_type>
<status>error</status>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:55Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Cash Payments
Cash
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>cash</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<notification_url>https://www.example.com/notification</notification_url>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<amount>50000</amount>
<currency>MXN</currency>
<customer_email>travis@example.com</customer_email>
<payment_type>scotiabank</payment_type>
<document_id>8812128812</document_id>
<billing_address>
<first_name>Barney</first_name>
<last_name>Rubble</last_name>
<address1>14, Nerazdelni str</address1>
<zip_code>1407</zip_code>
<city>Monterrey</city>
<country>MX</country>
</billing_address>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: cash |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
customer_email | required* | e-mail address | Must contain valid e-mail of customer |
customer_phone | required* | string(32) | Must contain valid phone number of customer |
payment_type | required | string | The payment type describes desired payment method. Must contain one of the allowed Payment types, but they may vary based on the specific setup. |
document_id | required | string(255) | Document ID value. |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported currencies
Currency name | Currency code |
---|---|
Mexican Peso | MXN |
Cash Payment Types
Payment Type Name | Payment Type Code |
---|---|
7 Eleven | seven_eleven |
Bancomer | bancomer |
Farmacias del Dr. Ahorro | pharmacies_del_dr_ahorro |
Farmacias Santa Maria | pharmacies_santa_maria |
OXXO | oxxo |
Scotiabank | scotiabank |
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>cash</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<transaction_id>119643250547501c79d8295</transaction_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<timestamp>2025-01-16T10:23:55Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>50000</amount>
<currency>MXN</currency>
<payment_type>scotiabank</payment_type>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
transaction_id | string(255) | Unique transaction id defined by merchant |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
redirect_url | url | The redirect URL to the provider page for payment finalization. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
payment_type | string | The payment type describes the method used to process cash transaction. See Payment types. |
Error Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>cash</transaction_type>
<status>error</status>
<mode>live</mode>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<transaction_id>119643250547501c79d8295</transaction_id>
<code>110</code>
<technical_message>amount is missing</technical_message>
<message>Please check input data for errors!</message>
<timestamp>2025-01-16T10:23:55Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>50000</amount>
<currency>MXN</currency>
<payment_type>scotiabank</payment_type>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
transaction_id | string(255) | Unique transaction id defined by merchant |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
payment_type | string | The payment type describes the method used to process cash transaction. See Payment types. |
Baloto
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\CashPayments\Baloto');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setAmount('100')
->setCurrency('USD')
->setConsumerReference('barney_rubble')
->setNationalId('8812128812')
->setBirthDate('30-12-1992')
->setCustomerEmail('travis@example.com')
// Billing Address
->setBillingFirstName('Barney')
->setBillingLastName('Rubble')
->setBillingAddress1('14, Nerazdelni str')
->setBillingZipCode('1407')
->setBillingCity('Bogota')
->setBillingCountry('CO')
// Risk Params
->setRiskUserId('123456');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>baloto</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<amount>100</amount>
<currency>USD</currency>
<consumer_reference>barney_rubble</consumer_reference>
<national_id>8812128812</national_id>
<birth_date>30-12-1992</birth_date>
<customer_email>travis@example.com</customer_email>
<billing_address>
<first_name>Barney</first_name>
<last_name>Rubble</last_name>
<address1>14, Nerazdelni str</address1>
<zip_code>1407</zip_code>
<city>Bogota</city>
<country>CO</country>
</billing_address>
<risk_params>
<user_id>123456</user_id>
</risk_params>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: baloto |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
consumer_reference | required | string(20) | Consumer reference is a unique consumer identifier |
national_id | required | string(20) | National ID of the consumer. See Document ID Parameter for more details. |
birth_date | optional | string(20) | Birth date of the customer |
customer_email | required | e-mail address | Must contain valid e-mail of customer |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported countries:
Country |
---|
CO |
Successful Response
stdClass Object
(
[transaction_type] => baloto
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:55.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>baloto</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<timestamp>2025-01-16T10:23:55Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => baloto
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 110
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:55.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>baloto</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:55Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Banco de Occidente
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\CashPayments\BancoDeOccidente');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setAmount('100')
->setCurrency('USD')
->setNationalId('8812128812')
->setBirthDate('30-12-1992')
->setCustomerEmail('travis@example.com')
// Billing Address
->setBillingFirstName('Barney')
->setBillingLastName('Rubble')
->setBillingAddress1('14, Nerazdelni str')
->setBillingZipCode('1407')
->setBillingCity('Bogota')
->setBillingCountry('CO')
// Risk Params
->setRiskUserId('123456');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>banco_de_occidente</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<amount>100</amount>
<currency>USD</currency>
<national_id>8812128812</national_id>
<birth_date>30-12-1992</birth_date>
<customer_email>travis@example.com</customer_email>
<billing_address>
<first_name>Barney</first_name>
<last_name>Rubble</last_name>
<address1>14, Nerazdelni str</address1>
<zip_code>1407</zip_code>
<city>Bogota</city>
<country>CO</country>
</billing_address>
<risk_params>
<user_id>123456</user_id>
</risk_params>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: banco_de_occidente |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
national_id | required | string(20) | National ID of the consumer. See Document ID Parameter for more details. |
birth_date | optional | string(20) | Birth date of the customer |
customer_email | required | e-mail address | Must contain valid e-mail of customer |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported countries:
Country |
---|
CO |
Successful Response
stdClass Object
(
[transaction_type] => banco_de_occidente
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:55.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>banco_de_occidente</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<timestamp>2025-01-16T10:23:55Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => banco_de_occidente
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 110
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:55.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>banco_de_occidente</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:55Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Boleto
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\CashPayments\Boleto');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setAmount('100')
->setCurrency('USD')
->setConsumerReference('barney_rubble')
->setNationalId('8812128812')
->setBirthDate('30-12-1992')
->setCustomerEmail('travis@example.com')
// Billing Address
->setBillingFirstName('Barney')
->setBillingLastName('Rubble')
->setBillingAddress1('14, Nerazdelni str')
->setBillingZipCode('1407')
->setBillingCity('Rio de Janeiro')
->setBillingCountry('BR')
// Risk Params
->setRiskUserId('123456');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>boleto</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<amount>100</amount>
<currency>USD</currency>
<consumer_reference>barney_rubble</consumer_reference>
<national_id>8812128812</national_id>
<birth_date>30-12-1992</birth_date>
<customer_email>travis@example.com</customer_email>
<billing_address>
<first_name>Barney</first_name>
<last_name>Rubble</last_name>
<address1>14, Nerazdelni str</address1>
<zip_code>1407</zip_code>
<city>Rio de Janeiro</city>
<country>BR</country>
</billing_address>
<risk_params>
<user_id>123456</user_id>
</risk_params>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: boleto |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
consumer_reference | required | string(20) | Consumer reference is a unique consumer identifier |
national_id | required | string(20) | National ID of the consumer. See Document ID Parameter for more details. |
birth_date | optional | string(20) | Birth date of the customer |
customer_email | required | e-mail address | Must contain valid e-mail of customer |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported countries:
Country |
---|
BR |
Successful Response
stdClass Object
(
[transaction_type] => boleto
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:55.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
[barcode] => 03395929800000015009008773800000000000270101
[ticket_expiry_date] => 04052022
[digitable_line] => 03399008707380000000900004301016489750000019000
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>boleto</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<timestamp>2025-01-16T10:23:55Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
<barcode>03395929800000015009008773800000000000270101</barcode>
<ticket_expiry_date>04052022</ticket_expiry_date>
<digitable_line>03399008707380000000900004301016489750000019000</digitable_line>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
barcode | string(44) | Barcode digit value acquired after transaction process |
ticket_expiry_date | string(8) | Transaction expiry date in format %d%m%Y |
digitable_line | string(47) | Digitable line value acquired after transaction process |
Error Response
stdClass Object
(
[transaction_type] => boleto
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 110
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:55.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>boleto</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:55Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Efecty
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\CashPayments\Efecty');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setAmount('100')
->setCurrency('USD')
->setConsumerReference('barney_rumble')
->setNationalId('8812128812')
->setBirthDate('30-12-1992')
->setCustomerEmail('barney@example.com')
// Billing Address
->setBillingFirstName('Barney')
->setBillingLastName('Rubble')
->setBillingAddress1('14, Nerazdelni str')
->setBillingZipCode('1407')
->setBillingCity('Bogota')
->setBillingCountry('CO')
// Risk Params
->setRiskUserId('123456');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>efecty</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<amount>100</amount>
<currency>USD</currency>
<consumer_reference>barney_rumble</consumer_reference>
<national_id>8812128812</national_id>
<birth_date>30-12-1992</birth_date>
<customer_email>barney@example.com</customer_email>
<billing_address>
<first_name>Barney</first_name>
<last_name>Rubble</last_name>
<address1>14, Nerazdelni str</address1>
<zip_code>1407</zip_code>
<city>Bogota</city>
<country>CO</country>
</billing_address>
<risk_params>
<user_id>123456</user_id>
</risk_params>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: efecty |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
consumer_reference | required | string(20) | Consumer reference is a unique consumer identifier |
national_id | required | string(20) | National ID of the consumer. See Document ID Parameter for more details. |
birth_date | optional | dd-mm-yyyy | Required for Visa only when MCC is a Financial Services one (e.g. MCC 6012) |
customer_email | required | e-mail address | Must contain valid e-mail of customer |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported countries:
Country |
---|
CO |
Successful Response
stdClass Object
(
[transaction_type] => efecty
[status] => pending_async
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[technical_message] => Transaction successful!
[message] => Transaction successful!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:55.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>efecty</transaction_type>
<status>pending_async</status>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:55Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => efecty
[status] => error
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 110
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:55.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>efecty</transaction_type>
<status>error</status>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:55Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
OXXO
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\CashPayments\Oxxo');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setAmount('100')
->setCurrency('USD')
->setConsumerReference('barney_rumble')
->setNationalId('8812128812')
->setBirthDate('30-12-1992')
->setCustomerEmail('barney@example.com')
// Billing Address
->setBillingFirstName('Barney')
->setBillingLastName('Rubble')
->setBillingAddress1('14, Nerazdelni str')
->setBillingZipCode('1407')
->setBillingCity('Mexico City')
->setBillingCountry('MX')
// Risk Params
->setRiskUserId('123456');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>oxxo</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<amount>100</amount>
<currency>USD</currency>
<consumer_reference>barney_rumble</consumer_reference>
<national_id>8812128812</national_id>
<birth_date>30-12-1992</birth_date>
<customer_email>barney@example.com</customer_email>
<billing_address>
<first_name>Barney</first_name>
<last_name>Rubble</last_name>
<address1>14, Nerazdelni str</address1>
<zip_code>1407</zip_code>
<city>Mexico City</city>
<country>MX</country>
</billing_address>
<risk_params>
<user_id>123456</user_id>
</risk_params>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: oxxo |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
consumer_reference | required | string(20) | Consumer reference is a unique consumer identifier |
national_id | required | string(20) | National ID of the consumer. See Document ID Parameter for more details. |
birth_date | optional | dd-mm-yyyy | Required for Visa only when MCC is a Financial Services one (e.g. MCC 6012) |
customer_email | required | e-mail address | Must contain valid e-mail of customer |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported countries:
Country |
---|
MX |
Successful Response
stdClass Object
(
[transaction_type] => oxxo
[status] => pending_async
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[technical_message] => Transaction successful!
[message] => Transaction successful!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:55.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>oxxo</transaction_type>
<status>pending_async</status>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:55Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => oxxo
[status] => error
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 110
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:55.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>oxxo</transaction_type>
<status>error</status>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:55Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Pago Facil
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\CashPayments\PagoFacil');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setAmount('100')
->setCurrency('USD')
->setConsumerReference('barney_rumble')
->setNationalId('8812128812')
->setBirthDate('30-12-1992')
->setCustomerEmail('barney@example.com')
// Billing Address
->setBillingFirstName('Barney')
->setBillingLastName('Rubble')
->setBillingAddress1('14, Nerazdelni str')
->setBillingZipCode('1407')
->setBillingCity('Buenos Aires')
->setBillingCountry('AR')
// Risk Params
->setRiskUserId('123456');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>pago_facil</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<amount>100</amount>
<currency>USD</currency>
<consumer_reference>barney_rumble</consumer_reference>
<national_id>8812128812</national_id>
<birth_date>30-12-1992</birth_date>
<customer_email>barney@example.com</customer_email>
<billing_address>
<first_name>Barney</first_name>
<last_name>Rubble</last_name>
<address1>14, Nerazdelni str</address1>
<zip_code>1407</zip_code>
<city>Buenos Aires</city>
<country>AR</country>
</billing_address>
<risk_params>
<user_id>123456</user_id>
</risk_params>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: pago_facil |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
consumer_reference | required | string(20) | Consumer reference is a unique consumer identifier |
national_id | required | string(20) | National ID of the consumer. See Document ID Parameter for more details. |
birth_date | optional | dd-mm-yyyy | Required for Visa only when MCC is a Financial Services one (e.g. MCC 6012) |
customer_email | required | e-mail address | Must contain valid e-mail of customer |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported countries:
Country |
---|
AR |
Successful Response
stdClass Object
(
[transaction_type] => pago_facil
[status] => pending_async
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[technical_message] => Transaction successful!
[message] => Transaction successful!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:55.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>pago_facil</transaction_type>
<status>pending_async</status>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:55Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => pago_facil
[status] => error
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 110
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:56.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>pago_facil</transaction_type>
<status>error</status>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:56Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
PIX
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>pix</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<return_pending_url>http://www.example.com/pending</return_pending_url>
<amount>100</amount>
<currency>USD</currency>
<document_id>12345678909</document_id>
<birth_date>30-12-1992</birth_date>
<customer_email>travis@example.com</customer_email>
<billing_address>
<first_name>Barney</first_name>
<last_name>Rubble</last_name>
<address1>14, Nerazdelni str</address1>
<zip_code>1407</zip_code>
<city>Rio de Janeiro</city>
<country>BR</country>
</billing_address>
<risk_params>
<user_id>123456</user_id>
</risk_params>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: pix |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required* | url | URL where customer is sent to after successful payment |
return_failure_url | required* | url | URL where customer is sent to after unsuccessful payment |
return_pending_url | required* | url | URL where customer is sent to when asynchronous payment is pending confirmation |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
document_id | required | string(255) | Document ID of the consumer. See Document ID Parameter for more details. |
customer_email | required* | e-mail address | Must contain valid e-mail of customer |
mothers_name | optional | string(255) | Mother's name of the customer. Submitting this parameter can increase the acceptance ratio for the payment method. |
gender | optional | enum | 0 = Male, 1 = Female, 2 = Other. Submitting this parameter can increase the acceptance ratio for the payment method. |
marital_status | optional | enum | 0 = NotMarried, 1 = Married, 2 = Divorced, 3 = Separate, 4 = Widower, 5 = Single, 6 = Other. Submitting this parameter can increase the acceptance ratio for the payment method. |
sender_occupation | optional | string(255) | Occupation of the recepient. Submitting this parameter can increase the acceptance ratio for the payment method. |
nationality | optional | string(255) | Nationality of the payer. Submitting this parameter can increase the acceptance ratio for the payment method. |
country_of_origin | optional | string(255) | Country of origing of the payer. Two-letter iso codes. Submitting this parameter can increase the acceptance ratio for the payment method. |
birth_city | optional | string(255) | City of birth of the payer. Submitting this parameter can increase the acceptance ratio for the payment method. |
birth_state | optional | string(255) | Birth state of the payer. Submitting this parameter can increase the acceptance ratio for the payment method. |
company_type | optional | enum | 0 = SA, 1 = LTDA, 2 = MEI, 3 = ME, 4 = EIRELI, 5 = Condominium, 6 = Closed SA, 7 = Simple EIRELI, 8 = Outros. Applicable for B2B payments only. Submitting this parameter can increase the acceptance ratio for the payment method. |
company_activity | optional | string(255) | Type of company activity. Applicable for B2B payments only. Submitting this parameter can increase the acceptance ratio for the payment method. |
birth_date | optional | string(10) | Birth date of the consumer |
incorporation_date | optional | dd-mm-yyyy | Applicable for B2B payments only. Submitting this parameter can increase the acceptance ratio for the payment method. |
billing_address | required | See Required vs Optional API params for details | |
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported countries:
Country |
---|
BR |
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>pix</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:56Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
<emv_string>00020101021226870014br.gov.bcb.pix2565pix-h.santander.com.br/qr/v2/573119fe-8811-4612-9233-7252abc22ef45204000053039865802BR5925EMERCHANTPAY DO BRAZIL...6009SAO PAULO62070503***6304e675</emv_string>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
transaction_id | string(255) | Unique transaction id defined by merchant |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
emv_string | string(255) | A string representation of the QR code. |
Error Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>pix</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:56Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Redpagos
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\CashPayments\Redpagos');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setAmount('100')
->setCurrency('USD')
->setConsumerReference('barney_rubble')
->setNationalId('8812128812')
->setBirthDate('30-12-1992')
->setCustomerEmail('travis@example.com')
// Billing Address
->setBillingFirstName('Barney')
->setBillingLastName('Rubble')
->setBillingAddress1('14, Nerazdelni str')
->setBillingZipCode('1407')
->setBillingCity('Montevideo')
->setBillingCountry('UY')
// Risk Params
->setRiskUserId('123456');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>redpagos</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<amount>100</amount>
<currency>USD</currency>
<consumer_reference>barney_rubble</consumer_reference>
<national_id>8812128812</national_id>
<birth_date>30-12-1992</birth_date>
<customer_email>travis@example.com</customer_email>
<billing_address>
<first_name>Barney</first_name>
<last_name>Rubble</last_name>
<address1>14, Nerazdelni str</address1>
<zip_code>1407</zip_code>
<city>Montevideo</city>
<country>UY</country>
</billing_address>
<risk_params>
<user_id>123456</user_id>
</risk_params>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: redpagos |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
consumer_reference | required | string(20) | Consumer reference is a unique consumer identifier |
national_id | required | string(20) | National ID of the consumer. See Document ID Parameter for more details. |
birth_date | optional | string(20) | Birth date of the customer |
customer_email | required | e-mail address | Must contain valid e-mail of customer |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported countries:
Country |
---|
UY |
Successful Response
stdClass Object
(
[transaction_type] => redpagos
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:56.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>redpagos</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<timestamp>2025-01-16T10:23:56Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => redpagos
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 110
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:56.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>redpagos</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:56Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Gift Cards
Intersolve
Intersolve transactions are made using gift card provided by Intersolve
Using an intersolve transaction, the amount is immediately billed to the customer’s gift card.
It can be reversed via a void transaction. Intersolve gift cards also support payout.
Use intersolve transactions if you are using gift cards provided by Intersolve.
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\GiftCards\Intersolve');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardNumber('7000001163991388834')
->setCvv('944062')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.giftcards.IntersolveRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
IntersolveRequest request = new IntersolveRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardNumber("7000001163991388834");
request.setCvv("944062");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>intersolve</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_number>7000001163991388834</card_number>
<cvv>944062</cvv>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: intersolve |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | required* | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
card_number | required | string(19..21) | Gift card number |
cvv | required* | 5 to 8 digits | Verification code of the gift card, requirement is based on terminal configuration |
token | optional | string(36) | See Tokenization for more details. If present, the cardholder parameters can be omitted. Cannot be set together with remember_card |
remember_card | optional | "true" | See Tokenize. Tokenizes cardholder parameters. Cannot be set together with token |
consumer_id | optional | string(10) | See Consumers and Tokenization. Combine with remember_card to tokenize or with token to use token |
billing_address | required* | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required* | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
dynamic_descriptor_params | optional | ||
merchant_name | optional | string(25) | Allows to dynamically override the charge descriptor |
merchant_city | optional | string(13) | Allows to dynamically override the merchant phone number |
sub_merchant_id | optional | string(15) | Allows to dynamically override the sub-merchant ID. |
merchant_country | optional | string(3) | Allows to dynamically override the merchant country. |
merchant_state | optional | string(3) | Allows to dynamically override the merchant subdivision code. |
merchant_zip_code | optional | string(10) | Allows to dynamically override the merchant zip/postal code. Required for VISA OCT transactions with Australian and Canadian card bins. |
merchant_address | optional | string(48) | Allows to dynamically override the merchant address. |
merchant_url | optional | string(60) | Allows to dynamically override the merchant URL |
merchant_phone | optional | string(16) | Allows to dynamically override the merchant phone number. |
merchant_service_city | optional | string(13) | Allows to dynamically override the merchant service city. |
merchant_service_country | optional | string(3) | Allows to dynamically override the merchant service country. |
merchant_service_state | optional | string(3) | Allows to dynamically override the merchant service subdivision code. |
merchant_service_zip_code | optional | string(10) | Allows to dynamically override the merchant service zip/postal code. |
merchant_service_phone | optional | string(16) | Allows to dynamically override the merchant service phone number. |
merchant_geo_coordinates | optional | string(20) | Allows to dynamically override the merchant geographic coordinates. |
merchant_service_geo_coordinates | optional | string(20) | Allows to dynamically override the merchant service geographic coordinates. |
required* = conditionally required
Successful Response
stdClass Object
(
[transaction_type] => intersolve
[status] => approved
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[consumer_id] => 123456
[token] => ee946db8-d7db-4bb7-b608-b65b153e127d
[technical_message] => Transaction successful!
[message] => Transaction successful!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:56.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[intersolve]>
<status content=[approved]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<consumer_id content=[123456]>
<token content=[ee946db8-d7db-4bb7-b608-b65b153e127d]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<timestamp content=[2025-01-16T10:23:56Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[true]>
]>
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>intersolve</transaction_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<consumer_id>123456</consumer_id>
<token>ee946db8-d7db-4bb7-b608-b65b153e127d</token>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:56Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
consumer_id | string(10) | Consumer unique reference. See Consumers |
token | string(36) | Plain-text token value. See Tokenization |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
Error Response
stdClass Object
(
[transaction_type] => intersolve
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 340
[technical_message] => Transaction_id is invalid!
[message] => Transaction_id is invalid!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:56.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => false
)
<payment_response content=[
<transaction_type content=[intersolve]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<code content=[340]>
<technical_message content=[Transaction_id is invalid!]>
<message content=[Transaction_id is invalid!]>
<timestamp content=[2025-01-16T10:23:56Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[false]>
]>
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>intersolve</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>340</code>
<technical_message>Transaction_id is invalid!</technical_message>
<message>Transaction_id is invalid!</message>
<timestamp>2025-01-16T10:23:56Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
Fashioncheque
Fashioncheque transactions are made using gift card provided by Fashioncheque
Using a fashioncheque transaction, the amount is immediately billed to the customer’s gift card.
It can be reversed via a void transaction on the same day of the transaction. They can also be refunded.
Use fashioncheque transactions, if you are using gift cards provided by Fashioncheque.
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\GiftCards\Fashioncheque');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardNumber('6046425117120757123')
->setCvv('121839')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.giftcards.FashionchequeRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
FashionchequeRequest request = new FashionchequeRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardNumber("6046425117120757123");
request.setCvv("121839");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>fashioncheque</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_number>6046425117120757123</card_number>
<cvv>121839</cvv>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: fashioncheque |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | required* | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Only USD and EUR |
card_number | required | string(19..21) | Gift card number |
cvv | required* | 5 to 8 digits | Verification code of the gift card, requirement is based on terminal configuration |
token | optional | string(36) | See Tokenization for more details. If present, the cardholder parameters can be omitted |
billing_address | required* | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required* | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
dynamic_descriptor_params | optional | ||
merchant_name | optional | string(25) | Allows to dynamically override the charge descriptor |
merchant_city | optional | string(13) | Allows to dynamically override the merchant phone number |
sub_merchant_id | optional | string(15) | Allows to dynamically override the sub-merchant ID. |
merchant_country | optional | string(3) | Allows to dynamically override the merchant country. |
merchant_state | optional | string(3) | Allows to dynamically override the merchant subdivision code. |
merchant_zip_code | optional | string(10) | Allows to dynamically override the merchant zip/postal code. Required for VISA OCT transactions with Australian and Canadian card bins. |
merchant_address | optional | string(48) | Allows to dynamically override the merchant address. |
merchant_url | optional | string(60) | Allows to dynamically override the merchant URL |
merchant_phone | optional | string(16) | Allows to dynamically override the merchant phone number. |
merchant_service_city | optional | string(13) | Allows to dynamically override the merchant service city. |
merchant_service_country | optional | string(3) | Allows to dynamically override the merchant service country. |
merchant_service_state | optional | string(3) | Allows to dynamically override the merchant service subdivision code. |
merchant_service_zip_code | optional | string(10) | Allows to dynamically override the merchant service zip/postal code. |
merchant_service_phone | optional | string(16) | Allows to dynamically override the merchant service phone number. |
merchant_geo_coordinates | optional | string(20) | Allows to dynamically override the merchant geographic coordinates. |
merchant_service_geo_coordinates | optional | string(20) | Allows to dynamically override the merchant service geographic coordinates. |
required* = conditionally required
Successful Response
stdClass Object
(
[transaction_type] => fashioncheque
[status] => approved
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:56.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[fashioncheque]>
<status content=[approved]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<timestamp content=[2025-01-16T10:23:56Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[true]>
]>
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>fashioncheque</transaction_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:56Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
Error Response
stdClass Object
(
[transaction_type] => fashioncheque
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 340
[technical_message] => Transaction_id is invalid!
[message] => Transaction_id is invalid!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:56.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => false
)
<payment_response content=[
<transaction_type content=[fashioncheque]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<code content=[340]>
<technical_message content=[Transaction_id is invalid!]>
<message content=[Transaction_id is invalid!]>
<timestamp content=[2025-01-16T10:23:56Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[false]>
]>
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>fashioncheque</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>340</code>
<technical_message>Transaction_id is invalid!</technical_message>
<message>Transaction_id is invalid!</message>
<timestamp>2025-01-16T10:23:56Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
TCS
The container store transactions are made using gift cards provided by TCS.
The amount from a Container Store Transactions is immediately billed to the customer’s gift card.
It can be reversed via a void transaction.
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\GiftCards\Tcs');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardNumber('6046425117120757123')
->setCvv('121839')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.giftcards.TCSRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
TCSRequest request = new TCSRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardNumber("6046425117120757123");
request.setCvv("121839");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>container_store</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_number>6046425117120757123</card_number>
<cvv>121839</cvv>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: container_store |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | required* | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Only USD and EUR |
card_number | required | string(19..21) | Gift card number |
cvv | required* | 5 to 8 digits | Verification code of the gift card, requirement is based on terminal configuration |
token | optional | string(36) | See Tokenization for more details. If present, the cardholder parameters can be omitted |
billing_address | required* | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required* | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
dynamic_descriptor_params | optional | ||
merchant_name | optional | string(25) | Allows to dynamically override the charge descriptor |
merchant_city | optional | string(13) | Allows to dynamically override the merchant phone number |
sub_merchant_id | optional | string(15) | Allows to dynamically override the sub-merchant ID. |
merchant_country | optional | string(3) | Allows to dynamically override the merchant country. |
merchant_state | optional | string(3) | Allows to dynamically override the merchant subdivision code. |
merchant_zip_code | optional | string(10) | Allows to dynamically override the merchant zip/postal code. Required for VISA OCT transactions with Australian and Canadian card bins. |
merchant_address | optional | string(48) | Allows to dynamically override the merchant address. |
merchant_url | optional | string(60) | Allows to dynamically override the merchant URL |
merchant_phone | optional | string(16) | Allows to dynamically override the merchant phone number. |
merchant_service_city | optional | string(13) | Allows to dynamically override the merchant service city. |
merchant_service_country | optional | string(3) | Allows to dynamically override the merchant service country. |
merchant_service_state | optional | string(3) | Allows to dynamically override the merchant service subdivision code. |
merchant_service_zip_code | optional | string(10) | Allows to dynamically override the merchant service zip/postal code. |
merchant_service_phone | optional | string(16) | Allows to dynamically override the merchant service phone number. |
merchant_geo_coordinates | optional | string(20) | Allows to dynamically override the merchant geographic coordinates. |
merchant_service_geo_coordinates | optional | string(20) | Allows to dynamically override the merchant service geographic coordinates. |
required* = conditionally required
Successful Response
stdClass Object
(
[transaction_type] => container_store
[status] => approved
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:56.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[container_store]>
<status content=[approved]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<timestamp content=[2025-01-16T10:23:56Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[true]>
]>
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>container_store</transaction_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:56Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
Error Response
stdClass Object
(
[transaction_type] => container_store
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 340
[technical_message] => Transaction_id is invalid!
[message] => Transaction_id is invalid!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:56.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => false
)
<payment_response content=[
<transaction_type content=[container_store]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<code content=[340]>
<technical_message content=[Transaction_id is invalid!]>
<message content=[Transaction_id is invalid!]>
<timestamp content=[2025-01-16T10:23:56Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[false]>
]>
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>container_store</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>340</code>
<technical_message>Transaction_id is invalid!</technical_message>
<message>Transaction_id is invalid!</message>
<timestamp>2025-01-16T10:23:56Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
Split Payments
Split payments are performed on gift card transaction types when there isn’t enough balance in the gift card. In order to use split payments you need to enable them on terminal. For more information please contact tech support.
Split payments follow this workflow:
- Split payment can be initiated only on gift card transaction.
- You can have maximum three payment series including the initial transaction.
- If the gift card does not have enough balance to perform the transaction, the whole available balance is taken from the gift card and new split payment is initiated.
- You can continue the split payment with another gift card
- You can finish the split payment with either gift card or credit card by submitting the ’unique id’ of the initial transaction as ’reference id’ in the request.
- Any failure during split payment causes rollback of all split payment series transactions.
Example for initial split payment transaction:
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\GiftCards\Fashioncheque');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('5000')
->setCurrency('EUR')
->setCardNumber('6046425117120757123')
->setCvv('121839')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.giftcards.FashionchequeRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
FashionchequeRequest request = new FashionchequeRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(5000));
request.setCurrency("EUR");
request.setCardNumber("6046425117120757123");
request.setCvv("121839");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>fashioncheque</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>5000</amount>
<currency>EUR</currency>
<card_number>6046425117120757123</card_number>
<cvv>121839</cvv>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: fashioncheque |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | required* | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Only USD and EUR |
card_number | required | string(19..21) | Gift card number |
cvv | required* | 5 to 8 digits | Verification code of the gift card, requirement is based on terminal configuration |
token | optional | string(36) | See Tokenization for more details. If present, the cardholder parameters can be omitted |
billing_address | required* | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required* | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
dynamic_descriptor_params | optional | ||
merchant_name | optional | string(25) | Allows to dynamically override the charge descriptor |
merchant_city | optional | string(13) | Allows to dynamically override the merchant phone number |
sub_merchant_id | optional | string(15) | Allows to dynamically override the sub-merchant ID. |
merchant_country | optional | string(3) | Allows to dynamically override the merchant country. |
merchant_state | optional | string(3) | Allows to dynamically override the merchant subdivision code. |
merchant_zip_code | optional | string(10) | Allows to dynamically override the merchant zip/postal code. Required for VISA OCT transactions with Australian and Canadian card bins. |
merchant_address | optional | string(48) | Allows to dynamically override the merchant address. |
merchant_url | optional | string(60) | Allows to dynamically override the merchant URL |
merchant_phone | optional | string(16) | Allows to dynamically override the merchant phone number. |
merchant_service_city | optional | string(13) | Allows to dynamically override the merchant service city. |
merchant_service_country | optional | string(3) | Allows to dynamically override the merchant service country. |
merchant_service_state | optional | string(3) | Allows to dynamically override the merchant service subdivision code. |
merchant_service_zip_code | optional | string(10) | Allows to dynamically override the merchant service zip/postal code. |
merchant_service_phone | optional | string(16) | Allows to dynamically override the merchant service phone number. |
merchant_geo_coordinates | optional | string(20) | Allows to dynamically override the merchant geographic coordinates. |
merchant_service_geo_coordinates | optional | string(20) | Allows to dynamically override the merchant service geographic coordinates. |
required* = conditionally required
Successful Response
stdClass Object
(
[transaction_type] => fashioncheque
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 406bc1b340472db4dbbba4b749850234
[technical_message] => Transaction successful!
[message] => Transaction successful!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:56.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 2000
[currency] => EUR
[split_payment] => initiated
[leftover_amount] => 3000
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[fashioncheque]>
<status content=[pending_async]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[406bc1b340472db4dbbba4b749850234]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<timestamp content=[2025-01-16T10:23:56Z]>
<descriptor content=[Descriptor one]>
<amount content=[2000]>
<currency content=[EUR]>
<split_payment content=[initiated]>
<leftover_amount content=[3000]>
<sent_to_acquirer content=[true]>
]>
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>fashioncheque</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>406bc1b340472db4dbbba4b749850234</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:56Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>2000</amount>
<currency>EUR</currency>
<split_payment>initiated</split_payment>
<leftover_amount>3000</leftover_amount>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
split_payment | string | Split payment status for this transaction. Should be ’initiated’. |
leftover_amount | integer | Leftover amount of transaction in minor currency unit, see Currency Handling for details |
sent_to_acquirer | string(255) | "true" or "false" |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
Error Response
stdClass Object
(
[transaction_type] => fashioncheque
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 340
[technical_message] => Transaction_id is invalid!
[message] => Transaction_id is invalid!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:56.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 5000
[currency] => EUR
[sent_to_acquirer] => false
)
<payment_response content=[
<transaction_type content=[fashioncheque]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<code content=[340]>
<technical_message content=[Transaction_id is invalid!]>
<message content=[Transaction_id is invalid!]>
<timestamp content=[2025-01-16T10:23:56Z]>
<descriptor content=[Descriptor one]>
<amount content=[5000]>
<currency content=[EUR]>
<sent_to_acquirer content=[false]>
]>
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>fashioncheque</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>340</code>
<technical_message>Transaction_id is invalid!</technical_message>
<message>Transaction_id is invalid!</message>
<timestamp>2025-01-16T10:23:56Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>5000</amount>
<currency>EUR</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
Example for continued split payment transaction:
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\GiftCards\Intersolve');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReferenceId('406bc1b340472db4dbbba4b749850234')
->setAmount('3000')
->setCurrency('EUR')
->setCardNumber('7000001163991388834')
->setCvv('944062')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.giftcards.IntersolveRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
IntersolveRequest request = new IntersolveRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setReferenceId("406bc1b340472db4dbbba4b749850234");
request.setAmount(new BigDecimal(3000));
request.setCurrency("EUR");
request.setCardNumber("7000001163991388834");
request.setCvv("944062");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>intersolve</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<reference_id>406bc1b340472db4dbbba4b749850234</reference_id>
<amount>3000</amount>
<currency>EUR</currency>
<card_number>7000001163991388834</card_number>
<cvv>944062</cvv>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: intersolve |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | required* | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
reference_id | required | string(32) | The ’unique id’ of the initial split payment transaction. |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
card_number | required | string(19..21) | Gift card number |
cvv | required* | 5 to 8 digits | Verification code of the gift card, requirement is based on terminal configuration |
token | optional | string(36) | See Tokenization for more details. If present, the cardholder parameters can be omitted |
billing_address | required* | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required* | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
dynamic_descriptor_params | optional | ||
merchant_name | optional | string(25) | Allows to dynamically override the charge descriptor |
merchant_city | optional | string(13) | Allows to dynamically override the merchant phone number |
sub_merchant_id | optional | string(15) | Allows to dynamically override the sub-merchant ID. |
merchant_country | optional | string(3) | Allows to dynamically override the merchant country. |
merchant_state | optional | string(3) | Allows to dynamically override the merchant subdivision code. |
merchant_zip_code | optional | string(10) | Allows to dynamically override the merchant zip/postal code. Required for VISA OCT transactions with Australian and Canadian card bins. |
merchant_address | optional | string(48) | Allows to dynamically override the merchant address. |
merchant_url | optional | string(60) | Allows to dynamically override the merchant URL |
merchant_phone | optional | string(16) | Allows to dynamically override the merchant phone number. |
merchant_service_city | optional | string(13) | Allows to dynamically override the merchant service city. |
merchant_service_country | optional | string(3) | Allows to dynamically override the merchant service country. |
merchant_service_state | optional | string(3) | Allows to dynamically override the merchant service subdivision code. |
merchant_service_zip_code | optional | string(10) | Allows to dynamically override the merchant service zip/postal code. |
merchant_service_phone | optional | string(16) | Allows to dynamically override the merchant service phone number. |
merchant_geo_coordinates | optional | string(20) | Allows to dynamically override the merchant geographic coordinates. |
merchant_service_geo_coordinates | optional | string(20) | Allows to dynamically override the merchant service geographic coordinates. |
required* = conditionally required
Successful Response
stdClass Object
(
[transaction_type] => intersolve
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:56.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 2500
[currency] => EUR
[split_payment] => continued
[leftover_amount] => 500
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[intersolve]>
<status content=[pending_async]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<timestamp content=[2025-01-16T10:23:56Z]>
<descriptor content=[Descriptor one]>
<amount content=[2500]>
<currency content=[EUR]>
<split_payment content=[continued]>
<leftover_amount content=[500]>
<sent_to_acquirer content=[true]>
]>
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>intersolve</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:56Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>2500</amount>
<currency>EUR</currency>
<split_payment>continued</split_payment>
<leftover_amount>500</leftover_amount>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
split_payment | string | Split payment status for this transaction. Should be ’continued’. |
leftover_amount | integer | Leftover amount of transaction in minor currency unit, see Currency Handling for details |
sent_to_acquirer | string(255) | "true" or "false" |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
Error Response
stdClass Object
(
[transaction_type] => intersolve
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 340
[technical_message] => Transaction_id is invalid!
[message] => Transaction_id is invalid!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:56.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 3000
[currency] => EUR
[sent_to_acquirer] => false
)
<payment_response content=[
<transaction_type content=[intersolve]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<code content=[340]>
<technical_message content=[Transaction_id is invalid!]>
<message content=[Transaction_id is invalid!]>
<timestamp content=[2025-01-16T10:23:56Z]>
<descriptor content=[Descriptor one]>
<amount content=[3000]>
<currency content=[EUR]>
<sent_to_acquirer content=[false]>
]>
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>intersolve</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>340</code>
<technical_message>Transaction_id is invalid!</technical_message>
<message>Transaction_id is invalid!</message>
<timestamp>2025-01-16T10:23:56Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>3000</amount>
<currency>EUR</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
Example for finalized split payment transaction:
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\GiftCards\Intersolve');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReferenceId('406bc1b340472db4dbbba4b749850234')
->setAmount('500')
->setCurrency('EUR')
->setCardNumber('7000001163991388834')
->setCvv('944062')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.giftcards.IntersolveRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
IntersolveRequest request = new IntersolveRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setReferenceId("406bc1b340472db4dbbba4b749850234");
request.setAmount(new BigDecimal(500));
request.setCurrency("EUR");
request.setCardNumber("7000001163991388834");
request.setCvv("944062");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>intersolve</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<reference_id>406bc1b340472db4dbbba4b749850234</reference_id>
<amount>500</amount>
<currency>EUR</currency>
<card_number>7000001163991388834</card_number>
<cvv>944062</cvv>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: intersolve |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | required* | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
reference_id | required | string(32) | The ’unique id’ of the initial split payment transaction. |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
card_number | required | string(19..21) | Gift card number |
cvv | required* | 5 to 8 digits | Verification code of the gift card, requirement is based on terminal configuration |
token | optional | string(36) | See Tokenization for more details. If present, the cardholder parameters can be omitted |
billing_address | required* | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required* | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
dynamic_descriptor_params | optional | ||
merchant_name | optional | string(25) | Allows to dynamically override the charge descriptor |
merchant_city | optional | string(13) | Allows to dynamically override the merchant phone number |
sub_merchant_id | optional | string(15) | Allows to dynamically override the sub-merchant ID. |
merchant_country | optional | string(3) | Allows to dynamically override the merchant country. |
merchant_state | optional | string(3) | Allows to dynamically override the merchant subdivision code. |
merchant_zip_code | optional | string(10) | Allows to dynamically override the merchant zip/postal code. Required for VISA OCT transactions with Australian and Canadian card bins. |
merchant_address | optional | string(48) | Allows to dynamically override the merchant address. |
merchant_url | optional | string(60) | Allows to dynamically override the merchant URL |
merchant_phone | optional | string(16) | Allows to dynamically override the merchant phone number. |
merchant_service_city | optional | string(13) | Allows to dynamically override the merchant service city. |
merchant_service_country | optional | string(3) | Allows to dynamically override the merchant service country. |
merchant_service_state | optional | string(3) | Allows to dynamically override the merchant service subdivision code. |
merchant_service_zip_code | optional | string(10) | Allows to dynamically override the merchant service zip/postal code. |
merchant_service_phone | optional | string(16) | Allows to dynamically override the merchant service phone number. |
merchant_geo_coordinates | optional | string(20) | Allows to dynamically override the merchant geographic coordinates. |
merchant_service_geo_coordinates | optional | string(20) | Allows to dynamically override the merchant service geographic coordinates. |
required* = conditionally required
Successful Response
stdClass Object
(
[transaction_type] => intersolve
[status] => approved
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:56.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 500
[currency] => EUR
[split_payment] => finalized
[leftover_amount] => 0
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[intersolve]>
<status content=[approved]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<timestamp content=[2025-01-16T10:23:56Z]>
<descriptor content=[Descriptor one]>
<amount content=[500]>
<currency content=[EUR]>
<split_payment content=[finalized]>
<leftover_amount content=[0]>
<sent_to_acquirer content=[true]>
]>
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>intersolve</transaction_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:56Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>500</amount>
<currency>EUR</currency>
<split_payment>finalized</split_payment>
<leftover_amount>0</leftover_amount>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
split_payment | string | Split payment status for this transaction. Should be ’finalized’. |
leftover_amount | integer | Leftover amount of transaction in minor currency unit, see Currency Handling for details |
sent_to_acquirer | string(255) | "true" or "false" |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
Error Response
stdClass Object
(
[transaction_type] => intersolve
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 340
[technical_message] => Transaction_id is invalid!
[message] => Transaction_id is invalid!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:56.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 500
[currency] => EUR
[sent_to_acquirer] => false
)
<payment_response content=[
<transaction_type content=[intersolve]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<code content=[340]>
<technical_message content=[Transaction_id is invalid!]>
<message content=[Transaction_id is invalid!]>
<timestamp content=[2025-01-16T10:23:56Z]>
<descriptor content=[Descriptor one]>
<amount content=[500]>
<currency content=[EUR]>
<sent_to_acquirer content=[false]>
]>
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>intersolve</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>340</code>
<technical_message>Transaction_id is invalid!</technical_message>
<message>Transaction_id is invalid!</message>
<timestamp>2025-01-16T10:23:56Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>500</amount>
<currency>EUR</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
Example for finalized Sale split payment transaction:
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Sale');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReferenceId('406bc1b340472db4dbbba4b749850234')
->setAmount('500')
->setCurrency('EUR')
->setCardHolder('Travis Pastrana')
->setCardNumber('4200000000000000')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.SaleRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
SaleRequest request = new SaleRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setReferenceId("406bc1b340472db4dbbba4b749850234");
request.setAmount(new BigDecimal(500));
request.setCurrency("EUR");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4200000000000000");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.sale(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"reference_id": "406bc1b340472db4dbbba4b749850234",
"amount": "500",
"currency": "EUR",
"card_holder": "Travis Pastrana",
"card_number": "4200000000000000",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>sale</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<reference_id>406bc1b340472db4dbbba4b749850234</reference_id>
<amount>500</amount>
<currency>EUR</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4200000000000000</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: sale |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
gaming | optional | "true" | Signifies whether a gaming transaction is performed. Gaming transactions usually use MCC 7995. Contact tech-support@emerchantpay.com for more details |
moto | optional | "true" | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech-support@emerchantpay.com for more details |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
reference_id | required* | string(32) | The ’unique id’ of the initial split payment transaction |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
card_holder | required | string(255) | Full name of customer as printed on credit card (first name and last name at least) |
card_number | required | 13 to 16 digits | Complete cc number of customer |
cvv | required* | 3 to 4 digits | cvv of cc, requirement is based on terminal configuration |
expiration_month | required | MM | Expiration month as printed on credit card |
expiration_year | required | YYYY | Expiration year as printed on credit card |
customer_email | required* | e-mail address | Must contain valid e-mail of customer |
customer_phone | required* | string(32) | Must contain valid phone number of customer |
birth_date | required* | dd-mm-yyyy | Required for Visa only when MCC is a Financial Services one (e.g. MCC 6012) |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required* | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
neighborhood | optional | string(255) | Neighborhood |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
dynamic_descriptor_params | optional | ||
merchant_name | optional | string(25) | Allows to dynamically override the charge descriptor |
merchant_city | optional | string(13) | Allows to dynamically override the merchant phone number |
sub_merchant_id | optional | string(15) | Allows to dynamically override the sub-merchant ID. |
merchant_country | optional | string(3) | Allows to dynamically override the merchant country. |
merchant_state | optional | string(3) | Allows to dynamically override the merchant subdivision code. |
merchant_zip_code | optional | string(10) | Allows to dynamically override the merchant zip/postal code. Required for VISA OCT transactions with Australian and Canadian card bins. |
merchant_address | optional | string(48) | Allows to dynamically override the merchant address. |
merchant_url | optional | string(60) | Allows to dynamically override the merchant URL |
merchant_phone | optional | string(16) | Allows to dynamically override the merchant phone number. |
merchant_service_city | optional | string(13) | Allows to dynamically override the merchant service city. |
merchant_service_country | optional | string(3) | Allows to dynamically override the merchant service country. |
merchant_service_state | optional | string(3) | Allows to dynamically override the merchant service subdivision code. |
merchant_service_zip_code | optional | string(10) | Allows to dynamically override the merchant service zip/postal code. |
merchant_service_phone | optional | string(16) | Allows to dynamically override the merchant service phone number. |
merchant_geo_coordinates | optional | string(20) | Allows to dynamically override the merchant geographic coordinates. |
merchant_service_geo_coordinates | optional | string(20) | Allows to dynamically override the merchant service geographic coordinates. |
required* = conditionally required
Successful Response
stdClass Object
(
[transaction_type] => sale
[status] => approved
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[avs_response_code] => 5I
[avs_response_text] => Response provided by issuer processor; Address information not verified
[cvv_result_code] => M
[authorization_code] => 345678
[response_code] => 00
[technical_message] => Transaction successful!
[message] => Transaction successful!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:56.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 500
[currency] => EUR
[split_payment] => finalized
[leftover_amount] => 0
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[sale]>
<status content=[approved]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<avs_response_code content=[5I]>
<avs_response_text content=[Response provided by issuer processor; Address information not verified]>
<cvv_result_code content=[M]>
<authorization_code content=[345678]>
<response_code content=[00]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<timestamp content=[2025-01-16T10:23:56Z]>
<descriptor content=[Descriptor one]>
<amount content=[500]>
<currency content=[EUR]>
<split_payment content=[finalized]>
<leftover_amount content=[0]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "sale",
status: "approved",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
avs_response_code: "5I",
avs_response_text: "Response provided by issuer processor; Address information not verified",
cvv_result_code: "M",
authorization_code: "345678",
response_code: "00",
technical_message: "Transaction successful!",
message: "Transaction successful!",
timestamp: "2025-01-16T10:23:56Z",
descriptor: "Descriptor one",
amount: "500",
currency: "EUR",
split_payment: "finalized",
leftover_amount: "0",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>sale</transaction_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<avs_response_code>5I</avs_response_code>
<avs_response_text>Response provided by issuer processor; Address information not verified</avs_response_text>
<cvv_result_code>M</cvv_result_code>
<authorization_code>345678</authorization_code>
<response_code>00</response_code>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:56Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>500</amount>
<currency>EUR</currency>
<split_payment>finalized</split_payment>
<leftover_amount>0</leftover_amount>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
gaming | 'true' | Signifies whether a gaming transaction is performed. Gaming transactions usually use MCC 7995, contact tech support for more details. |
moto | 'true' | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech support for more details. |
avs_response_code | string(255) | Generated by the card network on trying to match the billing address when performing the address verification. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
avs_response_text | string(255) | Gives the human response text for the AVS response code above. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
cvv_result_code | string(1) | Card Verification Value response code. Optional, returned only if acquirer supports it |
authorization_code | string(6) | Generated by the card network when an authorisation has occurred, used to identify that auth. Consists of 6 alphanumeric chars |
response_code | string(2) | Defines the result of a transaction with the acquirer, the status of a message or some action taken or required. Contact tech-support@emerchantpay.com for more details. |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
split_payment | string | Split payment status for this transaction. Should be ’finalized’. |
leftover_amount | integer | Leftover amount of transaction in minor currency unit, see Currency Handling for details |
sent_to_acquirer | string(255) | "true" or "false" |
partial_approval | string(4) | Optional, set to ’true’ if partial approval happened. Partially approved amount is then in the amount field. Check Partial Approvals for details |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
Error Response
stdClass Object
(
[response_code] => 57
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 340
[technical_message] => billing_address[zip_code] is invalid!
[message] => billing_address[zip_code] is invalid!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:57.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 500
[currency] => EUR
[sent_to_acquirer] => false
)
<payment_response content=[
<response_code content=[57]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<code content=[340]>
<technical_message content=[billing_address[zip_code] is invalid!]>
<message content=[billing_address[zip_code] is invalid!]>
<timestamp content=[2025-01-16T10:23:57Z]>
<descriptor content=[Descriptor one]>
<amount content=[500]>
<currency content=[EUR]>
<sent_to_acquirer content=[false]>
]>
{
response_code: "57",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
code: "340",
technical_message: "billing_address[zip_code] is invalid!",
message: "billing_address[zip_code] is invalid!",
timestamp: "2025-01-16T10:23:57Z",
descriptor: "Descriptor one",
amount: "500",
currency: "EUR",
sent_to_acquirer: "false",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<response_code>57</response_code>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>340</code>
<technical_message>billing_address[zip_code] is invalid!</technical_message>
<message>billing_address[zip_code] is invalid!</message>
<timestamp>2025-01-16T10:23:57Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>500</amount>
<currency>EUR</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
gaming | 'true' | Signifies whether a gaming transaction is performed. Gaming transactions usually use MCC 7995, contact tech support for more details. |
moto | 'true' | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech support for more details. |
response_code | string(2) | Defines the result of a transaction with the acquirer, the status of a message or some action taken or required. Contact tech-support@emerchantpay.com for more details. |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
Example for finalized Sale 3D split payment transaction:
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: sale3d |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
gaming | optional | "true" | Signifies whether a gaming transaction is performed. Gaming transactions usually use MCC 7995. Contact tech-support@emerchantpay.com for more details |
moto | optional | "true" | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech-support@emerchantpay.com for more details |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
reference_id | required | string(32) | The ’unique id’ of the initial split payment transaction |
notification_url | required1 | url | URL at merchant where gateway sends outcome of transaction. |
return_success_url | required1 | url | URL where customer is sent to after successful payment |
return_failure_url | required1 | url | URL where customer is sent to after unsuccessful payment |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
card_holder | required | string(255) | Full name of customer as printed on credit card (first name and last name at least) |
card_number | required | 13 to 16 digits | Complete cc number of customer |
cvv | required | 3 to 4 digits | cvv of cc, requirement is based on terminal configuration |
expiration_month | required | MM | Expiration month as printed on credit card |
expiration_year | required | YYYY | Expiration year as printed on credit card |
customer_email | required* | e-mail address | Must contain valid e-mail of customer |
customer_phone | required* | string(32) | Must contain valid phone number of customer |
birth_date | required* | dd-mm-yyyy | Required for Visa only when MCC is a Financial Services one (e.g. MCC 6012) |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required* | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
neighborhood | optional | string(255) | Neighborhood |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
mpi_params | required2 | ||
cavv | required3 | string(255) | Verification Id of the authentication. Please note this can be the CAVV for Visa Card or UCAF to identify MasterCard. |
eci | required3 | string(255) | See Electronic Commerce Indicator as returned from the MPI for details |
dynamic_descriptor_params | optional | ||
merchant_name | optional | string(25) | Allows to dynamically override the charge descriptor |
merchant_city | optional | string(13) | Allows to dynamically override the merchant phone number |
sub_merchant_id | optional | string(15) | Allows to dynamically override the sub-merchant ID. |
merchant_country | optional | string(3) | Allows to dynamically override the merchant country. |
merchant_state | optional | string(3) | Allows to dynamically override the merchant subdivision code. |
merchant_zip_code | optional | string(10) | Allows to dynamically override the merchant zip/postal code. Required for VISA OCT transactions with Australian and Canadian card bins. |
merchant_address | optional | string(48) | Allows to dynamically override the merchant address. |
merchant_url | optional | string(60) | Allows to dynamically override the merchant URL |
merchant_phone | optional | string(16) | Allows to dynamically override the merchant phone number. |
merchant_service_city | optional | string(13) | Allows to dynamically override the merchant service city. |
merchant_service_country | optional | string(3) | Allows to dynamically override the merchant service country. |
merchant_service_state | optional | string(3) | Allows to dynamically override the merchant service subdivision code. |
merchant_service_zip_code | optional | string(10) | Allows to dynamically override the merchant service zip/postal code. |
merchant_service_phone | optional | string(16) | Allows to dynamically override the merchant service phone number. |
merchant_geo_coordinates | optional | string(20) | Allows to dynamically override the merchant geographic coordinates. |
merchant_service_geo_coordinates | optional | string(20) | Allows to dynamically override the merchant service geographic coordinates. |
required* = conditionally required
1 - required if mpi_params is not present, the transaction will be handled asynchronously. Not required if configured on Terminal or Merchant level. Contact [tech-support@#{email_domain_name}](mailto:tech-support@#{email_domain_name}) for more details.
2 - required if transaction should be handled synchronous.
3 - eci is always required if mpi_params is present. cavv is not required for the 3D attempted only workflow, but it is strongly recommended in a combination with the Directory Server ID in order to be in the scope of the 3DSv2 authentication protocol.
Successful Asynchronous Response
stdClass Object
(
[transaction_type] => sale3d
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:57.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 500
[currency] => EUR
[split_payment] => finalized
[leftover_amount] => 0
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[sale3d]>
<status content=[pending_async]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<redirect_url content=[https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61]>
<timestamp content=[2025-01-16T10:23:57Z]>
<descriptor content=[Descriptor one]>
<amount content=[500]>
<currency content=[EUR]>
<split_payment content=[finalized]>
<leftover_amount content=[0]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "sale3d",
status: "pending_async",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
technical_message: "Transaction successful!",
message: "Transaction successful!",
redirect_url: "https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61",
timestamp: "2025-01-16T10:23:57Z",
descriptor: "Descriptor one",
amount: "500",
currency: "EUR",
split_payment: "finalized",
leftover_amount: "0",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>sale3d</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<timestamp>2025-01-16T10:23:57Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>500</amount>
<currency>EUR</currency>
<split_payment>finalized</split_payment>
<leftover_amount>0</leftover_amount>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
gaming | 'true' | Signifies whether a gaming transaction is performed. Gaming transactions usually use MCC 7995, contact tech support for more details. |
moto | 'true' | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech support for more details. |
avs_response_code | string(255) | Generated by the card network on trying to match the billing address when performing the address verification. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
avs_response_text | string(255) | Gives the human response text for the AVS response code above. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
cvv_result_code | string(1) | Card Verification Value response code. Optional, returned only if acquirer supports it |
authorization_code | string(6) | Generated by the card network when an authorisation has occurred, used to identify that auth. Consists of 6 alphanumeric chars |
response_code | string(2) | Defines the result of a transaction with the acquirer, the status of a message or some action taken or required. Contact tech-support@emerchantpay.com for more details. |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
partial_approval | string(4) | Optional, set to ’true’ if partial approval happened. Partially approved amount is then in the amount field. Check Partial Approvals for details |
split_payment | string | Split payment status for this transaction. Should be ’finalized’. |
leftover_amount | integer | Leftover amount of transaction in minor currency unit, see Currency Handling for details |
sent_to_acquirer | string(255) | "true" or "false" |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
Error Response
stdClass Object
(
[transaction_type] => sale3d
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[response_code] => 57
[code] => 340
[technical_message] => expiration_year is invalid
[message] => expiration_year is invalid
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:57.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 500
[currency] => EUR
[sent_to_acquirer] => false
)
<payment_response content=[
<transaction_type content=[sale3d]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<response_code content=[57]>
<code content=[340]>
<technical_message content=[expiration_year is invalid]>
<message content=[expiration_year is invalid]>
<timestamp content=[2025-01-16T10:23:57Z]>
<descriptor content=[Descriptor one]>
<amount content=[500]>
<currency content=[EUR]>
<sent_to_acquirer content=[false]>
]>
{
transaction_type: "sale3d",
status: "error",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
response_code: "57",
code: "340",
technical_message: "expiration_year is invalid",
message: "expiration_year is invalid",
timestamp: "2025-01-16T10:23:57Z",
descriptor: "Descriptor one",
amount: "500",
currency: "EUR",
sent_to_acquirer: "false",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>sale3d</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<response_code>57</response_code>
<code>340</code>
<technical_message>expiration_year is invalid</technical_message>
<message>expiration_year is invalid</message>
<timestamp>2025-01-16T10:23:57Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>500</amount>
<currency>EUR</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
gaming | 'true' | Signifies whether a gaming transaction is performed. Gaming transactions usually use MCC 7995, contact tech support for more details. |
moto | 'true' | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech support for more details. |
response_code | string(2) | Defines the result of a transaction with the acquirer, the status of a message or some action taken or required. Contact tech-support@emerchantpay.com for more details. |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
Voiding of split payments:
- Voiding of any transaction in unfinished split payment (while still pending async) will cause rollback of all other transactions in split payment series. The current transaction will appear as voided while the other transaction will become declined.
- Voiding any transaction after the split payment has been completed will cause voiding only of the single transaction. In order to revert such split payment you need to manually void all transactions in it.
- The above points are valid also for refunding the transactions if the gift card gateway supports refund.
Split Payment Timeouts:
- All unfinished split payments will be automatically timed out after a period of time and all transactions in them will be rollbacked.
- If the split payment is finished with async 3D credit card transaction the split payment will be timed out according to the mpi timeout of the final transaction.
Invoice Payment Methods
Alternative payments refer to payment methods that are used as an alternative to credit card payments.
Each alternative payment method has its own unique application, settlement process and currency support.
Invoice
With Invoice transactions, you can confirm that an order is successful.
After settling the transaction (e.g. shipping the goods), you should use invoice capture transaction type to capture the amount.
Invoice transaction will automatically be cancelled after a certain time frame, most likely two weeks.
For a typical e-commerce application it is recommended to authorize the amount on incoming orders and capture it when shipping the goods.
If you choose not to serve the customer, consider to void the invoice to cancel the initial transaction.
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Alternatives\Invoice\Authorize');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setPaymentType('klarna')
->setPaymentMethodCategory('pay_over_time')
->setNotificationUrl('https://www.example.com/notification')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setReturnCancelUrl('http://www.example.com/cancel')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('60')
->setCurrency('EUR')
->setCustomerPhone('1987987987987')
->setCustomerEmail('travis@example.com')
->setCustomerGender('male')
->setCustomerBirthdate('1990-03-20')
->setCustomerReferenceNumber('123')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Berlin')
->setBillingNeighborhood('Lichtenberg')
->setBillingState('Berlin')
->setBillingCountry('DE')
// Shipping Address
->setShippingFirstName('Travis')
->setShippingLastName('Pastrana')
->setShippingAddress1('Muster Str. 12')
->setShippingZipCode('10178')
->setShippingCity('Berlin')
->setShippingNeighborhood('Lichtenberg')
->setShippingState('Berlin')
->setShippingCountry('DE');
// Transaction Items
$items = new \Genesis\API\Request\Financial\Alternatives\Transaction\Items('EUR');
$item = new \Genesis\API\Request\Financial\Alternatives\Transaction\Item();
$item
->setItemType('physical')
->setReference('19-402-USA')
->setName('BatteryPowerPack')
->setQuantity('1')
->setUnitPrice('60')
->setTaxRate('0')
->setTotalAmount('60')
->setTotalDiscountAmount('0')
->setTotalTaxAmount('0')
->setImageUrl('https://example.com/image_url')
->setProductUrl('https://example.com/product_url')
->setQuantityUnit('pcs')
->addMerchantMarketplaceSellerInfo('Electronic gadgets')
$items->addItem($item);
$request->setItems($items);
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>invoice</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<payment_type>klarna</payment_type>
<payment_method_category>pay_over_time</payment_method_category>
<notification_url>https://www.example.com/notification</notification_url>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<return_cancel_url>http://www.example.com/cancel</return_cancel_url>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>60</amount>
<currency>EUR</currency>
<customer_phone>1987987987987</customer_phone>
<customer_email>travis@example.com</customer_email>
<customer_gender>male</customer_gender>
<customer_birthdate>1990-03-20</customer_birthdate>
<customer_reference_number>123</customer_reference_number>
<order_tax_amount>0</order_tax_amount>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Berlin</city>
<neighborhood>Lichtenberg</neighborhood>
<state>Berlin</state>
<country>DE</country>
</billing_address>
<shipping_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Berlin</city>
<neighborhood>Lichtenberg</neighborhood>
<state>Berlin</state>
<country>DE</country>
</shipping_address>
<items>
<item>
<item_type>physical</item_type>
<reference>19-402-USA</reference>
<name>BatteryPowerPack</name>
<quantity>1</quantity>
<unit_price>60</unit_price>
<tax_rate>0</tax_rate>
<total_amount>60</total_amount>
<total_discount_amount>0</total_discount_amount>
<total_tax_amount>0</total_tax_amount>
<image_url>https://example.com/image_url</image_url>
<product_url>https://example.com/product_url</product_url>
<quantity_unit>pcs</quantity_unit>
<merchant_data>
<marketplace_seller_info>Electronic gadgets</marketplace_seller_info>
</merchant_data>
</item>
</items>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: invoice |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
payment_type | required | string | Payment provider type: klarna / secure_invoice |
payment_method_category | required | string(255) | Payment method category: either pay_over_time or pay_later |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
customer_gender | optional | Customer gender | |
customer_birthdate | required* | yyyy-mm-dd | Customer date of birth, required for Secure Invoice |
customer_reference_number | required* | string(255) | Customer reference number, required for Secure Invoice |
order_tax_amount | required | Non-negative, minor units. The total tax amount of the order | |
items | required | List with items | |
item_type | required | string(255) | Order line type. Possible values: Supported item types |
quantity | required | integer | Non-negative. The item quantity |
unit_price | required | integer | Minor units. Includes tax, excludes discount(max value: 100000000) |
total_amount | required | integer | Includes tax and discount. Must match (quantity unit price) - total discount amount divided by quantity (max value: 100000000) |
reference | optional | string(255) | Article number, SKU or similar |
name | optional | string(255) | Descriptive item name |
tax_rate | optional | integer | Non-negative. In percent, two implicit decimals. I.e 2500 = 25.00 percent |
total_discount_amount | optional | integer | Non-negative minor units. Includes tax |
total_tax_amount | optional | integer | Must be within 1 of total amount - total_amount * 10000 / (10000 + tax rate). Negative when type is discount |
image_url | optional | url | URL to an image that can be later embedded in communications between Klarna and the customer. (max 1024 characters) |
product_url | optional | url | URL to an image that can be later embedded in communications between Klarna and the customer. (max 1024 characters) |
quantity_unit | optional | string(8) | Unit used to describe the quantity, e.g. kg, pcs... If defined has to be 1-8 characters |
product_identifiers | optional | List with product identifiers | |
brand | optional | string(255) | The product's brand name as generally recognized by consumers. If no brand is available for a product, do not supply any value |
category_path | optional | string(255) | The product's category path as used in the merchant's webshop. Include the full and most detailed category and separate the segments with ' > ' |
global_trade_item_number | optional | string(255) | The product's Global Trade Item Number (GTIN). Common types of GTIN are EAN, ISBN or UPC. Exclude dashes and spaces, where possible |
manufacturer_part_number | optional | string(255) | The product's Manufacturer Part Number (MPN), which - together with the brand - uniquely identifies a product. Only submit MPNs assigned by a manufacturer and use the most specific MPN possible |
merchant_data | optional | List with merchant data | |
marketplace_seller_info | optional | string(255) | Information for merchant marketplace |
required* = conditionally required
Supported countries:
Country | Country code |
---|---|
Austria | AT |
Denmark | DK |
Finland | FI |
Germany | DE |
Netherlands | NL |
Norway | NO |
Sweden | SE |
Supported item types:
Item Types |
---|
physical |
discount |
shipping fee |
sales tax |
digital |
gift card |
store credit |
surcharge |
Successful Response
stdClass Object
(
[transaction_type] => invoice
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:57.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 60
[currency] => EUR
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>invoice</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<timestamp>2025-01-16T10:23:57Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>60</amount>
<currency>EUR</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => invoice
[status] => error
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 340
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:57.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 60
[currency] => EUR
[sent_to_acquirer] => false
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>invoice</transaction_type>
<status>error</status>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>340</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:57Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>60</amount>
<currency>EUR</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
sent_to_acquirer | string(255) | "true" or "false" |
Invoice Capture
Invoice capture settles a Invoice transaction.
Do this when you are shipping goods, for example. A Invoice capture can only be used after a Invoice on the same transaction.
Therefore, the reference_id
of the Invoice transaction is mandatory.
Transaction workflow:
- The merchant sends invoice transaction to the gateway.
- The gateway replies to it. One of returned values is the unique id of the transaction.
- The merchant sends invoice capture transaction. Its reference id is unique id of invoice response.
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Alternatives\Invoice\Capture');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setPaymentType('klarna')
->setIban('DE09100100101234567891')
->setAccountHolder('Ivan Ivanov')
->setBankTransferRemittanceSlip('123123123')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReferenceId('43672')
->setAmount('60')
->setCurrency('EUR');
// Transaction Items
$items = new \Genesis\API\Request\Financial\Alternatives\Transaction\Items('EUR');
$item = new \Genesis\API\Request\Financial\Alternatives\Transaction\Item();
$item
->setItemType('physical')
->setReference('19-402-USA')
->setName('BatteryPowerPack')
->setQuantity('1')
->setUnitPrice('60')
->setTaxRate('0')
->setTotalAmount('60')
->setTotalDiscountAmount('0')
->setTotalTaxAmount('0')
->setImageUrl('https://example.com/image_url')
->setProductUrl('https://example.com/product_url')
->setQuantityUnit('pcs')
->addMerchantMarketplaceSellerInfo('Electronic gadgets')
$items->addItem($item);
$request->setItems($items);
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>invoice_capture</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<payment_type>klarna</payment_type>
<iban>DE09100100101234567891</iban>
<account_holder>Ivan Ivanov</account_holder>
<bank_transfer_remittance_slip>123123123</bank_transfer_remittance_slip>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<reference_id>43672</reference_id>
<amount>60</amount>
<currency>EUR</currency>
<items>
<item>
<item_type>physical</item_type>
<reference>19-402-USA</reference>
<name>BatteryPowerPack</name>
<quantity>1</quantity>
<unit_price>60</unit_price>
<tax_rate>0</tax_rate>
<total_amount>60</total_amount>
<total_discount_amount>0</total_discount_amount>
<total_tax_amount>0</total_tax_amount>
<image_url>https://example.com/image_url</image_url>
<product_url>https://example.com/product_url</product_url>
<quantity_unit>pcs</quantity_unit>
<merchant_data>
<marketplace_seller_info>Electronic gadgets</marketplace_seller_info>
</merchant_data>
</item>
</items>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: invoice_capture |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
payment_type | required | string | Payment provider type: klarna / secure_invoice |
account_holder | required* | string(255) | Account Holder, required for Secure Invoice in case of Direct Debit payment (payment_method_category: pay_over_time) |
iban | required* | string(255) | IBAN, required for Secure Invoice in case of Direct Debit payment (payment_method_category: pay_over_time) |
bank_transfer_remittance_slip | required* | string(255) | Bank Transfer Remittance Slip, required for Secure Invoice. Less then 16 symbols. |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
reference_id | required | string(32) | Unique id returned by corresponding transaction |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
items | required | List with items | |
item_type | required | string(255) | Order line type. Possible values: Supported item types |
quantity | required | integer | Non-negative. The item quantity |
unit_price | required | integer | Minor units. Includes tax, excludes discount(max value: 100000000) |
total_amount | required | integer | Includes tax and discount. Must match (quantity unit price) - total discount amount divided by quantity (max value: 100000000) |
reference | optional | string(255) | Article number, SKU or similar |
name | optional | string(255) | Descriptive item name |
tax_rate | optional | integer | Non-negative. In percent, two implicit decimals. I.e 2500 = 25.00 percent |
total_discount_amount | optional | integer | Non-negative minor units. Includes tax |
total_tax_amount | optional | integer | Must be within 1 of total amount - total_amount * 10000 / (10000 + tax rate). Negative when type is discount |
image_url | optional | url | URL to an image that can be later embedded in communications between Klarna and the customer. (max 1024 characters) |
product_url | optional | url | URL to an image that can be later embedded in communications between Klarna and the customer. (max 1024 characters) |
quantity_unit | optional | string(8) | Unit used to describe the quantity, e.g. kg, pcs... If defined has to be 1-8 characters |
product_identifiers | optional | List with product identifiers | |
brand | optional | string(255) | The product's brand name as generally recognized by consumers. If no brand is available for a product, do not supply any value |
category_path | optional | string(255) | The product's category path as used in the merchant's webshop. Include the full and most detailed category and separate the segments with ' > ' |
global_trade_item_number | optional | string(255) | The product's Global Trade Item Number (GTIN). Common types of GTIN are EAN, ISBN or UPC. Exclude dashes and spaces, where possible |
manufacturer_part_number | optional | string(255) | The product's Manufacturer Part Number (MPN), which - together with the brand - uniquely identifies a product. Only submit MPNs assigned by a manufacturer and use the most specific MPN possible |
merchant_data | optional | List with merchant data | |
marketplace_seller_info | optional | string(255) | Information for merchant marketplace |
required* = conditionally required
Supported countries:
Country | Country code |
---|---|
Austria | AT |
Denmark | DK |
Finland | FI |
Germany | DE |
Netherlands | NL |
Norway | NO |
Sweden | SE |
Supported item types:
Item Types |
---|
physical |
discount |
shipping_fee |
sales_tax |
digital |
gift_card |
store_credit |
surcharge |
Successful Response
stdClass Object
(
[transaction_type] => invoice_capture
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:57.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 60
[currency] => EUR
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>invoice_capture</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<timestamp>2025-01-16T10:23:57Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>60</amount>
<currency>EUR</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => invoice_capture
[status] => error
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 340
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:57.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 60
[currency] => EUR
[sent_to_acquirer] => false
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>invoice_capture</transaction_type>
<status>error</status>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>340</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:57Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>60</amount>
<currency>EUR</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
sent_to_acquirer | string(255) | "true" or "false" |
Crypto
Alternative payment methods supporting digital cryptocurrencies.
BitPay Sale
BitPay is a cryptocurrency payments provider supporting blockchain payments with Bitcoin (BTC) and BitcoinCash (BCH).
BitPay Sale is an asynchronous transaction type.
When this payment method is selected at checkout, the customer will be redirected to the BitPay system window including all the data for the payment: Bitcoin/BitcoinCash account, amount to be paid in cryptocurrency and the Fiat equivalent.
If the customer possesses a BitPay wallet or another BitPay compatible crypto wallet, the payment can be done from that window with one click, otherwise a QR CODE containing all the payment data can be scanned and used in any crypto wallet.
Then the customer has 15 minutes to fulfill the generated invoice.
If that timeframe is not met, the invoice will expire and the Merchant will be notified.
If the invoice is fulfilled in the timeframe, it needs to obtain 6 blockchain confirmations (1 hour) before it’s safe for the payment to be considered as completed.
At that point, the Merchant will be notified for the approved payment.
After the 6th confirmation, when the transaction is completed, the Merchant can process a refund if it’s needed.
Supported countries
Country name | Country code |
---|---|
Afghanistan | AF |
Aland Islands | AX |
Albania | AL |
American Samoa | AS |
Andorra | AD |
Angola | AO |
Anguilla | AI |
Antarctica | AQ |
Antigua and Barbuda | AG |
Argentina | AR |
Armenia | AM |
Aruba | AW |
Australia | AU |
Austria | AT |
Azerbaijan | AZ |
Bahamas | BS |
Bahrain | BH |
Barbados | BB |
Belarus | BY |
Belgium | BE |
Belize | BZ |
Benin | BJ |
Bermuda | BM |
Bhutan | BT |
Bonaire, Sint Eustatius and Saba | BQ |
Bosnia and Herzegovina | BA |
Botswana | BW |
Bouvet Island | BV |
Brazil | BR |
British Indian Ocean Territory | IO |
Brunei Darussalam | BN |
Bulgaria | BG |
Burkina Faso | BF |
Burundi | BI |
Cameroon | CM |
Canada | CA |
Cape Verde | CV |
Cayman Islands | KY |
Central African Republic | CF |
Chad | TD |
Chile | CL |
China | CN |
Christmas Island | CX |
Cocos (Keeling) Islands | CC |
Colombia | CO |
Comoros | KM |
Congo | CG |
Congo, the Democratic Republic of the | CD |
Cook Islands | CK |
Costa Rica | CR |
Cote D'Ivoire | CI |
Croatia | HR |
Cuba | CU |
Curacao | CW |
Cyprus | CY |
Czech Republic | CZ |
Denmark | DK |
Djibouti | DJ |
Dominica | DM |
Dominican Republic | DO |
El Salvador | SV |
Equatorial Guinea | GQ |
Eritrea | ER |
Estonia | EE |
Ethiopia | ET |
Falkland Islands (Malvinas) | FK |
Faroe Islands | FO |
Fiji | FJ |
Finland | FI |
France | FR |
French Guiana | GF |
French Polynesia | PF |
French Southern Territories | TF |
Gabon | GA |
Gambia | GM |
Georgia | GE |
Germany | DE |
Ghana | GH |
Gibraltar | GI |
Greece | GR |
Greenland | GL |
Grenada | GD |
Guadeloupe | GP |
Guam | GU |
Guatemala | GT |
Guernsey | GG |
Guinea | GN |
Guinea-Bissau | GW |
Guyana | GY |
Haiti | HT |
Heard Island and McDonald Islands | HM |
Holy See (Vatican City State) | VA |
Honduras | HN |
Hong Kong | HK |
Hungary | HU |
Iceland | IS |
India | IN |
Iran, Islamic Republic of | IR |
Ireland | IE |
Isle of Man | IM |
Israel | IL |
Italy | IT |
Jamaica | JM |
Japan | JP |
Jersey | JE |
Jordan | JO |
Kazakhstan | KZ |
Kenya | KE |
Kiribati | KI |
Korea, Democratic People's Republic of | KP |
Korea, Republic of | KR |
Kosovo, Republic of | XK |
Kuwait | KW |
Lao People's Democratic Republic | LA |
Latvia | LV |
Lebanon | LB |
Lesotho | LS |
Liberia | LR |
Libyan Arab Jamahiriya | LY |
Liechtenstein | LI |
Lithuania | LT |
Luxembourg | LU |
Macao | MO |
Madagascar | MG |
Malawi | MW |
Malaysia | MY |
Maldives | MV |
Mali | ML |
Malta | MT |
Marshall Islands | MH |
Martinique | MQ |
Mauritania | MR |
Mauritius | MU |
Mayotte | YT |
Mexico | MX |
Micronesia, Federated States of | FM |
Moldova, Republic of | MD |
Monaco | MC |
Mongolia | MN |
Montenegro | ME |
Montserrat | MS |
Mozambique | MZ |
Myanmar | MM |
Namibia | NA |
Nauru | NR |
Netherlands | NL |
Netherlands Antilles | AN |
New Caledonia | NC |
New Zealand | NZ |
Nicaragua | NI |
Niger | NE |
Nigeria | NG |
Niue | NU |
Norfolk Island | NF |
Northern Mariana Islands | MP |
Norway | NO |
Oman | OM |
Palau | PW |
Panama | PA |
Papua New Guinea | PG |
Paraguay | PY |
Peru | PE |
Philippines | PH |
Pitcairn | PN |
Poland | PL |
Portugal | PT |
Puerto Rico | PR |
Qatar | QA |
Reunion | RE |
Romania | RO |
Russian Federation | RU |
Rwanda | RW |
Saint Barthélemy | BL |
Saint Helena | SH |
Saint Kitts and Nevis | KN |
Saint Lucia | LC |
Saint Martin French Part | MF |
Saint Pierre and Miquelon | PM |
Saint Vincent and the Grenadines | VC |
Samoa | WS |
San Marino | SM |
Sao Tome and Principe | ST |
Saudi Arabia | SA |
Senegal | SN |
Serbia | RS |
Seychelles | SC |
Sierra Leone | SL |
Singapore | SG |
Sint Maarten (Dutch part) | SX |
Slovakia | SK |
Slovenia | SI |
Solomon Islands | SB |
Somalia | SO |
South Africa | ZA |
South Georgia and the South Sandwich Islands | GS |
South Sudan | SS |
Spain | ES |
Sri Lanka | LK |
Sudan | SD |
Suriname | SR |
Svalbard and Jan Mayen | SJ |
Swaziland | SZ |
Sweden | SE |
Switzerland | CH |
Syrian Arab Republic | SY |
Taiwan, Province of China | TW |
Tajikistan | TJ |
Tanzania, United Republic of | TZ |
Thailand | TH |
Timor-Leste | TL |
Togo | TG |
Tokelau | TK |
Tonga | TO |
Trinidad and Tobago | TT |
Tunisia | TN |
Turkmenistan | TM |
Turks and Caicos Islands | TC |
Tuvalu | TV |
Uganda | UG |
Ukraine | UA |
United Arab Emirates | AE |
United Kingdom | GB |
United States | US |
United States Minor Outlying Islands | UM |
Uruguay | UY |
Uzbekistan | UZ |
Vanuatu | VU |
Venezuela, Bolivarian Republic of | VE |
Virgin Islands, British | VG |
Virgin Islands, U.S. | VI |
Wallis and Futuna | WF |
Western Sahara | EH |
Yemen | YE |
Zambia | ZM |
Zimbabwe | ZW |
Supported currencies
Currency name | Currency code |
---|---|
Afghan Afghani | AFN |
Albanian Lek | ALL |
Angolan Kwanza | AOA |
Argentine Peso | ARS |
Armenian Dram | AMD |
Aruban Florin | AWG |
Australian Dollar | AUD |
Azerbaijani Manat | AZN |
Bahamian Dollar | BSD |
Bahraini Dinar | BHD |
Barbadian Dollar | BBD |
Belarusian Ruble | BYN |
Belize Dollar | BZD |
Bermudan Dollar | BMD |
Bhutanese Ngultrum | BTN |
Bosnia-Herzegovina Convertible Mark | BAM |
Botswanan Pula | BWP |
Brazilian Real | BRL |
British Pound Sterling | GBP |
Brunei Dollar | BND |
Bulgarian Lev | BGN |
Burundian Franc | BIF |
CFA Franc BCEAO | XOF |
CFA Franc BEAC | XAF |
CFP Franc | XPF |
Canadian Dollar | CAD |
Cape Verdean Escudo | CVE |
Cayman Islands Dollar | KYD |
Chilean Peso | CLP |
Chinese Yuan | CNY |
Colombian Peso | COP |
Comorian Franc | KMF |
Congolese Franc | CDF |
Costa Rican Colón | CRC |
Croatian Kuna | HRK |
Cuba Pesos | CUP |
Czech Republic Koruna | CZK |
Danish Krone | DKK |
Djiboutian Franc | DJF |
Dominican Peso | DOP |
East Caribbean Dollar | XCD |
Eritrean Nakfa | ERN |
Ethiopian Birr | ETB |
Falkland Islands Pound | FKP |
Fijian Dollar | FJD |
Gambian Dalasi | GMD |
Georgian Lari | GEL |
Ghanaian Cedi | GHS |
Gibraltar Pound | GIP |
Guatemalan Quetzal | GTQ |
Guinean Franc | GNF |
Guyanaese Dollar | GYD |
Haitian Gourde | HTG |
Honduran Lempira | HNL |
Hong Kong Dollar | HKD |
Hungarian Forint | HUF |
Icelandic Króna | ISK |
Indian Rupee | INR |
Iran, Rials | IRR |
Israeli New Sheqel | ILS |
Jamaican Dollar | JMD |
Japanese Yen | JPY |
Jordanian Dinar | JOD |
Kazakhstani Tenge | KZT |
Kenyan Shilling | KES |
Korea (North), Won | KPW |
Kuwaiti Dinar | KWD |
Laotian Kip | LAK |
Lebanese Pound | LBP |
Lesotho Loti | LSL |
Liberian Dollar | LRD |
Libyan Dinar | LYD |
Macanese Pataca | MOP |
Malagasy Ariary | MGA |
Malawian Kwacha | MWK |
Malaysian Ringgit | MYR |
Maldivian Rufiyaa | MVR |
Mauritanian Ouguiya | MRU |
Mauritian Rupee | MUR |
Mexican Peso | MXN |
Moldovan Leu | MDL |
Mongolian Tugrik | MNT |
Mozambican Metical | MZN |
Myanma Kyat | MMK |
Namibian Dollar | NAD |
Netherlands Antillean Guilder | ANG |
New Taiwan Dollar | TWD |
New Zealand Dollar | NZD |
Nicaraguan Córdoba | NIO |
Nigerian Naira | NGN |
Norwegian Krone | NOK |
Omani Rial | OMR |
Panamanian Balboa | PAB |
Papua New Guinean Kina | PGK |
Paraguayan Guarani | PYG |
Peruvian Nuevo Sol | PEN |
Philippine Peso | PHP |
Polish Zloty | PLN |
Qatari Rial | QAR |
Romanian Leu | RON |
Russian Ruble | RUB |
Rwandan Franc | RWF |
Saint Helena Pound | SHP |
Salvadoran Colón | SVC |
Samoan Tala | WST |
Saudi Riyal | SAR |
Serbian Dinar | RSD |
Seychellois Rupee | SCR |
Sierra Leonean Leone | SLL |
Singapore Dollar | SGD |
Solomon Islands Dollar | SBD |
Somali Shilling | SOS |
South African Rand | ZAR |
South Korean Won | KRW |
South Sudanese Pound | SSP |
Sri Lankan Rupee | LKR |
Sudan, Pounds | SDG |
Surinamese Dollar | SRD |
Swazi Lilangeni | SZL |
Swedish Krona | SEK |
Swiss Franc | CHF |
Syria Pounds | SYP |
São Tomé and Príncipe Dobra | STN |
Tajikistani Somoni | TJS |
Tanzanian Shilling | TZS |
Thai Baht | THB |
Tongan Paʻanga | TOP |
Trinidad and Tobago Dollar | TTD |
Tunisian Dinar | TND |
Turkmenistani Manat | TMT |
Ugandan Shilling | UGX |
Ukraine, Hryvnia | UAH |
United Arab Emirates Dirham | AED |
Uruguayan Peso | UYU |
Uzbekistan Som | UZS |
Vanuatu Vatu | VUV |
Yemeni Rial | YER |
Zambian Kwach | ZMW |
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Crypto\BitPay\Sale');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReturnUrl('https://staging.gate.emerchantpay.net/redirect/to_acquirer/a55ab44d242f')
->setAmount('3000')
->setCurrency('EUR')
->setCustomerEmail('travis@example.com')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Berlin')
->setBillingCountry('DE');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>bitpay_sale</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/a55ab44d242f</return_url>
<amount>3000</amount>
<currency>EUR</currency>
<customer_email>travis@example.com</customer_email>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Berlin</city>
<country>DE</country>
</billing_address>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: bitpay_sale |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | optional | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_url | required | url | URL where consumer is sent to after payment |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
customer_email | required | e-mail address | Must contain valid e-mail of customer |
billing_address | required* | See Required vs Optional API params for details | |
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Successful Response
stdClass Object
(
[transaction_type] => bitpay_sale
[status] => approved
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[redirect_url] => https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:57.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 3000
[currency] => EUR
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>bitpay_sale</transaction_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/649e1ff35c61</redirect_url>
<timestamp>2025-01-16T10:23:57Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>3000</amount>
<currency>EUR</currency>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => bitpay_sale
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 110
[technical_message] => Something went wrong, please contact support!
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:57.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 3000
[currency] => EUR
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>bitpay_sale</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<technical_message>Something went wrong, please contact support!</technical_message>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:57Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>3000</amount>
<currency>EUR</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Payouts
Bank Pay-out
Bank Pay-out option allows merchants to transfer funds directly to their consumers' bank account.
To process a bank pay-out via Trustly system, you need to have your customer’s unique Account_ID. It is returned to your notification url during initial Trustly sale transaction. Alternatively, you may generate new customer’s Account_ID via one the following steps: Trustly-register-account or Trustly-select-account
Once you’ve got your consumer’s Account_ID, you may proceed to the Bank-Pay-out call.
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\OnlineBankingPayments\OnlineBanking\Payout');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setNotificationUrl('https://www.example.com/notification')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setAmount('50000')
->setCurrency('INR')
->setCustomerPhone('+1987987987987')
->setCustomerEmail('travis@example.com')
->setBankName('Netbanking')
->setBankCode('321')
->setBankBranch('HDFC0000001')
->setBankAccountNumber('1234123412341234')
->setBankAccountName('Anurak Nghuen')
->setIdCardNumber('123789456')
->setPayerBankPhoneNumber('01234567891')
->setBankAccountType('C')
->setBankAccountVerificationDigit('1')
->setDocumentType('PASS')
->setPaymentType('bank_to_bank')
// Billing Address
->setBillingFirstName('Anurak')
->setBillingLastName('Nghuen')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('New Delhi')
->setBillingState('New Delhi')
->setBillingCountry('IN')
->setCompanyType('EIRELI')
->setCompanyActivity('Mining')
->setIncorporationDate('2020-03-02')
->setMothersName('Maria')
->setPixKey('78690450041');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>bank_payout</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<notification_url>https://www.example.com/notification</notification_url>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<amount>50000</amount>
<currency>INR</currency>
<customer_phone>+1987987987987</customer_phone>
<customer_email>travis@example.com</customer_email>
<bank_name>Netbanking</bank_name>
<bank_code>321</bank_code>
<bank_branch>HDFC0000001</bank_branch>
<bank_account_number>1234123412341234</bank_account_number>
<bank_account_name>Anurak Nghuen</bank_account_name>
<id_card_number>123789456</id_card_number>
<payer_bank_phone_number>01234567891</payer_bank_phone_number>
<bank_account_type>C</bank_account_type>
<bank_account_verification_digit>1</bank_account_verification_digit>
<document_type>PASS</document_type>
<payment_type>bank_to_bank</payment_type>
<billing_address>
<first_name>Anurak</first_name>
<last_name>Nghuen</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>New Delhi</city>
<state>New Delhi</state>
<country>IN</country>
</billing_address>
<company_type>EIRELI</company_type>
<company_activity>Mining</company_activity>
<incorporation_date>2020-03-02</incorporation_date>
<mothers_name>Maria</mothers_name>
<pix_key>78690450041</pix_key>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: bank_payout |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
notification_url | required | url | URL at merchant where gateway sends outcome of transaction. |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
bank_name | optional | bank name | Name of the bank. If specified, it must be one of the supported Bank Names |
bank_code | required | bank code | The bank code used to process the transaction. Must be one of the supported Bank codes. |
customer_email | required* | e-mail address | Must contain valid e-mail of customer |
customer_phone | required1 | string(32) | Must contain valid phone number of customer |
bank_branch | required* | bank branch | Name of the Bank branch |
bank_account_name | required* | bank account name | Bank account name is required, for CNY currency and should be in Simplified Chinese. For other currency, must be in English Language. |
bank_account_number | required* | bank account number | Bank account number of the customer. |
bank_province | required* | bank province | Name of the province that the bank is located. |
id_card_number | required* | id card number | ID card number. See Document ID Parameter for more details. |
payer_bank_phone_number | required* | string(11) | Payer bank phone number |
bank_account_type | required* | string(1) | The type of account. C: for Checking accounts S: for Savings accounts M: for Maestra accounts(Only Peru) P: for Payment accounts |
bank_account_verification_digit | required* | string(1) | Verifier digit. Given by external provider, used to verify transaction. |
document_type | required* | string(10) | ID card/document type |
account_id | required* | string(255) | Unique account identifier in Trustly's system. You will receive this after Select Account call and after Trustly Sale on the notification URL. |
user_id | required* | string(255) | Unique user identifier defined by merchant in their own system. ID, username, hash or anything uniquely identifying the consumer requesting the deposit. Must be static per each consumer for any type of transaction where this consumer is involved (trustly_sale, bank pay_out, register_account, select account). |
birth_date | required* | dd-mm-yyyy | Required for Visa only when MCC is a Financial Services one (e.g. MCC 6012) |
payment_type | required* | string(12) | Bank payout subtype. Available values: bank_to_bank, pix, bsb, pay_id, bank_to_bank_b2b, pix_b2b |
company_type | required* | string(255) | Company type of the customer. For Legal Person. |
company_activity | required* | string(255) | Company activity of the customer. For Legal Person. |
incorporation_date | required* | yyyy-mm-dd | The incoroporation date of the customer. For Legal Person. |
mothers_name | required* | string(255) | Mother's name of the customer. |
pix_key | required* | string(255) | PIX key of the customer. |
billing_address | required | See Required vs Optional API params for details | |
first_name | required | string(255) | Customer first name |
last_name | required | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
required* = conditionally required
1 - Only for Brazilian transactions allowed characters are as follows:
- 12345678901: Exactly 11 digits.
- +1234567890123: An optional plus sign followed by exactly 13 digits.
Supported currencies
Currency name | Currency code |
---|---|
Argentine peso | ARS |
Brazilian real | BRL |
Chilean peso | CLP |
China yen | CNY |
Colombian peso | COP |
Indonesian rupiah | IDR |
Indian rupee | INR |
Malaysian ringgit | MYR |
Mexican peso | MXN |
Peruvian sol | PEN |
Thai baht | THB |
Uruguayan peso | UYU |
Bank Names
For CAD currency:
Bank Name |
---|
Interac e-Transfer Outbound Pay-out |
eCashout Pay-out |
For CNY currency:
Bank Name |
---|
中国银行 |
中国交通银行 |
中信银行 |
上海浦发银行 |
中国农业银行 |
中国渤海银行 |
上海银行 |
中国工商银行 |
东亚银行 |
上海农商银行 |
中国建设银行 |
中国兴业银行 |
平安银行 |
广发银行 |
北京农商银行 |
宁波银行 |
光大银行 |
北京银行 |
大连银行 |
尧都农商银行 |
徽商银行 |
华夏银行 |
南京银行 |
广州银行 |
浙商银行 |
招商银行 |
民生银行 |
汉口银行 |
晋商银行 |
杭州银行 |
深圳发展银行 |
江苏银行 |
成都银行 |
珠海农商银行 |
顺德农村商业银行 |
中国邮政银行 |
银联通道 |
For MYR currency:
Bank Name |
---|
423 |
CIMB Clicks Bank |
Hong Leong Bank |
May Bank |
Public Bank |
RHB Bank |
For THB currency:
Bank Name |
---|
Bangkok Bank |
Kasikorn Bank |
Krungsri (Bank of Ayudhya Public Company Limited) |
Krung Thai Bank |
Siam Commercial Bank |
UOBT |
For IDR currency:
Bank Name |
---|
Bank Central Asia |
Bank Rakyat Indonesia |
Bank Negara Indonesia |
BTN Bank |
CIMB Clicks Indonesia |
Danamon Bank |
Mandiri Bank |
Permata Bank |
For INR currency:
Bank Name |
---|
ABHYUDAYA COOP BANK |
THE ROYAL BANK OF SCOTLAND |
ABU DHABI COMMERCIAL BANK |
THE AKOLA DISTRICT CENTRAL COOPERATIVE BANK |
AIRTEL PAYMENTS BANK LIMITED |
AKOLA JANATA COMMERCIAL COOPERATIVE BANK |
ALLAHABAD BANK |
THE AHMEDABAD MERC COOP BANK |
ANDHRA BANK |
AUSTRALIA & NEW ZEALAND BANK |
THE ANDHRA PRADESH STATE COOP BANK |
ANDHRA PRAGATI GRAMEEN BANK |
THE A.P. MAHESH CO-OP URBAN BANK |
APNA SAHAKARI BANK LTD |
ALMORA URBAN CO-OPERATIVE BANK LTD. |
BASSEIN CATHOLIC CO-OP BANK |
BANK OF BARODA |
BARCLAYS BANK |
BANK OF BAHREIN & KUWAIT |
THE BHARAT COOPERATIVE BANK |
BANK OF CEYLON |
BANDHAN BANK LIMITED |
DENA BANK |
BANK OF INDIA |
BHARATIYA MAHILA BANK LIMITED |
B N PARIBAS BANK |
BANK OF AMERICA |
BANK OF TOKYO-MITSUBISHI |
CENTRAL BANK OF INDIA |
CITIZEN CREDIT COOP BANK |
JP MORGAN CHASE BANK |
CITI BANK |
CITY UNION BANK |
CAPITAL LOCAL AREA BANK LTD. |
CANARA BANK |
CORPORATION BANK |
THE COSMOS CO-OP. BANK |
CREDIT SUISSE AG? |
CREDIT AGRICOLE CORP N INVSMNT BK |
CHHATRAPATI RAJARSHISHAHU COOP BANK |
CATHOLIC SYRIAN BANK |
COMMONWEALTH BK OF AUSTRALIA |
CHINATRUST COMMERCIAL BANK |
DEVELOPMENT BANK OF SINGAPORE |
DEVELOPMENT CREDIT BANK |
DEOGIRI NAGARI SAHAKARI BANK LTD. AURANGABAD |
DEUTSCHE BANK |
DICGC |
THE DELHI STATE COOPERATIVE BANK LIMITED |
DHANALAXMI BANK |
DOMBIVLI NAGARI SAHAKARI BANK LTD |
DOHA BANK QSC |
EXPORT IMPORT BANK OF INDIA |
EQUITAS SMALL FINANCE BANK LIMITED |
THE FEDERAL BANK |
FIRSTRAND BANK |
THE GREATER BOMBAY CO-OP. BANK LTD |
THE GADCHIROLI DISTRICT CENTRAL COOPERATIVE BANK LIMITED |
GURGAON GRAMIN BANK LTD. |
THE GUJARAT STATE CO-OPERATIVE BANK |
THE HASTI COOP BANK LTD |
HDFC BANK LTD. |
HIMACHAL PRADESH STATE COOPERATIVE BANK LTD |
HONG KONG & SHANGHAI BANK |
Woori |
PT BANK MAYBANK INDONESIA TBK |
IDBI BANK |
INDUSTRIAL BANK OF KOREA |
INDUSTRIAL AND COMMERCIAL BANK OF CHINA LIMITED |
ICICI BANK LTD. |
IDFC BANK LIMITED |
INDIAN BANK |
IDUKKI DISTRICT CO OPERATIVE BANK LTD |
INDUS-IND BANK |
INDIAN OVERSEAS BANK |
THE JAMMU & KASHMIR BANK |
JANSEVA SHAHKARI BANK LTD. PUNE |
JANASEVA SAHAKARI BANK BORIVLI LIMITED |
JALGAON JANATA SAHAKARI |
THE JALGAON PEOPELS COOPERATIVE BANK LIMITED |
JANKALYAN SHAKARI BANK |
JANATA SAHAKARI BANK LTD (PUNE) |
THE KANGRA CENTRAL COOPERATIVE BANK |
KALLAPPANNA AWADE ICH JANATA S |
THE KANGRA COOPERATIVE BANK LTD |
KARNATAKA BANK |
KAPOLE BANK |
THE KALUPUR COMM COOP BANK |
THE KALYAN JANATA SAHAKARI BANK |
KOTAK MAHINDRA BANK |
KERALA GRAMIN BANK |
THE KURMANCHAL NAGAR SAHAKARI BANK LIMITED |
THE KARNATAKA STATE COOP APEX BANK |
KEB Hana Bank |
THE KARAD URBAN COOP BANK LTD |
KARUR VYSYA BANK |
KARNATAKA GRAMIN VIKAS BANK |
THE LAKSHMI VILAS BANK |
BANK OF MAHARASHTRA |
Maharashtra Gramin Bank |
MAHANAGAR COOP BANK |
MUMBAI DISTRICT CENTRAL CO-OP BANK |
MIZUHO CORPORATE BANK LTD |
Maharashtra State Cooperative Bank |
MASHREQ BANK |
THE MEHSANA URBAN COOPERATIVE BANK |
THE MUNICIPAL CO OPERATIVE BANK LTD |
NATIONAL AUSTRALIA BANK LIMITED |
NATIONAL BANK OF ABU DHABI PJSC |
NAGPUR NAGRIK (NNSB LTD*) |
NEW INDIA CO-OPERATIVE BANK |
NKGSB BANK |
THE NASIK MERCHANTS CO-OP BANK LTD. |
NORTH MALBAR GRAMIN BANK |
NUTAN NAGARIK SAHAKARI BANK |
THE BANK OF NOVA SCOTIA |
THE NAINITAL BANK LTD |
NAGAR URBAN CO OPERATIVE BANK |
OMAN INTERNATIONAL BANK |
ORIENTAL BANK OF COMMERCE |
PARSIK JANATA SAHAKARI BANK |
PRAGATHI KRISHNA GRAMIN BANK |
PUNJAB AND MAHARASHTRA CO-OP BANK |
PRIME CO OPERATIVE BANK LTD |
PRATHAMA BANK |
PUNJAB AND SIND BANK |
THE PANDHARPUR URBAN CO OP. BANK LTD. PANDHARPUR |
PUNJAB NATIONAL BANK |
RABOBANK INTERNATIONAL (CCRB) |
THE RATNAKAR BANK |
RESERVE BANK OF INDIA |
RAJKOT NAGARIK SAHAKARI BANK LTD |
RAJGURUNAGAR SAHAKARI BANK LIMITED |
THE RAJASTHAN STATE CO-OP BANK |
SBERBANK |
SAHEBRAO DESHMUKH COOPERATIVE BANK LIMITED |
STATE BANK OF BIKANER AND JAIPUR |
STATE BANK OF HYDERABAD |
STATE BANK OF INDIA |
STATE BANK OF MYSORE |
SAMARTH SAHAKARI BANK LTD |
STATE BANK OF TRAVANCORE |
STANDARD CHARTERED BANK |
THE SURAT DISTRICT CO-OP BAN |
SHINHAN BANK |
SHIKSHAK SAHAKARI BANK LIMITED |
SOUTH INDIAN BANK |
SOLAPUR JANATA SAHAKARI BANK LIMITED |
SUMITOMO MITSUI BANKING CORPORATION |
SHIVALIK MERCANTILE CO OPERATIVE BANK LTD |
SOCIETE GENERALE |
THE SURAT PEOPLE?S CO-OP BANK |
THE SARASWAT CO-OPERATIVE BANK |
STATE BANK OF PATIALA |
STATE BANK OF MAURITIUS |
SURAT NATIONAL COOPERATIVE BANK LIMITED |
THE SUTEX COOPERATIVE BANK |
THE SEVA VIKAS COOPERATIVE BANK LIMITED |
THE SHAMRAO VITHAL COOP BANK |
SYNDICATE BANK |
THANE BHARAT SAHAKARI BANK LTD |
THE THANE DISTRICT CENTRAL COOPERATIVE BANK LIMITED |
TUMKUR GRAIN MERCHANTS CO-OP BANK |
THE THANE JANATA SAHAKARI BANK |
TAMILNADU MERC. BANK |
THE TAMILDADU STATE APEX COOP BANK |
UNION BANK OF INDIA |
UBS AG |
UCO BANK |
UNITED OVERSEAS BANK LIMITED |
UNITED BANK OF INDIA |
AXIS BANK |
THE VARACHHA CO-OP. BANK LTD. |
VIJAYA BANK |
THE VISHWESHWAR SAHAKARI BANK LTD |
VASAI VIKAS SAHAKARI BANK |
ING VYSYA BANK |
THE WEST BENGAL STATE CO-OP BANK |
WESTPAC BANKING CORPORATION |
YES BANK |
THE ZOROASTRIAN COOPERATIVE BANK LIMITED |
ZILA SAHAKRI BANK LIMITED GHAZIABAD |
Paytm Payments Bank Ltd. |
For ARS currency:
Bank Name |
---|
CVU Account |
Banco de Galicia Y Buenos Aires |
Banco de La Nacion Argentina |
Banco de La Provincia de Buenos Aires |
Industrial and Commercial Bank of China (ICBC) Argentina |
BBVA |
Banco de La Provincia de Cordoba |
Banco Supervielle S.A. |
Banco de La Ciudad de Buenos Aires |
Banco Patagonia Sudameris |
Banco Hipotecario |
Banco de San Juan |
Banco Municipal de Rosario |
Banco Santander |
Banco Del Chubut |
Banco de Santa Cruz |
Banco de La Pampa Sociedad de Economia M |
Banco de Corrientes |
Banco Provincia Del Neuquen |
Brubank S.A.U. |
Banco B. I. Creditanstalt |
HSBC Bank Argentina |
J P Morgan Chase Bank Sucursal Buenos Aires |
Banco Credicoop Coop. L |
Banco de Valores |
Banco Roela |
Banco Mariva |
Banco Itau |
Bank Of America, National Associa |
Bnp Paribas |
Banco Provincia de Tierra Del Fuego |
Banco de La Republica Oriental Del Uruguay |
Banco Saenz |
Banco Meridian |
Banco Macro |
Banco Comafi |
Banco de Inversion Y Comercio Exterior |
Banco Piano |
Banco Julio |
Nuevo Banco de La Rioja |
Banco Del Sol |
Nuevo Banco Del Chaco |
BANCO VOII S.A. |
Banco de Formosa |
Banco CMF |
Banco de Santiago Del Estero |
Nuevo Banco Industrial de Azul |
Deutsche Bank |
Nuevo Banco de Santa Fe |
Banco Cetelem Argentina |
Banco de Servicios Financieros |
Banco Cofidis |
Banco Bradesco Argentina |
Banco de Servicios Y Transacciones |
RCI Banque Argentina |
Bacs Banco de Credito Y Securitizacion |
Banco Mas Ventas |
Wilobank S.A. |
Nuevo Banco de Entre Rios |
Banco Columbia |
Banco Bica S.A. |
Banco Coinag S.A. |
Banco de Comercio S.A. |
Banco Sucredito Regional S.A.U. |
Banco Dino S.A. |
Bank of Chine Limited Sucursal Buenos Aires |
For BRL currency
Bank Code | Bank Name |
---|---|
001 | BANCO DO BRASIL S.A. |
003 | BANCO DA AMAZONIA S.A. |
004 | BANCO DO NORDESTE DO BRASIL S.A. |
007 | BANCO NACIONAL DE DESENVOLVIMENTO ECONOMICO E SOCIAL |
010 | CREDICOAMO CREDITO RURAL COOPERATIVA |
011 | CREDIT SUISSE HEDGING-GRIFFO CORRETORA DE VALORES S.A |
012 | BANCO INBURSA S.A. |
014 | STATE STREET BRASIL S.A. - BANCO COMERCIAL |
015 | UBS BRASIL CORRETORA DE CÂMBIO, TÍTULOS E VALORES MOBILIÁRIOS S.A. |
016 | COOPERATIVA DE CRÉDITO MÚTUO DOS DESPACHANTES DE TRÂNSITO DE SANTA CATARINA E RI |
017 | BNY MELLON BANCO S.A. |
018 | BANCO TRICURY S.A. |
021 | BANESTES S.A. BANCO DO ESTADO DO ESPIRITO SANTO |
024 | BANCO BANDEPE S.A. |
025 | BANCO ALFA S.A. |
029 | BANCO ITAÚ CONSIGNADO S.A. |
033 | BANCO SANTANDER (BRASIL) S.A. |
036 | BANCO BRADESCO BBI S.A. |
037 | BANCO DO ESTADO DO PARÁ S.A. |
040 | BANCO CARGILL S.A. |
041 | BANCO DO ESTADO DO RIO GRANDE DO SUL S.A. |
047 | BANCO DO ESTADO DE SERGIPE S.A. |
060 | CONFIDENCE CORRETORA DE CÂMBIO S.A. |
062 | HIPERCARD BANCO MÚLTIPLO S.A. |
063 | BANCO BRADESCARD S.A. |
064 | GOLDMAN SACHS DO BRASIL BANCO MULTIPLO S.A. |
065 | BANCO ANDBANK (BRASIL) S.A. |
066 | BANCO MORGAN STANLEY S.A. |
069 | BANCO CREFISA S.A. |
070 | BRB - BANCO DE BRASILIA S.A. |
074 | BANCO J. SAFRA S.A. |
075 | BANCO ABN AMRO S.A. |
076 | BANCO KDB DO BRASIL S.A. |
077 | BANCO INTER S.A. |
078 | HAITONG BANCO DE INVESTIMENTO DO BRASIL S.A. |
079 | PICPAY BANK - BANCO MÚLTIPLO S.A |
080 | B&T CORRETORA DE CAMBIO LTDA. |
081 | BANCOSEGURO S.A. |
082 | BANCO TOPÁZIO S.A. |
083 | BANCO DA CHINA BRASIL S.A. |
084 | UNIPRIME DO BRASIL - COOPERATIVA DE CRÉDITO |
085 | COOPERATIVA CENTRAL DE CRÉDITO - AILOS |
088 | BANCO RANDON S.A. |
089 | CREDISAN COOPERATIVA DE CRÉDITO |
093 | PÓLOCRED SOCIEDADE DE CRÉDITO AO MICROEMPREENDEDOR E À EMPRESA DE PEQUENO PORT |
094 | BANCO FINAXIS S.A. |
095 | TRAVELEX BANCO DE CÂMBIO S.A. |
096 | BANCO B3 S.A. |
097 | CREDISIS - CENTRAL DE COOPERATIVAS DE CRÉDITO LTDA. |
098 | CREDIALIANÇA COOPERATIVA DE CRÉDITO RURAL |
099 | UNIPRIME CENTRAL NACIONAL - CENTRAL NACIONAL DE COOPERATIVA DE CREDITO |
100 | PLANNER CORRETORA DE VALORES S.A. |
101 | RENASCENCA DISTRIBUIDORA DE TÍTULOS E VALORES MOBILIÁRIOS LTDA |
102 | XP INVESTIMENTOS CORRETORA DE CÂMBIO,TÍTULOS E VALORES MOBILIÁRIOS S/A |
104 | CAIXA ECONOMICA FEDERAL |
105 | LECCA CRÉDITO, FINANCIAMENTO E INVESTIMENTO S/A |
107 | BANCO BOCOM BBM S.A. |
111 | OLIVEIRA TRUST DISTRIBUIDORA DE TÍTULOS E VALORES MOBILIARIOS S.A. |
113 | NEON CORRETORA DE TÍTULOS E VALORES MOBILIÁRIOS S.A. |
114 | CENTRAL COOPERATIVA DE CRÉDITO NO ESTADO DO ESPÍRITO SANTO - CECOOP |
117 | ADVANCED CORRETORA DE CÂMBIO LTDA |
119 | BANCO WESTERN UNION DO BRASIL S.A. |
120 | BANCO RODOBENS S.A. |
121 | BANCO AGIBANK S.A. |
122 | BANCO BRADESCO BERJ S.A. |
124 | BANCO WOORI BANK DO BRASIL S.A. |
125 | BANCO GENIAL S.A. |
126 | BR PARTNERS BANCO DE INVESTIMENTO S.A. |
127 | CODEPE CORRETORA DE VALORES E CÂMBIO S.A. |
128 | MS BANK S.A. BANCO DE CÂMBIO |
129 | UBS BRASIL BANCO DE INVESTIMENTO S.A. |
130 | CARUANA S.A. - SOCIEDADE DE CRÉDITO, FINANCIAMENTO E INVESTIMENTO |
131 | TULLETT PREBON BRASIL CORRETORA DE VALORES E CÂMBIO LTDA |
132 | ICBC DO BRASIL BANCO MÚLTIPLO S.A. |
133 | CONFEDERAÇÃO NACIONAL DAS COOPERATIVAS CENTRAIS DE CRÉDITO E ECONOMIA FAMILIAR E |
134 | BGC LIQUIDEZ DISTRIBUIDORA DE TÍTULOS E VALORES MOBILIÁRIOS LTDA |
136 | CONFEDERAÇÃO NACIONAL DAS COOPERATIVAS CENTRAIS UNICRED LTDA. - UNICRED DO BRASI |
138 | GET MONEY CORRETORA DE CÂMBIO S.A. |
139 | INTESA SANPAOLO BRASIL S.A. - BANCO MÚLTIPLO |
140 | NU INVEST CORRETORA DE VALORES S.A. |
142 | BROKER BRASIL CORRETORA DE CÂMBIO LTDA. |
143 | TREVISO CORRETORA DE CÂMBIO S.A. |
144 | BEXS BANCO DE CÂMBIO S/A |
145 | LEVYCAM - CORRETORA DE CAMBIO E VALORES LTDA. |
146 | GUITTA CORRETORA DE CAMBIO LTDA. |
149 | FACTA FINANCEIRA S.A. - CRÉDITO FINANCIAMENTO E INVESTIMENTO |
157 | ICAP DO BRASIL CORRETORA DE TÍTULOS E VALORES MOBILIÁRIOS LTDA. |
159 | CASA DO CRÉDITO S.A. SOCIEDADE DE CRÉDITO AO MICROEMPREENDEDOR |
163 | COMMERZBANK BRASIL S.A. - BANCO MÚLTIPLO |
173 | BRL TRUST DISTRIBUIDORA DE TÍTULOS E VALORES MOBILIÁRIOS S.A. |
174 | PEFISA S.A. - CRÉDITO, FINANCIAMENTO E INVESTIMENTO |
177 | GUIDE INVESTIMENTOS S.A. CORRETORA DE VALORES |
180 | CM CAPITAL MARKETS CORRETORA DE CÂMBIO, TÍTULOS E VALORES MOBILIÁRIOS LTDA |
183 | SOCRED S.A. - SOCIEDADE DE CRÉDITO AO MICROEMPREENDEDOR E À EMPRESA DE PEQUENO P |
184 | BANCO ITAÚ BBA S.A. |
188 | ATIVA INVESTIMENTOS S.A. CORRETORA DE TÍTULOS, CÂMBIO E VALORES |
189 | HS FINANCEIRA S/A CREDITO, FINANCIAMENTO E INVESTIMENTOS |
190 | SERVICOOP - COOPERATIVA DE CRÉDITO DOS SERVIDORES PÚBLICOS ESTADUAIS E MUNICIPAI |
191 | NOVA FUTURA CORRETORA DE TÍTULOS E VALORES MOBILIÁRIOS LTDA. |
194 | PARMETAL DISTRIBUIDORA DE TÍTULOS E VALORES MOBILIÁRIOS LTDA |
195 | VALOR SOCIEDADE DE CRÉDITO DIRETO S.A. |
196 | FAIR CORRETORA DE CAMBIO S.A. |
197 | STONE INSTITUIÇÃO DE PAGAMENTO S.A. |
208 | BANCO BTG PACTUAL S.A. |
212 | BANCO ORIGINAL S.A. |
213 | BANCO ARBI S.A. |
217 | BANCO JOHN DEERE S.A. |
218 | BANCO BS2 S.A. |
222 | BANCO CRÉDIT AGRICOLE BRASIL S.A. |
224 | BANCO FIBRA S.A. |
233 | BANCO CIFRA S.A. |
237 | BANCO BRADESCO S.A. |
241 | BANCO CLASSICO S.A. |
243 | BANCO MASTER S/A |
246 | BANCO ABC BRASIL S.A. |
249 | BANCO INVESTCRED UNIBANCO S.A. |
250 | BCV - BANCO DE CRÉDITO E VAREJO S.A. |
253 | BEXS CORRETORA DE CÂMBIO S/A |
254 | PARANÁ BANCO S.A. |
259 | MONEYCORP BANCO DE CÂMBIO S.A. |
260 | NU PAGAMENTOS S.A. - INSTITUIÇÃO DE PAGAMENTO |
265 | BANCO FATOR S.A. |
266 | BANCO CEDULA S.A. |
268 | BARI COMPANHIA HIPOTECÁRIA |
269 | BANCO HSBC S.A. |
270 | SAGITUR CORRETORA DE CÂMBIO S.A. |
271 | IB CORRETORA DE CÂMBIO, TÍTULOS E VALORES MOBILIÁRIOS S.A. |
272 | AGK CORRETORA DE CAMBIO S.A. |
273 | COOPERATIVA DE CRÉDITO RURAL DE SÃO MIGUEL DO OESTE - SULCREDI/SÃO MIGUEL |
274 | BMP SOCIEDADE DE CRÉDITO AO MICROEMPREENDEDOR E A EMPRESA DE PEQUENO PORTE LTDA. |
276 | BANCO SENFF S.A. |
278 | GENIAL INVESTIMENTOS CORRETORA DE VALORES MOBILIÁRIOS S.A. |
279 | PRIMACREDI COOPERATIVA DE CRÉDITO DE PRIMAVERA DO LESTE |
280 | WILL FINANCEIRA S.A. CRÉDITO, FINANCIAMENTO E INVESTIMENTO |
281 | COOPERATIVA DE CRÉDITO RURAL COOPAVEL |
283 | RB INVESTIMENTOS DISTRIBUIDORA DE TITULOS E VALORES MOBILIARIOS LIMITADA |
285 | FRENTE CORRETORA DE CÂMBIO LTDA. |
286 | UNIPRIME OURO - COOPERATIVA DE CRÉDITO DE OURO |
288 | CAROL DISTRIBUIDORA DE TITULOS E VALORES MOBILIARIOS LTDA. |
289 | EFX CORRETORA DE CÂMBIO LTDA. |
290 | PAGSEGURO INTERNET INSTITUIÇÃO DE PAGAMENTO S.A. |
292 | BS2 DISTRIBUIDORA DE TÍTULOS E VALORES MOBILIÁRIOS S.A. |
293 | LASTRO RDV DISTRIBUIDORA DE TÍTULOS E VALORES MOBILIÁRIOS LTDA. |
296 | OZ CORRETORA DE CÂMBIO S.A. |
298 | VIP'S CORRETORA DE CÂMBIO LTDA. |
299 | BANCO AFINZ S.A. - BANCO MÚLTIPLO |
300 | BANCO DE LA NACION ARGENTINA |
301 | DOCK INSTITUIÇÃO DE PAGAMENTO S.A. |
306 | PORTOPAR DISTRIBUIDORA DE TITULOS E VALORES MOBILIARIOS LTDA. |
307 | TERRA INVESTIMENTOS DISTRIBUIDORA DE TÍTULOS E VALORES MOBILIÁRIOS LTDA. |
309 | CAMBIONET CORRETORA DE CÂMBIO LTDA. |
310 | VORTX DISTRIBUIDORA DE TITULOS E VALORES MOBILIARIOS LTDA. |
311 | DOURADA CORRETORA DE CÂMBIO LTDA. |
312 | HSCM - SOCIEDADE DE CRÉDITO AO MICROEMPREENDEDOR E À EMPRESA DE PEQUENO PORTE LT |
313 | AMAZÔNIA CORRETORA DE CÂMBIO LTDA. |
318 | BANCO BMG S.A. |
319 | OM DISTRIBUIDORA DE TÍTULOS E VALORES MOBILIÁRIOS LTDA |
320 | CHINA CONSTRUCTION BANK (BRASIL) BANCO MÚLTIPLO S/A |
321 | CREFAZ SOCIEDADE DE CRÉDITO AO MICROEMPREENDEDOR E A EMPRESA DE PEQUENO PORTE LT |
322 | COOPERATIVA DE CRÉDITO RURAL DE ABELARDO LUZ - SULCREDI/CREDILUZ |
323 | MERCADO PAGO INSTITUIÇÃO DE PAGAMENTO LTDA. |
324 | CARTOS SOCIEDADE DE CRÉDITO DIRETO S.A. |
325 | ÓRAMA DISTRIBUIDORA DE TÍTULOS E VALORES MOBILIÁRIOS S.A. |
326 | PARATI - CREDITO, FINANCIAMENTO E INVESTIMENTO S.A. |
328 | COOPERATIVA DE ECONOMIA E CRÉDITO MÚTUO DOS FABRICANTES DE CALÇADOS DE SAPIRANGA |
329 | QI SOCIEDADE DE CRÉDITO DIRETO S.A. |
330 | BANCO BARI DE INVESTIMENTOS E FINANCIAMENTOS S.A. |
331 | FRAM CAPITAL DISTRIBUIDORA DE TÍTULOS E VALORES MOBILIÁRIOS S.A. |
332 | ACESSO SOLUÇÕES DE PAGAMENTO S.A. - INSTITUIÇÃO DE PAGAMENTO |
334 | BANCO BESA S.A. |
335 | BANCO DIGIO S.A. |
336 | BANCO C6 S.A. |
340 | SUPERDIGITAL INSTITUIÇÃO DE PAGAMENTO S.A. |
341 | ITAÚ UNIBANCO S.A. |
342 | CREDITAS SOCIEDADE DE CRÉDITO DIRETO S.A. |
343 | FFA SOCIEDADE DE CRÉDITO AO MICROEMPREENDEDOR E À EMPRESA DE PEQUENO PORTE LTDA. |
348 | BANCO XP S.A. |
349 | AL5 S.A. CRÉDITO, FINANCIAMENTO E INVESTIMENTO |
350 | COOPERATIVA DE CRÉDITO RURAL DE PEQUENOS AGRICULTORES E DA REFORMA AGRÁRIA DO CE |
352 | TORO CORRETORA DE TÍTULOS E VALORES MOBILIÁRIOS S.A. |
355 | ÓTIMO SOCIEDADE DE CRÉDITO DIRETO S.A. |
358 | MIDWAY S.A. - CRÉDITO, FINANCIAMENTO E INVESTIMENTO |
359 | ZEMA CRÉDITO, FINANCIAMENTO E INVESTIMENTO S/A |
360 | TRINUS CAPITAL DISTRIBUIDORA DE TÍTULOS E VALORES MOBILIÁRIOS S.A. |
362 | CIELO S.A. - INSTITUIÇÃO DE PAGAMENTO |
363 | SINGULARE CORRETORA DE TÍTULOS E VALORES MOBILIÁRIOS S.A. |
364 | EFÍ S.A. - INSTITUIÇÃO DE PAGAMENTO |
365 | SIMPAUL CORRETORA DE CAMBIO E VALORES MOBILIARIOS S.A. |
366 | BANCO SOCIETE GENERALE BRASIL S.A. |
367 | VITREO DISTRIBUIDORA DE TÍTULOS E VALORES MOBILIÁRIOS S.A. |
368 | BANCO CSF S.A. |
370 | BANCO MIZUHO DO BRASIL S.A. |
371 | WARREN CORRETORA DE VALORES MOBILIÁRIOS E CÂMBIO LTDA. |
373 | UP.P SOCIEDADE DE EMPRÉSTIMO ENTRE PESSOAS S.A. |
374 | REALIZE CRÉDITO, FINANCIAMENTO E INVESTIMENTO S.A. |
376 | BANCO J.P. MORGAN S.A. |
377 | BMS SOCIEDADE DE CRÉDITO DIRETO S.A. |
378 | BANCO BRASILEIRO DE CRÉDITO SOCIEDADE ANÔNIMA |
379 | COOPERFORTE - COOPERATIVA DE ECONOMIA E CRÉDITO MÚTUO DE FUNCIONÁRIOS DE INSTITU |
380 | PICPAY INSTITUIÇÃO DE PAGAMENTO S.A. |
381 | BANCO MERCEDES-BENZ DO BRASIL S.A. |
382 | FIDÚCIA SOCIEDADE DE CRÉDITO AO MICROEMPREENDEDOR E À EMPRESA DE PEQUENO PORTE L |
383 | EBANX INSTITUICAO DE PAGAMENTOS LTDA. |
384 | GLOBAL FINANÇAS SOCIEDADE DE CRÉDITO AO MICROEMPREENDEDOR E À EMPRESA DE PEQUENO |
385 | COOPERATIVA DE ECONOMIA E CREDITO MUTUO DOS TRABALHADORES PORTUARIOS DA GRANDE V |
386 | NU FINANCEIRA S.A. - SOCIEDADE DE CRÉDITO, FINANCIAMENTO E INVESTIMENTO |
387 | BANCO TOYOTA DO BRASIL S.A. |
389 | BANCO MERCANTIL DO BRASIL S.A. |
390 | BANCO GM S.A. |
391 | COOPERATIVA DE CREDITO RURAL DE IBIAM - SULCREDI/IBIAM |
393 | BANCO VOLKSWAGEN S.A. |
394 | BANCO BRADESCO FINANCIAMENTOS S.A. |
395 | F.D'GOLD - DISTRIBUIDORA DE TÍTULOS E VALORES MOBILIÁRIOS LTDA. |
396 | HUB INSTITUIÇÃO DE PAGAMENTO S.A. |
397 | LISTO SOCIEDADE DE CREDITO DIRETO S.A. |
398 | IDEAL CORRETORA DE TÍTULOS E VALORES MOBILIÁRIOS S.A. |
399 | KIRTON BANK S.A. - BANCO MÚLTIPLO |
400 | COOPERATIVA DE CRÉDITO, POUPANÇA E SERVIÇOS FINANCEIROS DO CENTRO OESTE - CREDIT |
401 | IUGU INSTITUIÇÃO DE PAGAMENTO S.A. |
402 | COBUCCIO S/A - SOCIEDADE DE CRÉDITO, FINANCIAMENTO E INVESTIMENTOS |
403 | CORA SOCIEDADE DE CRÉDITO DIRETO S.A. |
404 | SUMUP SOCIEDADE DE CRÉDITO DIRETO S.A. |
406 | ACCREDITO - SOCIEDADE DE CRÉDITO DIRETO S.A. |
407 | ÍNDIGO INVESTIMENTOS DISTRIBUIDORA DE TÍTULOS E VALORES MOBILIÁRIOS LTDA. |
408 | BONUSPAGO SOCIEDADE DE CRÉDITO DIRETO S.A. |
410 | PLANNER SOCIEDADE DE CRÉDITO DIRETO S.A. |
411 | VIA CERTA FINANCIADORA S.A. - CRÉDITO, FINANCIAMENTO E INVESTIMENTOS |
412 | SOCIAL BANK BANCO MÚLTIPLO S/A |
413 | BANCO BV S.A. |
414 | LEND SOCIEDADE DE CRÉDITO DIRETO S.A. |
416 | LAMARA SOCIEDADE DE CRÉDITO DIRETO S.A. |
418 | ZIPDIN SOLUÇÕES DIGITAIS SOCIEDADE DE CRÉDITO DIRETO S/A |
419 | NUMBRS SOCIEDADE DE CRÉDITO DIRETO S.A. |
421 | LAR COOPERATIVA DE CRÉDITO - LAR CREDI |
422 | BANCO SAFRA S.A. |
423 | COLUNA S/A DISTRIBUIDORA DE TITULOS E VALORES MOBILIÁRIOS |
425 | SOCINAL S.A. - CRÉDITO, FINANCIAMENTO E INVESTIMENTO |
426 | BIORC FINANCEIRA - CRÉDITO, FINANCIAMENTO E INVESTIMENTO S.A. |
427 | COOPERATIVA DE CREDITO DOS SERVIDORES DA UNIVERSIDADE FEDERAL DO ESPIRITO SANTO |
428 | CREDSYSTEM SOCIEDADE DE CRÉDITO DIRETO S.A. |
429 | CREDIARE S.A. - CRÉDITO, FINANCIAMENTO E INVESTIMENTO |
430 | COOPERATIVA DE CREDITO RURAL SEARA - CREDISEARA |
433 | BR-CAPITAL DISTRIBUIDORA DE TÍTULOS E VALORES MOBILIÁRIOS S.A. |
435 | DELCRED SOCIEDADE DE CRÉDITO DIRETO S.A. |
438 | TRUSTEE DISTRIBUIDORA DE TÍTULOS E VALORES MOBILIÁRIOS LTDA. |
439 | ID CORRETORA DE TÍTULOS E VALORES MOBILIÁRIOS S.A. |
440 | CREDIBRF - COOPERATIVA DE CRÉDITO |
442 | MAGNETIS - DISTRIBUIDORA DE TÍTULOS E VALORES MOBILIÁRIOS LTDA |
443 | CREDIHOME SOCIEDADE DE CRÉDITO DIRETO S.A. |
444 | TRINUS SOCIEDADE DE CRÉDITO DIRETO S.A. |
445 | PLANTAE S.A. - CRÉDITO, FINANCIAMENTO E INVESTIMENTO |
447 | MIRAE ASSET WEALTH MANAGEMENT (BRAZIL) CORRETORA DE CÂMBIO, TÍTULOS E VALORES MO |
448 | HEMERA DISTRIBUIDORA DE TÍTULOS E VALORES MOBILIÁRIOS LTDA. |
449 | DM SOCIEDADE DE CRÉDITO DIRETO S.A. |
450 | FITBANK INSTITUIÇÃO DE PAGAMENTOS ELETRÔNICOS S.A. |
451 | J17 - SOCIEDADE DE CRÉDITO DIRETO S/A |
452 | CREDIFIT SOCIEDADE DE CRÉDITO DIRETO S.A. |
454 | MÉRITO DISTRIBUIDORA DE TÍTULOS E VALORES MOBILIÁRIOS LTDA. |
455 | FÊNIX DISTRIBUIDORA DE TÍTULOS E VALORES MOBILIÁRIOS LTDA. |
456 | BANCO MUFG BRASIL S.A. |
457 | UY3 SOCIEDADE DE CRÉDITO DIRETO S/A |
458 | HEDGE INVESTMENTS DISTRIBUIDORA DE TÍTULOS E VALORES MOBILIÁRIOS LTDA. |
459 | COOPERATIVA DE CRÉDITO MÚTUO DE SERVIDORES PÚBLICOS DO ESTADO DE SÃO PAULO - CRE |
460 | UNAVANTI SOCIEDADE DE CRÉDITO DIRETO S/A |
461 | ASAAS GESTÃO FINANCEIRA INSTITUIÇÃO DE PAGAMENTO S.A. |
462 | STARK SOCIEDADE DE CRÉDITO DIRETO S.A. |
463 | AZUMI DISTRIBUIDORA DE TÍTULOS E VALORES MOBILIÁRIOS LTDA. |
464 | BANCO SUMITOMO MITSUI BRASILEIRO S.A. |
465 | CAPITAL CONSIG SOCIEDADE DE CRÉDITO DIRETO S.A. |
467 | MASTER S/A CORRETORA DE CÂMBIO, TÍTULOS E VALORES MOBILIÁRIOS |
468 | PORTOSEG S.A. - CREDITO, FINANCIAMENTO E INVESTIMENTO |
469 | LIGA INVEST DISTRIBUIDORA DE TÍTULOS E VALORES MOBILIÁRIOS LTDA |
470 | CDC SOCIEDADE DE CRÉDITO DIRETO S.A. |
471 | COOPERATIVA DE ECONOMIA E CREDITO MUTUO DOS SERVIDORES PUBLICOS DE PINHÃO - CRES |
473 | BANCO CAIXA GERAL - BRASIL S.A. |
475 | BANCO YAMAHA MOTOR DO BRASIL S.A. |
477 | CITIBANK N.A. |
478 | GAZINCRED S.A. SOCIEDADE DE CRÉDITO, FINANCIAMENTO E INVESTIMENTO |
479 | BANCO ITAUBANK S.A. |
481 | SUPERLÓGICA SOCIEDADE DE CRÉDITO DIRETO S.A. |
482 | SBCASH SOCIEDADE DE CRÉDITO DIRETO S.A. |
484 | MAF DISTRIBUIDORA DE TÍTULOS E VALORES MOBILIÁRIOS S.A. |
487 | DEUTSCHE BANK S.A. - BANCO ALEMAO |
488 | JPMORGAN CHASE BANK, NATIONAL ASSOCIATION |
495 | BANCO DE LA PROVINCIA DE BUENOS AIRES |
505 | BANCO CREDIT SUISSE (BRASIL) S.A. |
506 | RJI CORRETORA DE TITULOS E VALORES MOBILIARIOS LTDA |
507 | SOCIEDADE DE CRÉDITO, FINANCIAMENTO E INVESTIMENTO EFÍ S.A. |
508 | AVENUE SECURITIES DISTRIBUIDORA DE TÍTULOS E VALORES MOBILIÁRIOS LTDA. |
509 | CELCOIN INSTITUICAO DE PAGAMENTO S.A. |
510 | FFCRED SOCIEDADE DE CRÉDITO DIRETO S.A.. |
511 | MAGNUM SOCIEDADE DE CRÉDITO DIRETO S.A. |
512 | FINVEST DISTRIBUIDORA DE TÍTULOS E VALORES MOBILIÁRIOS LTDA. |
513 | ATF CREDIT SOCIEDADE DE CRÉDITO DIRETO S.A. |
516 | FC FINANCEIRA S.A. - CRÉDITO, FINANCIAMENTO E INVESTIMENTO |
518 | MERCADO CRÉDITO SOCIEDADE DE CRÉDITO, FINANCIAMENTO E INVESTIMENTO S.A. |
519 | LIONS TRUST DISTRIBUIDORA DE TÍTULOS E VALORES MOBILIÁRIOS LTDA. |
521 | PEAK SOCIEDADE DE EMPRÉSTIMO ENTRE PESSOAS S.A. |
523 | HR DIGITAL - SOCIEDADE DE CRÉDITO DIRETO S/A |
525 | INTERCAM CORRETORA DE CÂMBIO LTDA. |
526 | MONETARIE SOCIEDADE DE CRÉDITO DIRETO S.A. |
527 | ATICCA - SOCIEDADE DE CRÉDITO DIRETO S.A. |
529 | PINBANK BRASIL INSTITUIÇÃO DE PAGAMENTO S.A. |
535 | MARÚ SOCIEDADE DE CRÉDITO DIRETO S.A. |
536 | NEON PAGAMENTOS S.A. - INSTITUIÇÃO DE PAGAMENTO |
545 | SENSO CORRETORA DE CAMBIO E VALORES MOBILIARIOS S.A |
600 | BANCO LUSO BRASILEIRO S.A. |
604 | BANCO INDUSTRIAL DO BRASIL S.A. |
610 | BANCO VR S.A. |
611 | BANCO PAULISTA S.A. |
612 | BANCO GUANABARA S.A. |
613 | OMNI BANCO S.A. |
623 | BANCO PAN S.A. |
626 | BANCO C6 CONSIGNADO S.A. |
630 | BANCO LETSBANK S.A. |
633 | BANCO RENDIMENTO S.A. |
634 | BANCO TRIANGULO S.A. |
637 | BANCO SOFISA S.A. |
643 | BANCO PINE S.A. |
653 | BANCO VOITER S.A. |
654 | BANCO DIGIMAIS S.A. |
655 | BANCO VOTORANTIM S.A. |
707 | BANCO DAYCOVAL S.A. |
712 | BANCO OURINVEST S.A. |
720 | BANCO RNX S.A. |
739 | BANCO CETELEM S.A. |
741 | BANCO RIBEIRAO PRETO S.A. |
743 | BANCO SEMEAR S.A. |
745 | BANCO CITIBANK S.A. |
746 | BANCO MODAL S.A. |
747 | BANCO RABOBANK INTERNATIONAL BRASIL S.A. |
748 | BANCO COOPERATIVO SICREDI S.A. |
751 | SCOTIABANK BRASIL S.A. BANCO MÚLTIPLO |
752 | BANCO BNP PARIBAS BRASIL S.A. |
753 | NOVO BANCO CONTINENTAL S.A. - BANCO MÚLTIPLO |
754 | BANCO SISTEMA S.A. |
755 | BANK OF AMERICA MERRILL LYNCH BANCO MÚLTIPLO S.A. |
756 | BANCO COOPERATIVO SICOOB S.A. - BANCO SICOOB |
757 | BANCO KEB HANA DO BRASIL S.A. |
For CLP currency:
Bank Name |
---|
Banco de Chile |
Banco Internacional |
Banco del Estado de Chile |
Scotiabank Chile |
Banco Crédito e Inversiones |
Banco Bice |
HSBC Bank |
Banco Santander- Santiago |
Itau Corpbanca |
Banco Security |
Banco Falabella |
Banco Ripley |
Banco Consorcio |
BBVA Chile |
Banco del Desarrollo |
Coopeuch |
Prepago los Héroes |
Tenpo Prepago |
For COP currency:
Bank Name |
---|
BANCO DE BOGOTA |
BANCO POPULAR |
BANCO SANTANDER |
BANCOLOMBIA |
HSBC |
BANCO SUDAMERIS |
BBVA |
ITAU |
BANCO COLPATRIA |
BANCO DE OCCIDENTE |
BANCOLDEX S.A. |
BANCO CAJA SOCIAL BCSC |
BANCO AGRARIO |
BANCO MUNDO MUJER |
BANCO DAVIVIENDA |
BANCO AV VILLAS |
BANCO W S.A |
BANCO PROCREDIT |
BANCAMIA S.A |
BANCO PICHINCHA |
BANCOOMEVA |
BANCO FALABELLA S.A |
BANCO FINANDINA S.A. |
BANCO MULTIBANK S.A. |
BANCO SERFINANZA S.A. |
COOPCENTRAL S.A |
COOPERATIVA FINANCIERA DE ANTIOQUIA |
COTRAFA COOPERATIVA FINANCIERA |
CONFIAR |
FINANCIERA JURISCOOP |
COLTEFINANCIERA S.A. |
NEQUI |
For MXN currency:
Bank Name |
---|
BANAMEX |
BANCOMEXT |
BANOBRAS |
BBVA BANCOMER |
SANTANDER |
BANJERCITO |
HSBC |
BAJIO |
IXE |
INBURSA |
INTERACCIONES |
MIFEL |
SCOTIABANK |
BANREGIO |
INVEX |
BANSI |
AFIRME |
BANORTE |
THE ROYAL BANK |
AMERICAN EXPRESS |
BAMSA |
TOKYO |
JP MORGAN |
BMONEX |
VE POR MAS |
ING |
DEUTSCHE |
CREDIT SUISSE |
AZTECA |
AUTOFIN |
BARCLAYS |
COMPARTAMOS |
BANCO FAMSA |
BMULTIVA |
ACTINVER |
WALMART |
NAFIN |
INTERBANCO |
BANCOPPEL |
ABC CAPITAL |
UBS BANK |
CONSUBANCO |
VOLKSWAGEN |
CIBANCO |
BBASE |
BANSEFI |
HIPOTECARIA FEDERAL |
MONEXCB |
GBM |
MASARI |
VALUE |
ESTRUCTURADORES |
TIBER |
VECTOR |
B&B |
ACCIVAL |
MERRILL LYNCH |
FINAMEX |
VALMEX |
UNICA |
MAPFRE |
PROFUTURO |
CB ACTINVER |
OACTIN |
SKANDIA |
CBDEUTSCHE |
ZURICH |
ZURICHVI |
SU CASITA |
CB INTERCAM |
CI BOLSA |
BULLTICK CB |
STERLING |
FINCOMUN |
HDI SEGUROS |
ORDER |
AKALA |
CB JPMORGAN |
REFORMA |
STP |
TELECOMM |
EVERCORE |
SKANDIA |
SEGMTY |
ASEA |
KUSPIT |
SOFIEXPRESS |
UNAGRA |
OPCIONES EMPRESARIALES DEL NOROESTE |
LIBERTAD |
CLS |
INDEVAL |
For PEN currency:
Bank Name |
---|
Banco Central de Reserva |
Banco de Crédito del Perú |
Interbank |
Citibank |
Scotiabank |
BBVA Continental |
Banco de la Nación |
Banco de Comercio |
Banco Financiero |
Banco Interamericano de Finanzas (BIF) |
Crediscotia Financiera |
Mi Banco |
Banco GNB Perú S.A. |
Banco Falabella |
Santander |
Caja Metropolitana de Lima |
Caja Municipal de Ahorro y Crédito Piura SAC |
Caja Municipal de Ahorro y Crédito Trujillo |
Caja Municipal de Ahorro y Crédito Arequipa |
Caja Municipal de Ahorro y Crédito Sullana |
Caja Municipal de Ahorro y Crédito Cuzco |
Caja Municipal de Ahorro y Crédito Huancayo |
Caja Municipal de Ahorro y Crédito Tacna |
For UYU currency:
Bank Name |
---|
BROU - Banco de la República Oriental del Uruguay |
Banco Hipotecario del Uruguay |
Banco Bandes |
Banco ITAU |
Scotiabank |
Banco Santander |
Banco Bilbao Vizcaya Argentaria |
HSBC Bank |
Banque Heritage |
Citibank N.A. Sucursal |
Banco de la Nación Argentina |
Successful Response
stdClass Object
(
[transaction_type] => bank_payout
[status] => pending_async
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:57.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 50000
[currency] => INR
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>bank_payout</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:57Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>50000</amount>
<currency>INR</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => bank_payout
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 110
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:57.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 50000
[currency] => INR
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>bank_payout</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>110</code>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:57Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>50000</amount>
<currency>INR</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
BitPay Payout
BitPay Payout is a crypto currency payout method where merchants are requesting payouts in FIAT currency and the funds are transferred in Bitcoin equivalent to a crypto wallet address.
BitPay Payout is an asynchronous transaction type supported through the Processing API, Virtual Terminal and Web Payment Form.
The payout requests are processed once a day at 11:00 GMT and the settlement usually takes 24 hours.
Supported countries
Country name | Country code |
---|---|
Afghanistan | AF |
Aland Islands | AX |
Albania | AL |
American Samoa | AS |
Andorra | AD |
Angola | AO |
Anguilla | AI |
Antarctica | AQ |
Antigua and Barbuda | AG |
Argentina | AR |
Armenia | AM |
Aruba | AW |
Australia | AU |
Austria | AT |
Azerbaijan | AZ |
Bahamas | BS |
Bahrain | BH |
Barbados | BB |
Belarus | BY |
Belgium | BE |
Belize | BZ |
Benin | BJ |
Bermuda | BM |
Bhutan | BT |
Bonaire, Sint Eustatius and Saba | BQ |
Bosnia and Herzegovina | BA |
Botswana | BW |
Bouvet Island | BV |
Brazil | BR |
British Indian Ocean Territory | IO |
Brunei Darussalam | BN |
Bulgaria | BG |
Burkina Faso | BF |
Burundi | BI |
Cameroon | CM |
Canada | CA |
Cape Verde | CV |
Cayman Islands | KY |
Central African Republic | CF |
Chad | TD |
Chile | CL |
China | CN |
Christmas Island | CX |
Cocos (Keeling) Islands | CC |
Colombia | CO |
Comoros | KM |
Congo | CG |
Congo, the Democratic Republic of the | CD |
Cook Islands | CK |
Costa Rica | CR |
Cote D'Ivoire | CI |
Croatia | HR |
Cuba | CU |
Curacao | CW |
Cyprus | CY |
Czech Republic | CZ |
Denmark | DK |
Djibouti | DJ |
Dominica | DM |
Dominican Republic | DO |
El Salvador | SV |
Equatorial Guinea | GQ |
Eritrea | ER |
Estonia | EE |
Ethiopia | ET |
Falkland Islands (Malvinas) | FK |
Faroe Islands | FO |
Fiji | FJ |
Finland | FI |
France | FR |
French Guiana | GF |
French Polynesia | PF |
French Southern Territories | TF |
Gabon | GA |
Gambia | GM |
Georgia | GE |
Germany | DE |
Ghana | GH |
Gibraltar | GI |
Greece | GR |
Greenland | GL |
Grenada | GD |
Guadeloupe | GP |
Guam | GU |
Guatemala | GT |
Guernsey | GG |
Guinea | GN |
Guinea-Bissau | GW |
Guyana | GY |
Haiti | HT |
Heard Island and McDonald Islands | HM |
Holy See (Vatican City State) | VA |
Honduras | HN |
Hong Kong | HK |
Hungary | HU |
Iceland | IS |
India | IN |
Iran, Islamic Republic of | IR |
Ireland | IE |
Isle of Man | IM |
Israel | IL |
Italy | IT |
Jamaica | JM |
Japan | JP |
Jersey | JE |
Jordan | JO |
Kazakhstan | KZ |
Kenya | KE |
Kiribati | KI |
Korea, Democratic People's Republic of | KP |
Korea, Republic of | KR |
Kosovo, Republic of | XK |
Kuwait | KW |
Lao People's Democratic Republic | LA |
Latvia | LV |
Lebanon | LB |
Lesotho | LS |
Liberia | LR |
Libyan Arab Jamahiriya | LY |
Liechtenstein | LI |
Lithuania | LT |
Luxembourg | LU |
Macao | MO |
Madagascar | MG |
Malawi | MW |
Malaysia | MY |
Maldives | MV |
Mali | ML |
Malta | MT |
Marshall Islands | MH |
Martinique | MQ |
Mauritania | MR |
Mauritius | MU |
Mayotte | YT |
Mexico | MX |
Micronesia, Federated States of | FM |
Moldova, Republic of | MD |
Monaco | MC |
Mongolia | MN |
Montenegro | ME |
Montserrat | MS |
Mozambique | MZ |
Myanmar | MM |
Namibia | NA |
Nauru | NR |
Netherlands | NL |
Netherlands Antilles | AN |
New Caledonia | NC |
New Zealand | NZ |
Nicaragua | NI |
Niger | NE |
Nigeria | NG |
Niue | NU |
Norfolk Island | NF |
Northern Mariana Islands | MP |
Norway | NO |
Oman | OM |
Palau | PW |
Panama | PA |
Papua New Guinea | PG |
Paraguay | PY |
Peru | PE |
Philippines | PH |
Pitcairn | PN |
Poland | PL |
Portugal | PT |
Puerto Rico | PR |
Qatar | QA |
Reunion | RE |
Romania | RO |
Russian Federation | RU |
Rwanda | RW |
Saint Barthélemy | BL |
Saint Helena | SH |
Saint Kitts and Nevis | KN |
Saint Lucia | LC |
Saint Martin French Part | MF |
Saint Pierre and Miquelon | PM |
Saint Vincent and the Grenadines | VC |
Samoa | WS |
San Marino | SM |
Sao Tome and Principe | ST |
Saudi Arabia | SA |
Senegal | SN |
Serbia | RS |
Seychelles | SC |
Sierra Leone | SL |
Singapore | SG |
Sint Maarten (Dutch part) | SX |
Slovakia | SK |
Slovenia | SI |
Solomon Islands | SB |
Somalia | SO |
South Africa | ZA |
South Georgia and the South Sandwich Islands | GS |
South Sudan | SS |
Spain | ES |
Sri Lanka | LK |
Sudan | SD |
Suriname | SR |
Svalbard and Jan Mayen | SJ |
Swaziland | SZ |
Sweden | SE |
Switzerland | CH |
Syrian Arab Republic | SY |
Taiwan, Province of China | TW |
Tajikistan | TJ |
Tanzania, United Republic of | TZ |
Thailand | TH |
Timor-Leste | TL |
Togo | TG |
Tokelau | TK |
Tonga | TO |
Trinidad and Tobago | TT |
Tunisia | TN |
Turkmenistan | TM |
Turks and Caicos Islands | TC |
Tuvalu | TV |
Uganda | UG |
Ukraine | UA |
United Arab Emirates | AE |
United Kingdom | GB |
United States | US |
United States Minor Outlying Islands | UM |
Uruguay | UY |
Uzbekistan | UZ |
Vanuatu | VU |
Venezuela, Bolivarian Republic of | VE |
Virgin Islands, British | VG |
Virgin Islands, U.S. | VI |
Wallis and Futuna | WF |
Western Sahara | EH |
Yemen | YE |
Zambia | ZM |
Zimbabwe | ZW |
Supported currencies
Currency name | Currency code |
---|---|
American Dollar | USD |
Euro | EUR |
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Crypto\BitPay\Payout');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setNotificationUrl('https://www.example.com/notification')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setAmount('2000')
->setCurrency('USD')
->setCryptoAddress('n1jE32b88mtT7UETWvV6WgrV5AUVTPDxW8')
->setCryptoWalletProvider('other')
->setCustomerEmail('travis@example.com');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>bitpay_payout</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<notification_url>https://www.example.com/notification</notification_url>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<amount>2000</amount>
<currency>USD</currency>
<crypto_address>n1jE32b88mtT7UETWvV6WgrV5AUVTPDxW8</crypto_address>
<crypto_wallet_provider>other</crypto_wallet_provider>
<customer_email>travis@example.com</customer_email>
</payment_transaction>'
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Crypto\BitPay\Payout');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setNotificationUrl('https://www.example.com/notification')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setAmount('500000')
->setCurrency('USD')
->setCryptoAddress('n1jE32b88mtT7UETWvV6WgrV5AUVTPDxW7')
->setCryptoWalletProvider('kraken')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>bitpay_payout</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<notification_url>https://www.example.com/notification</notification_url>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<amount>500000</amount>
<currency>USD</currency>
<crypto_address>n1jE32b88mtT7UETWvV6WgrV5AUVTPDxW7</crypto_address>
<crypto_wallet_provider>kraken</crypto_wallet_provider>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: bitpay_payout |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
notification_url | required | url | URL at merchant where gateway sends outcome of transaction. |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
customer_email | required* | e-mail address | Must contain valid e-mail of customer |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
crypto_address | required | string(255) | Valid crypto address where the funds will be received |
crypto_wallet_provider | required | string(255) | If crypto wallet provider is not in the table below, you must send ’other’ |
billing_address | required* | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required* | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
neighborhood | optional | string(255) | Neighborhood |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Crypto wallet providers with additional requirements
crypto wallet provider | description | website |
---|---|---|
BitGo | crypto wallet provider | official website |
Uphold | crypto wallet provider | official website |
Circle | crypto exchange | official website |
Coinbase | crypto wallet provider | official website |
GDax | crypto exchange | official website |
Gemini | crypto exchange | official website |
ITBit | crypto exchange | official website |
Kraken | crypto exchange | official website |
Successful Response
stdClass Object
(
[transaction_type] => bitpay_payout
[status] => approved
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:57.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 500000
[currency] => USD
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>bitpay_payout</transaction_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<timestamp>2025-01-16T10:23:57Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>500000</amount>
<currency>USD</currency>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
Error Response
stdClass Object
(
[transaction_type] => bitpay_payout
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[response_code] =>
[code] => 940
[technical_message] => Bitcoin address is invalid
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:57.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 2000
[currency] => USD
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>bitpay_payout</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<payment_response>response_code</payment_response>
<code>940</code>
<technical_message>Bitcoin address is invalid</technical_message>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:57Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>2000</amount>
<currency>USD</currency>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
response_code | string(2) | Defines the result of a transaction with the acquirer, the status of a message or some action taken or required. Contact tech-support@emerchantpay.com for more details. |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
eZeeCard Payout
eZeeCard Payout is a sync based payout method. It's merchant initiated and can only reference specific transaction types:
Those need to have been completed using a card issued by our Issuing API.
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\EzeeCardPayout');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('1000')
->setCurrency('EUR')
->setReferenceId('43672');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>ezeecard_payout</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>1000</amount>
<currency>EUR</currency>
<reference_id>43672</reference_id>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: ezeecard_payout |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
reference_id | required | string(32) | Unique id returned by corresponding transaction |
required* = conditionally required
Successful Response
stdClass Object
(
[transaction_type] => ezeecard_payout
[status] => approved
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[transaction_id] => 119643250547501c79d8295
[mode] => live
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:57.000000
[timezone_type] => 2
[timezone] => Z
)
[amount] => 1000
[currency] => EUR
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>ezeecard_payout</transaction_type>
<status>approved</status>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<transaction_id>119643250547501c79d8295</transaction_id>
<mode>live</mode>
<timestamp>2025-01-16T10:23:57Z</timestamp>
<amount>1000</amount>
<currency>EUR</currency>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
transaction_id | string(255) | Unique transaction id defined by merchant |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
Error Response
stdClass Object
(
[transaction_type] => ezeecard_payout
[status] => error
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[transaction_id] => 119643250547501c79d8295
[technical_message] => invalid deposit transaction
[message] =>
[mode] => live
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:57.000000
[timezone_type] => 2
[timezone] => Z
)
[amount] => 1000
[currency] => EUR
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>ezeecard_payout</transaction_type>
<status>error</status>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<transaction_id>119643250547501c79d8295</transaction_id>
<technical_message>invalid deposit transaction</technical_message>
<payment_response>message</payment_response>
<mode>live</mode>
<timestamp>2025-01-16T10:23:57Z</timestamp>
<amount>1000</amount>
<currency>EUR</currency>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
transaction_id | string(255) | Unique transaction id defined by merchant |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
Payout
Payouts are credits without a reference transaction and as such are highly regulated and need specific gateway terminal configuration, so be sure to contact the IT Support team at tech-support@emerchantpay.com in case you want Payouts to be enabled. A valid bank account number needs to be provided.
Using a payout, the amount is billed to the customer’s credit card. It can be reversed via a void transaction on the same day of the transaction.
Both Visa and Mastercard/Maestro Payouts are authorized real-time.
Note that for exceptional cases with some countries Visa OCTS will not be authorized through the schemes but batched for offline settlement on the same day. This means that the authorization code and issuer response code will not be available only for them.
Note that VISA OCT transactions with Australian or Canadian card bins will require the merchant zip code to be set, either through the dynamic descriptor parameter or through the merchant configuration.
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Payout');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('4200000000000000')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
// Account Owner
->setAccountFirstName('Travis')
->setAccountMiddleName('Joe')
->setAccountLastName('Pastrana')
->setCredentialOnFileTransactionIdentifier('123456789101112');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.PayoutRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
PayoutRequest request = new PayoutRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4200000000000000");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
// Account Owner
request.setAccountFirstname("Travis");
request.setAccountMiddlename("Joe");
request.setAccountLastname("Pastrana");
request.setCredentialOnFileTransactionIdentifier("123456789101112");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.payout(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "4200000000000000",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"account_owner": {
"first_name": "Travis",
"middle_name": "Joe",
"last_name": "Pastrana"
},
"credential_on_file_transaction_identifier": "123456789101112"
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>payout</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4200000000000000</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<account_owner>
<first_name>Travis</first_name>
<middle_name>Joe</middle_name>
<last_name>Pastrana</last_name>
</account_owner>
<credential_on_file_transaction_identifier>123456789101112</credential_on_file_transaction_identifier>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: payout |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
gaming | optional | "true" | Signifies whether a gaming transaction is performed. Gaming transactions usually use MCC 7995. Contact tech-support@emerchantpay.com for more details |
moto | optional | "true" | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech-support@emerchantpay.com for more details |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
crypto | optional | "true" | Signifies whether a crypto-currency transaction is performed. Must be populated when indicating crypto for VISA and MCC 6051. This is only applied to VISA OCT transactions. Contact Tech Support for more details. |
card_holder | required | string(255) | Full name of customer as printed on credit card (first name and last name at least). Please, note that for Visa or Master, Intl maestro cards with gambling MCC 7995, only Latin alphabet characters are accepted (a..z, A..Z) and any of: . ' - 0..9. Any other characters will be rejected and the transaction will be declined respectively. |
card_number | required | 13 to 16 digits | Complete cc number of customer |
cvv | required* | 3 to 4 digits | cvv of cc, requirement is based on terminal configuration |
expiration_month | required | MM | Expiration month as printed on credit card |
expiration_year | required | YYYY | Expiration year as printed on credit card |
token | optional | string(36) | See Tokenization for more details. If present, the cardholder parameters can be omitted. Cannot be set together with remember_card |
remember_card | optional | "true" | See Tokenize. Tokenizes cardholder parameters. Cannot be set together with token |
consumer_id | optional | string(10) | See Consumers and Tokenization. Combine with remember_card to tokenize or with token to use token |
source_of_funds | optional | string | Specify the source of funds with one of credit , debit , prepaid , cash , other_debit_account , other_credit_account . |
purpose_of_payment | required* | string (12) | Purpose of Payment code, required for Visa OCTs with recipients in Argentina, Bangladesh, Egypt, India, Chile and Colombia. |
credential_on_file_transaction_identifier | optional | string(15) | The ID of the Account Funding Transactions, for money transfer OCTs. |
credential_on_file | required* | See Credential On File (COF) for more details | |
initial_customer_initiated | required* | string(18) | Initial transaction initiated by customer. Required for external tokenization, and optional for gateway-based tokenization |
subsequent_customer_initiated | required* | string(18) | Subsequent transaction initiated by customer. Required for external tokenization, and optional for gateway-based tokenization |
merchant_unscheduled | optional | string(20) | Transaction is initiated by the merchant |
customer_email | required* | e-mail address | Must contain valid e-mail of customer |
customer_phone | required* | string(32) | Must contain valid phone number of customer |
birth_date | required* | dd-mm-yyyy | Required when MCC is a Financial Services one (e.g. MCC 6012) and either card brand is Visa or Mastercard/Maestro with UK-based merchant, UK-based bin (domestic), and DEBIT card type |
document_id | required* | string(255) | Document ID value. |
fx_rate_id | optional | integer | See Get rates for FX Service. Offers the option to use a specific FX rate to convert the transaction processing amount. Used FX rate should have the same source currency as the processing currency. Contact tech-support@emerchantpay.com for more details |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required* | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
neighborhood | optional | string(255) | Neighborhood |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
customer_identification | required* | See Customer Identification Parameters for more details. | |
owner | required* | string(255) | The owner of the document ID |
type | required* | string(255) | The type of the document ID |
subtype | required* | string(255) | The subtype of the document ID |
document_id | required* | string(255) | Document ID value. |
issuing_country | required* | string(2) | The issuing country of the document ID |
account_owner | optional | Account owner parameters related to account owner inquiry requests | |
first_name | optional | string(35) | Account owner first name |
middle_name | optional | string(35) | Account owner middle name |
last_name | optional | string(35) | Account owner last name |
dynamic_descriptor_params | optional | ||
merchant_name | optional | string(25) | Allows to dynamically override the charge descriptor |
merchant_city | optional | string(13) | Allows to dynamically override the merchant phone number |
sub_merchant_id | optional | string(15) | Allows to dynamically override the sub-merchant ID. |
merchant_country | optional | string(3) | Allows to dynamically override the merchant country. |
merchant_state | optional | string(3) | Allows to dynamically override the merchant subdivision code. |
merchant_zip_code | optional | string(10) | Allows to dynamically override the merchant zip/postal code. Required for VISA OCT transactions with Australian and Canadian card bins. |
merchant_address | optional | string(48) | Allows to dynamically override the merchant address. |
merchant_url | optional | string(60) | Allows to dynamically override the merchant URL |
merchant_phone | optional | string(16) | Allows to dynamically override the merchant phone number. |
merchant_service_city | optional | string(13) | Allows to dynamically override the merchant service city. |
merchant_service_country | optional | string(3) | Allows to dynamically override the merchant service country. |
merchant_service_state | optional | string(3) | Allows to dynamically override the merchant service subdivision code. |
merchant_service_zip_code | optional | string(10) | Allows to dynamically override the merchant service zip/postal code. |
merchant_service_phone | optional | string(16) | Allows to dynamically override the merchant service phone number. |
merchant_geo_coordinates | optional | string(20) | Allows to dynamically override the merchant geographic coordinates. |
merchant_service_geo_coordinates | optional | string(20) | Allows to dynamically override the merchant service geographic coordinates. |
required* = conditionally required
Successful Response
stdClass Object
(
[transaction_type] => payout
[status] => approved
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[consumer_id] => 123456
[token] => ee946db8-d7db-4bb7-b608-b65b153e127d
[avs_response_code] => 5I
[avs_response_text] => Response provided by issuer processor; Address information not verified
[authorization_code] => 345678
[retrieval_reference_number] => 016813015184
[response_code] => 00
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:57.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
[scheme_response_code] => 00
[account_owner] => {"first_name"=>"Travis", "middle_name"=>"Joe", "last_name"=>"Pastrana"}
)
<payment_response content=[
<transaction_type content=[payout]>
<status content=[approved]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<consumer_id content=[123456]>
<token content=[ee946db8-d7db-4bb7-b608-b65b153e127d]>
<avs_response_code content=[5I]>
<avs_response_text content=[Response provided by issuer processor; Address information not verified]>
<authorization_code content=[345678]>
<retrieval_reference_number content=[016813015184]>
<response_code content=[00]>
<timestamp content=[2025-01-16T10:23:57Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[true]>
<scheme_response_code content=[00]>
<account_owner content=[{"first_name"=>"Travis", "middle_name"=>"Joe", "last_name"=>"Pastrana"}]>
]>
{
transaction_type: "payout",
status: "approved",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
consumer_id: "123456",
token: "ee946db8-d7db-4bb7-b608-b65b153e127d",
avs_response_code: "5I",
avs_response_text: "Response provided by issuer processor; Address information not verified",
authorization_code: "345678",
retrieval_reference_number: "016813015184",
response_code: "00",
timestamp: "2025-01-16T10:23:57Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "true",
scheme_response_code: "00",
account_owner: "{"first_name"=>"Travis", "middle_name"=>"Joe", "last_name"=>"Pastrana"}",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>payout</transaction_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<consumer_id>123456</consumer_id>
<token>ee946db8-d7db-4bb7-b608-b65b153e127d</token>
<avs_response_code>5I</avs_response_code>
<avs_response_text>Response provided by issuer processor; Address information not verified</avs_response_text>
<authorization_code>345678</authorization_code>
<retrieval_reference_number>016813015184</retrieval_reference_number>
<response_code>00</response_code>
<timestamp>2025-01-16T10:23:57Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
<scheme_response_code>00</scheme_response_code>
<account_owner>
<first_name>Travis</first_name>
<middle_name>Joe</middle_name>
<last_name>Pastrana</last_name>
</account_owner>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
consumer_id | string(10) | Consumer unique reference. See Consumers |
token | string(36) | Plain-text token value. See Tokenization |
avs_response_code | string(255) | Generated by the card network on trying to match the billing address when performing the address verification. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
avs_response_text | string(255) | Gives the human response text for the AVS response code above. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
authorization_code | string(6) | Generated by the card network when an authorisation has occurred, used to identify that auth. Consists of 6 alphanumeric chars |
retrieval_reference_number | string(255) | A reference number used for tracking all messages related to a given cardholder transaction returned by some acquirers. |
response_code | string(2) | Defines the result of a transaction with the acquirer, the status of a message or some action taken or required. Contact tech-support@emerchantpay.com for more details. |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
scheme_response_code | string(2) | The response code returned from the schemes. See Scheme response codes for details. |
recurring_advice_code | string(2) | Additional response code returned from the schemes. See Recurring advice details |
recurring_advice_text | string(255) | The text representation of the recurring advice code. |
Error Response
stdClass Object
(
[transaction_type] => payout
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[response_code] => 57
[code] => 340
[technical_message] => billing_address[zip_code] is invalid!
[message] => billing_address[zip_code] is invalid!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:57.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => false
)
<payment_response content=[
<transaction_type content=[payout]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<response_code content=[57]>
<code content=[340]>
<technical_message content=[billing_address[zip_code] is invalid!]>
<message content=[billing_address[zip_code] is invalid!]>
<timestamp content=[2025-01-16T10:23:57Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[false]>
]>
{
transaction_type: "payout",
status: "error",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
response_code: "57",
code: "340",
technical_message: "billing_address[zip_code] is invalid!",
message: "billing_address[zip_code] is invalid!",
timestamp: "2025-01-16T10:23:57Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "false",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>payout</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<response_code>57</response_code>
<code>340</code>
<technical_message>billing_address[zip_code] is invalid!</technical_message>
<message>billing_address[zip_code] is invalid!</message>
<timestamp>2025-01-16T10:23:57Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
response_code | string(2) | Defines the result of a transaction with the acquirer, the status of a message or some action taken or required. Contact tech-support@emerchantpay.com for more details. |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Money transfer Payout
Money transfer payout is a standard payout with additional parameters. The section and parameters below are optional and to be considered only when present.
Money transfers: account_to_account, person_to_person, wallet_transfer, funds_transfer, liquid_assets.
The transaction is not a result of a business operation but rather a pure funds movement from one account (card or non-card) to another (card).
Bear in mind that the sender of the funds in this case is not a merchant, but a consumer.
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Payout');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('4200000000000000')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
->setServiceProviderName('')
->setMoneyTransfer('{"type"=>"account_to_account", "sender_account_number"=>"DE91100000000123456789", "sender_birth_date"=>"24-09-1987", "service_provider_name"=>"eMPPay", "sender_address"=>{"first_name"=>"John", "last_name"=>"Smith", "country"=>"JoDEhn", "city"=>"Berlin", "zip_code"=>"10115", "address1"=>"1 Kaiserdamm Blvd, Berlin"}}');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.PayoutRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
PayoutRequest request = new PayoutRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4200000000000000");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
request.setServiceProviderName("");
request.setMoneyTransfer("{"type"=>"account_to_account", "sender_account_number"=>"DE91100000000123456789", "sender_birth_date"=>"24-09-1987", "service_provider_name"=>"eMPPay", "sender_address"=>{"first_name"=>"John", "last_name"=>"Smith", "country"=>"JoDEhn", "city"=>"Berlin", "zip_code"=>"10115", "address1"=>"1 Kaiserdamm Blvd, Berlin"}}");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.payout(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "4200000000000000",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"service_provider_name": null,
"money_transfer": {
"type": "account_to_account",
"sender_account_number": "DE91100000000123456789",
"sender_birth_date": "24-09-1987",
"service_provider_name": "eMPPay",
"sender_address": {
"first_name": "John",
"last_name": "Smith",
"country": "JoDEhn",
"city": "Berlin",
"zip_code": "10115",
"address1": "1 Kaiserdamm Blvd, Berlin"
}
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>payout</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4200000000000000</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<payment_transaction>service_provider_name</payment_transaction>
<money_transfer>
<type>account_to_account</type>
<sender_account_number>DE91100000000123456789</sender_account_number>
<sender_birth_date>24-09-1987</sender_birth_date>
<service_provider_name>eMPPay</service_provider_name>
<sender_address>
<first_name>John</first_name>
<last_name>Smith</last_name>
<country>JoDEhn</country>
<city>Berlin</city>
<zip_code>10115</zip_code>
<address1>1 Kaiserdamm Blvd, Berlin</address1>
</sender_address>
</money_transfer>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
money_transfer | optional | Money transfer Parameters | |
type | required | string | The type of money transfer. It can be account_to_account, person_to_person, wallet_transfer, funds_transfer, liquid_assets |
sender_account_number | required | string(33) | Sender account number |
sender_birth_date | optional | dd-mm-yyyy | Must contain valid birth date of the sender. |
service_provider_name | optional | string(25) | Must contain a valid Service Provider Name. Only alphanumeric characters are allowed (including spaces). |
sender_address | required | ||
first_name | required | string(255) | Sender first name |
last_name | required | string(255) | Sender last name |
country | required | string(2) | Sender Country code in ISO 3166 |
city | required | string(255) | Sender City |
zip_code | required | string | Sender ZIP code |
address1 | required | string(255) | Sender Primary address |
state | required* | string(2) | Sender State code in ISO 3166-2, required for USA and Canada |
required* = conditionally required
Money transfer is supported only by Visa.
Money transfer type |
---|
account_to_account |
person_to_person |
wallet_transfer |
funds_transfer |
liquid_assets |
Successful Response
stdClass Object
(
[transaction_type] => payout
[status] => approved
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[response_code] =>
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:58.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
)
<payment_response content=[
<transaction_type content=[payout]>
<status content=[approved]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<response_code content=[]>
<timestamp content=[2025-01-16T10:23:58Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
]>
{
transaction_type: "payout",
status: "approved",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
response_code: "",
timestamp: "2025-01-16T10:23:58Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>payout</transaction_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<payment_response>response_code</payment_response>
<timestamp>2025-01-16T10:23:58Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
</payment_response>
Error Response
stdClass Object
(
[transaction_type] => payout
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 340
[technical_message] => money_transfer_type is not supported. Please select one of account_to_account, person_to_person, wallet_transfer, funds_transfer, liquid_assets
[message] => Please check input data for errors!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:58.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
)
<payment_response content=[
<transaction_type content=[payout]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<code content=[340]>
<technical_message content=[money_transfer_type is not supported. Please select one of account_to_account, person_to_person, wallet_transfer, funds_transfer, liquid_assets]>
<message content=[Please check input data for errors!]>
<timestamp content=[2025-01-16T10:23:58Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
]>
{
transaction_type: "payout",
status: "error",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
code: "340",
technical_message: "money_transfer_type is not supported. Please select one of account_to_account, person_to_person, wallet_transfer, funds_transfer, liquid_assets",
message: "Please check input data for errors!",
timestamp: "2025-01-16T10:23:58Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>payout</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>340</code>
<technical_message>money_transfer_type is not supported. Please select one of account_to_account, person_to_person, wallet_transfer, funds_transfer, liquid_assets</technical_message>
<message>Please check input data for errors!</message>
<timestamp>2025-01-16T10:23:58Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
</payment_response>
Non-money transfer Payout
Non-money transfer payout is a standard payout with additional parameters. The section and parameters below are optional and to be considered only when present.
Non-money transfer types are: b2b_supplier, loyalty, funds_disbursment, merchant_settlement, prepaid_card_load.
The transaction is a result of a business operation.
Bear in mind that the sender of the funds in this case is a merchant.
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Payout');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('4200000000000000')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
->setMoneyTransfer('{"type"=>"loyalty"}');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.PayoutRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
PayoutRequest request = new PayoutRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4200000000000000");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
request.setMoneyTransfer("{"type"=>"loyalty"}");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.payout(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "4200000000000000",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"money_transfer": {
"type": "loyalty"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>payout</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4200000000000000</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<money_transfer>
<type>loyalty</type>
</money_transfer>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
money_transfer | optional | Non-money transfer Parameters | |
type | required | string | The type of non-money transfer. It can be b2b_supplier, loyalty, funds_disbursment, merchant_settlement, prepaid_card_load |
required* = conditionally required
Non-money transfer is supported only by Visa.
The listed non-money transfer types are allowed for all merchant category codes (MCCs).
Non-money transfer type |
---|
b2b_supplier |
loyalty |
funds_disbursment |
merchant_settlement |
prepaid_card_load |
Successful Response
stdClass Object
(
[transaction_type] => payout
[status] => approved
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[response_code] =>
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:58.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
)
<payment_response content=[
<transaction_type content=[payout]>
<status content=[approved]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<response_code content=[]>
<timestamp content=[2025-01-16T10:23:58Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
]>
{
transaction_type: "payout",
status: "approved",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
response_code: "",
timestamp: "2025-01-16T10:23:58Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>payout</transaction_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<payment_response>response_code</payment_response>
<timestamp>2025-01-16T10:23:58Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
</payment_response>
Error Response
stdClass Object
(
[transaction_type] => payout
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 340
[technical_message] => money_transfer_type is not supported. Please select one of b2b_supplier, loyalty, funds_disbursment, merchant_settlement, prepaid_card_load
[message] => Please check input data for errors!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:58.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
)
<payment_response content=[
<transaction_type content=[payout]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<code content=[340]>
<technical_message content=[money_transfer_type is not supported. Please select one of b2b_supplier, loyalty, funds_disbursment, merchant_settlement, prepaid_card_load]>
<message content=[Please check input data for errors!]>
<timestamp content=[2025-01-16T10:23:58Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
]>
{
transaction_type: "payout",
status: "error",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
code: "340",
technical_message: "money_transfer_type is not supported. Please select one of b2b_supplier, loyalty, funds_disbursment, merchant_settlement, prepaid_card_load",
message: "Please check input data for errors!",
timestamp: "2025-01-16T10:23:58Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>payout</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>340</code>
<technical_message>money_transfer_type is not supported. Please select one of b2b_supplier, loyalty, funds_disbursment, merchant_settlement, prepaid_card_load</technical_message>
<message>Please check input data for errors!</message>
<timestamp>2025-01-16T10:23:58Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
</payment_response>
SCT Payout
SCT payouts are Sepa-based payouts to consumers done without a reference transaction and as such are regulated and need specific gateway terminal configuration, so be sure to contact the IT Support team at tech-support@emerchantpay.com) in case you want SCT payouts to be enabled.
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\SDD\Payout');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('EUR')
->setIban('DE09100100101234567891')
->setBic('PBNKDEFFXXX')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingCountry('DE');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.sdd.SDDPayoutRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
SDDPayoutRequest request = new SDDPayoutRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("EUR");
request.setIban("DE09100100101234567891");
request.setBic("PBNKDEFFXXX");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingCountry("DE");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.sct_payout(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "EUR",
"iban": "DE09100100101234567891",
"bic": "PBNKDEFFXXX",
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"country": "DE"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>sct_payout</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>EUR</currency>
<iban>DE09100100101234567891</iban>
<bic>PBNKDEFFXXX</bic>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<country>DE</country>
</billing_address>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
iban | required | string(34) | Customer’s IBAN number |
bic | required | string(11) | SWIFT/BIC code of the customer’s bank |
billing_address | required | See Required vs Optional API params for details | |
first_name | required | string(255) | Customer first name |
last_name | required | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
neighborhood | optional | string(255) | Neighborhood |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: sct_payout |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
iban | required | string(34) | Customer’s IBAN number |
bic | required | string(11) | SWIFT/BIC code of the customer’s bank |
billing_address | required | See Required vs Optional API params for details | |
first_name | required | string(255) | Customer first name |
last_name | required | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
neighborhood | optional | string(255) | Neighborhood |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported countries:
Allowed countries include supported countries for SDD Init Recurring Sale and the list below:
Country Name | Country Code |
---|---|
Bulgaria | BG |
Croatia | HR |
Czech Republics | CZ |
Denmark | DK |
United Kingdom | UK |
Hungary | HU |
Iceland | IS |
Liechtenstein | LI |
Norway | NO |
Poland | PL |
Romania | RO |
Sweden | SE |
Switzerland | CH |
Successful Response
stdClass Object
(
[transaction_type] => sct_payout
[status] => approved
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:58.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => EUR
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[sct_payout]>
<status content=[approved]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<timestamp content=[2025-01-16T10:23:58Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[EUR]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "sct_payout",
status: "approved",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
technical_message: "Transaction successful!",
message: "Transaction successful!",
timestamp: "2025-01-16T10:23:58Z",
descriptor: "Descriptor one",
amount: "100",
currency: "EUR",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>sct_payout</transaction_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:58Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>EUR</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => sct_payout
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 340
[technical_message] => expiration_year is invalid
[message] => expiration_year is invalid
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:58.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => EUR
[sent_to_acquirer] => false
)
<payment_response content=[
<transaction_type content=[sct_payout]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<code content=[340]>
<technical_message content=[expiration_year is invalid]>
<message content=[expiration_year is invalid]>
<timestamp content=[2025-01-16T10:23:58Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[EUR]>
<sent_to_acquirer content=[false]>
]>
{
transaction_type: "sct_payout",
status: "error",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
code: "340",
technical_message: "expiration_year is invalid",
message: "expiration_year is invalid",
timestamp: "2025-01-16T10:23:58Z",
descriptor: "Descriptor one",
amount: "100",
currency: "EUR",
sent_to_acquirer: "false",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>sct_payout</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>340</code>
<technical_message>expiration_year is invalid</technical_message>
<message>expiration_year is invalid</message>
<timestamp>2025-01-16T10:23:58Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>EUR</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
African Mobile Payout
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>african_mobile_payout</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<amount>100</amount>
<currency>KES</currency>
<customer_email>barney.rubble@example.com</customer_email>
<customer_phone>254701123456</customer_phone>
<operator>SAFARICOM</operator>
<target>000010</target>
<billing_address>
<first_name>Barney</first_name>
<last_name>Rubble</last_name>
<address1>14, Nerazdelni str</address1>
<zip_code>1407</zip_code>
<city>Nairobi</city>
<country>KE</country>
</billing_address>
<risk_params>
<user_id>123456</user_id>
</risk_params>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: african_mobile_payout |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | required* | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
operator | required | string(20) | Name of the Mobile network operator (MNO) which should process the transaction |
target | required | string(20) | Number of the Paybill for which the transaction is intended |
customer_phone | required | string(32) | Must contain valid phone number of customer |
customer_email | required* | e-mail address | Must contain valid e-mail of customer |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
neighborhood | optional | string(255) | Neighborhood |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported countries, currencies, operators and payment method:
Country code | Currency code | Operator | Payment method |
---|---|---|---|
GH | GHS | AIRTEL | Airtel Money |
GH | GHS | MTN | MTN Mobile Money |
GH | GHS | TIGO | Tigo Cash |
GH | GHS | VODACOM | M-PESA |
KE | KES | AIRTEL | Airtel Money |
KE | KES | SAFARICOM | M-PESA |
MZ | MZN | MOVITEL | e-Mola |
MZ | MZN | VODACOM | M-PESA |
RW | RWF | MTN | MTN Mobile Money |
RW | RWF | TIGO | Tigo Cash |
TZ | TZS | AIRTEL | Airtel Money |
TZ | TZS | TIGO | Tigo Cash |
TZ | TZS | VODACOM | M-PESA |
UG | UGX | AIRTEL | Airtel Money |
UG | UGX | MTN | MTN Mobile Money |
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>african_mobile_payout</transaction_type>
<status>pending_async</status>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:58Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>KES</currency>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
Error Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>african_mobile_payout</transaction_type>
<status>error</status>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<message>Something went wrong, please contact support!</message>
<technical_message>operator is not supported!</technical_message>
<timestamp>2025-01-16T10:23:58Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>KES</currency>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
message | string(255) | Human readable error message which can be displayed to users. |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
Russian Mobile Payout
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>russian_mobile_payout</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<amount>100</amount>
<currency>RUB</currency>
<customer_email>barney.rubble@example.com</customer_email>
<customer_phone>79031234567</customer_phone>
<billing_address>
<first_name>Barney</first_name>
<last_name>Rubble</last_name>
<address1>14, Nerazdelni str</address1>
<zip_code>1407</zip_code>
<city>Nairobi</city>
<country>RU</country>
</billing_address>
<risk_params>
<user_id>123456</user_id>
</risk_params>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: russian_mobile_payout |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
customer_phone | required | string(32) | Must contain valid phone number of customer |
customer_email | optional | e-mail address | Must contain valid e-mail of customer |
billing_address | required | See Required vs Optional API params for details | |
first_name | required | string(255) | Customer first name |
last_name | required | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
neighborhood | optional | string(255) | Neighborhood |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
neighborhood | optional | string(255) | Neighborhood |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported countries and currencies:
Country code | Currency code |
---|---|
RU | RUB |
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>russian_mobile_payout</transaction_type>
<status>pending_async</status>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:58Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>RUB</currency>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
TransferTo Payout
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>transfer_to_payout</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>Funding</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<amount>100</amount>
<currency>USD</currency>
<customer_email>barney.rubble@example.com</customer_email>
<payer_id>7</payer_id>
<bank_account_number>0842024000</bank_account_number>
<billing_address>
<last_name>Rubble</last_name>
</billing_address>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: transfer_to_payout |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
customer_email | required* | e-mail address | Must contain valid e-mail of customer |
payer_id | required | string | ID of the Payer used to deliver the money through one of the 3 services. For more details regarding how the available payers are populated see Retrieve Payers API |
bank_account_number | required* | string | Bank identification number of the customer. *Requirement based on the Payer |
indian_financial_system_code | required* | string | Bank code of the bank in which the consumer resides. *Requirement based on the Payer |
msisdn | required* | string | Phone number for payment to bank account and wallet registration number for payment to wallet. Min 6 and max 32 digits. Numeric values only (can contain “+” at start or “(“ , ”)” , ”-“). *Requirement based on the Payer |
branch_number | required* | string | Branch number. *Requirement based on the Payer |
account_type | required* | string | Account type. Allowed values: CHECKING, SAVINGS, DEPOSIT, OTHERS. *Requirement based on the Payer |
registered_name | required* | string | Registered name of the business. *Requirement based on the Payer |
registration_number | required* | string | Registration number. *Requirement based on the Payer |
document_reference_number | required* | string | Reference number for the contract. *Requirement only for Business-to-Business (B2B) workflow |
purpose_of_remittance | required* | string | Identification type. Allowed values: FAMILY_SUPPORT, EDUCATION, GIFT_AND_DONATION, MEDICAL_TREATMENT, MAINTENANCE_EXPENSES, TRAVEL, SMALL_VALUE_REMITTANCE, LIBERALIZED_REMITTANCE, OTHER. *Requirement only for Business-to-Business (B2B) workflow |
iban | required* | string | Bank account number in IBAN format. *Requirement based on the Payer |
id_type | required* | string | Identification type. Allowed values: PASSPORT, NATIONAL_ID, DRIVING_LICENSE, SOCIAL_SECURITY, TAX_ID, SENIOR_CITIZEN_ID, BIRTH_CERTIFICATE, VILLAGE_ELDER_ID, RESIDENT_CARD, ALIEN_REGISTRATION, PAN_CARD, VOTERS_ID, HEALTH_CARD, EMPLOYER_ID, OTHER. *Requirement based on the Payer |
id_number | required* | string | Identification number. *Requirement based on the Payer |
sender_date_of_birth | required* | string | Date of birth with the following format YYYY-MM-DD. *Requirement based on the Payer |
sender_last_name | required* | string | First name of the sender. *Requirement based on the Payer |
sender_first_name | required* | string | First name of the sender. *Requirement based on the Payer |
sender_country_iso_code | required* | string | Three-letter country code of the sender. *Requirement based on the Payer |
sender_id_number | required* | string | Identification number of the sender. *Requirement based on the Payer |
sender_nationality_country_iso_code | required* | string | Three-letter country code corresponding to the nationality of the sender. *Requirement based on the Payer |
sender_address | required* | string | First line of address of the sender. *Requirement based on the Payer |
sender_occupation | required* | string | Occupation of the sender. *Requirement based on the Payer |
sender_beneficiary_relationship | required* | string | Relationship between the sender and the beneficiary. *Requirement based on the Payer |
sender_postal_code | required* | string | Postal code of the sender. *Requirement based on the Payer |
sender_city | required* | string | City of the sender. *Requirement based on the Payer |
sender_msisdn | required* | string | Phone number for payment to bank account and wallet registration number for payment to wallet. Min 6 and max 32 digits. Numeric values only (can contain “+” at start or “(“ , ”)” , ”-“). *Requirement based on the Payer |
sender_gender | required* | string | Gender of the sender. *Requirement based on the Payer |
sender_id_type | required* | string | Identification type of the sender. Allowed values: PASSPORT, NATIONAL_ID, DRIVING_LICENSE, SOCIAL_SECURITY, TAX_ID, SENIOR_CITIZEN_ID, BIRTH_CERTIFICATE, VILLAGE_ELDER_ID, RESIDENT_CARD, ALIEN_REGISTRATION, PAN_CARD, VOTERS_ID, HEALTH_CARD, EMPLOYER_ID, OTHER. *Requirement based on the Payer |
sender_province_state | required* | string | Province State of the sender. *Requirement based on the Payer |
sender_source_of_funds | required* | string | Source of funds of the sender. *Requirement based on the Payer |
sender_country_of_birth_iso_code | required* | string | Three-letter country code corresponding to the country of birth of the sender. *Requirement based on the Payer |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(3) | Three-letter country code in alpha-3 format |
required* = conditionally required
Supported currencies:
Currency |
---|
EUR |
GBP |
HKD |
USD |
Supported destination countries and currencies:
Country | Country Code | Currency |
---|---|---|
Brazil | BRA | BRL |
China | CHN | CNY |
Indonesia | IDN | IDR |
Malaysia | MYS | MYR |
Philippines | PHL | PHP |
Thailand | THA | THB |
Argentina | ARG | ARS |
Chile | CHL | CLP |
Mexico | MEX | MXN |
Peru | PER | PEN |
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>transfer_to_payout</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:58Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
Error Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>transfer_to_payout</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>910</code>
<technical_message>Payer is currently unavailable</technical_message>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:58Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
Mobile Payments
Apple Pay
Payment Object structure
{
"token": {
"paymentData": { ... },
"paymentMethod": { ... },
"transactionIdentifier": "32b...4f3"
},
"billingContact": { ... },
"shippingContact": { ... }
}
To use the Apple Pay, your application should be set up with public, private keys and payment processing certificate. Please contact tech-support@emerchantpay.com to enable Apple Pay payments.
Once a payment authorized by the customer in the merchant’s application, the Apple Pay APIs will return a Payment Object containing the payment data (Encrypted Payment Token) with customer information to the merchant’s application. On the right is an example of the Payment Object structure that will be returned to the merchant’s application.
Once a Payment Object received, it can be used to create an Apple Pay payment transaction. To create an Apple Pay
payment transaction you should specify the Encrypted Payment Token in the <payment_token>
tag and the
payment type you need in the <payment_subtype>
tag. To specify Encrypted Payment Token use the value of the
token
field of the received Payment Object.
The following payment types are supported:
Payment type | Description |
---|---|
authorize | behaves like common authorize transaction |
init_recurring_sale | behaves like common init_recurring_sale transaction |
sale | behaves like common sale transaction |
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>apple_pay</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<payment_subtype>authorize</payment_subtype>
<recurring_type>initial</recurring_type>
<payment_token>
{
"paymentData": { ... },
"paymentMethod": { ... },
"transactionIdentifier": "32B...4F3"
}
</payment_token>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<business_attributes>
<event_start_date>17-02-2025</event_start_date>
<event_end_date>26-02-2025</event_end_date>
<event_organizer_id>20192375</event_organizer_id>
<event_id>1912</event_id>
</business_attributes>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: apple_pay |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
payment_token | required | Encrypted Payment Token | |
payment_subtype | required | Use either authorize for Authorize or sale for Sale transactions. | |
usage | optional | string(255) | Description of the transaction for later use. |
recurring_type | optional | string(255) | Specifies recurring type of the transaction. Use initial. |
amount | required | integer >= 0 | Transaction amount in minor currency unit, see Currency and Amount Handling for details. In certain cases, it is possible to submit a transaction with a zero-value amount to act as an account verification transaction - Contact tech-support@emerchantpay.com for more details regarding this scenario. |
currency | required | string(3) | Currency code in ISO 4217 |
customer_email | required* | e-mail address | Must contain valid e-mail of customer |
customer_phone | required* | string(32) | Must contain valid phone number of customer |
birth_date | required* | dd-mm-yyyy | Required when MCC is a Financial Services one (e.g. MCC 6012) and either card brand is Visa or Mastercard/Maestro with UK-based merchant, UK-based bin (domestic), and DEBIT card type |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
document_id | required* | string(255) | Document ID value. |
business_attributes | required* | Check business attributes section. | |
event_start_date | required* | dd-mm-yyyy | The date when event starts in format dd-mm-yyyy |
event_end_date | required* | dd-mm-yyyy | The date when event ends in format dd-mm-yyyy |
event_organizer_id | required* | string | |
event_id | required* | string | |
date_of_order | required* | dd-mm-yyyy | The date when order was placed in format dd-mm-yyyy |
delivery_date | required* | dd-mm-yyyy | Date of the expected delivery in format dd-mm-yyyy |
name_of_the_supplier | required* | string | |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required* | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
neighborhood | optional | string(255) | Neighborhood |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
funding | optional | Funding Transaction Params | |
identifier_type | required* | string | This is only required in case of Mastercard. Type of Funding Transaction. Please check Identifier Types |
business_application_identifier | required* | string | This is only required in case of VISA. Type of VISA Funding Transaction. Please check BAI |
receiver | optional | Funding Transaction Receiver details | |
first_name | required* | string | First name of the receiver |
last_name | required* | string | Last name of the receiver |
country | required* | string(2) | Country code in ISO 3166 |
account_number | required* | string | Receiver account number. Mandatory for Mastercard. If Sender Reference Number is provided then it becomes optional for VISA |
account_number_type | required* | string | This is only required in case of Mastercard. Receiver account number type. Please check Receiver Account Types |
address | required* | string | Receiver address. Only required in case of VISA and Canadian cards |
state | required* | string | Receiver state. Only required in case of VISA and Canadian cards |
city | required* | string | Receiver city. Only required in case of VISA and Canadian cards |
sender | optional | Funding Transaction Sender details | |
name | required* | string | Sender name. Only required in case of VISA |
reference_number | required* | string | Sender Reference Number. Only required in case of VISA. This is option if Receiver Account Number is provided |
country | required* | string | Sender country. Only required in case of VISA. If not provided billing address is used |
address | required* | string | Sender address. Only required in case of VISA. If not provided billing address is used |
state | required* | string | Sender state. Only required in case of VISA and Canadian card. If not provided billing address is used |
city | required* | string | Sender city. Only required in case of VISA. If not provided billing address is used |
dynamic_descriptor_params | optional | ||
merchant_name | optional | string(25) | Allows to dynamically override the charge descriptor |
merchant_city | optional | string(13) | Allows to dynamically override the merchant phone number |
sub_merchant_id | optional | string(15) | Allows to dynamically override the sub-merchant ID. |
merchant_country | optional | string(3) | Allows to dynamically override the merchant country. |
merchant_state | optional | string(3) | Allows to dynamically override the merchant subdivision code. |
merchant_zip_code | optional | string(10) | Allows to dynamically override the merchant zip/postal code. Required for VISA OCT transactions with Australian and Canadian card bins. |
merchant_address | optional | string(48) | Allows to dynamically override the merchant address. |
merchant_url | optional | string(60) | Allows to dynamically override the merchant URL |
merchant_phone | optional | string(16) | Allows to dynamically override the merchant phone number. |
merchant_service_city | optional | string(13) | Allows to dynamically override the merchant service city. |
merchant_service_country | optional | string(3) | Allows to dynamically override the merchant service country. |
merchant_service_state | optional | string(3) | Allows to dynamically override the merchant service subdivision code. |
merchant_service_zip_code | optional | string(10) | Allows to dynamically override the merchant service zip/postal code. |
merchant_service_phone | optional | string(16) | Allows to dynamically override the merchant service phone number. |
merchant_geo_coordinates | optional | string(20) | Allows to dynamically override the merchant geographic coordinates. |
merchant_service_geo_coordinates | optional | string(20) | Allows to dynamically override the merchant service geographic coordinates. |
required* = conditionally required
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>apple_pay</transaction_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<consumer_id>123456</consumer_id>
<avs_response_code>5I</avs_response_code>
<avs_response_text>Response provided by issuer processor; Address information not verified</avs_response_text>
<authorization_code>345678</authorization_code>
<response_code>00</response_code>
<timestamp>2025-01-16T10:23:58Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
<scheme_transaction_identifier>019091214161031</scheme_transaction_identifier>
<payment_account_reference>50019P9LBXOLHN9G7QMU5VN520YSY</payment_account_reference>
</payment_response>
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>apple_pay</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<payment_subtype>authorize</payment_subtype>
<payment_token>
{
"paymentData": { ... },
"paymentMethod": { ... },
"transactionIdentifier": "32B...4F3"
}
</payment_token>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>0</amount>
<currency>USD</currency>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<business_attributes>
<event_start_date>17-02-2025</event_start_date>
<event_end_date>26-02-2025</event_end_date>
<event_organizer_id>20192375</event_organizer_id>
<event_id>1912</event_id>
</business_attributes>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
</payment_transaction>'
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>apple_pay</transaction_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<consumer_id>123456</consumer_id>
<avs_response_code>5I</avs_response_code>
<avs_response_text>Response provided by issuer processor; Address information not verified</avs_response_text>
<authorization_code>345678</authorization_code>
<response_code>00</response_code>
<timestamp>2025-01-16T10:23:58Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>0</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
<scheme_transaction_identifier>019091214161031</scheme_transaction_identifier>
<payment_account_reference>50019P9LBXOLHN9G7QMU5VN520YSY</payment_account_reference>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
consumer_id | string(10) | Consumer unique reference. See Consumers |
gaming | 'true' | Signifies whether a gaming transaction is performed. Gaming transactions usually use MCC 7995, contact tech support for more details. |
avs_response_code | string(255) | Generated by the card network on trying to match the billing address when performing the address verification. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
avs_response_text | string(255) | Gives the human response text for the AVS response code above. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
authorization_code | string(6) | Generated by the card network when an authorisation has occurred, used to identify that auth. Consists of 6 alphanumeric chars |
response_code | string(2) | Defines the result of a transaction with the acquirer, the status of a message or some action taken or required. Contact tech-support@emerchantpay.com for more details. |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
partial_approval | string(4) | Optional, set to ’true’ if partial approval happened. Partially approved amount is then in the amount field. Check Partial Approvals for details |
sent_to_acquirer | string(255) | "true" or "false" |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
scheme_transaction_identifier | string(32) | Id defined by card schemes. Corresponds to NETWORK DATA (field 63) for MasterCard or TRANS ID (field 62.2/125) for VISA. |
payment_account_reference | string(255) | Payment Account Reference value returned from the schemes. Links tokenized and PAN-based transactions. |
Error Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>apple_pay</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>340</code>
<technical_message>expiration_year is invalid</technical_message>
<message>expiration_year is invalid</message>
<timestamp>2025-01-16T10:23:58Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
gaming | 'true' | Signifies whether a gaming transaction is performed. Gaming transactions usually use MCC 7995, contact tech support for more details. |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
Google Pay
Payment Object structure
{
"signature":"...",
"intermediateSigningKey":{
"signedKey":"{
"keyValue": "...",
"keyExpiration": "..."
}",
"signatures":[...]
},
"protocolVersion":"...",
"signedMessage":"{
"encryptedMessage": "...",
"ephemeralPublicKey": "...",
"tag": "..."
}"
}
Once payment is authorized by the customer in the merchant’s application, the Google Pay APIs will return a Payment Method Token containing the payment data (Encrypted Payment Token) with customer information to the merchant’s application. On the right is an example of the Payment Method Token structure that will be returned to the merchant’s application.
Once a Payment Object is received, it can be used to create a Google Pay payment transaction. To create a Google Pay
payment transaction you should specify the Encrypted Payment Token in the <payment_token>
tag and the
payment type you need in the <payment_subtype>
tag.
The following payment types are supported:
Payment type | Description |
---|---|
authorize | behaves like common authorize transaction |
init_recurring_sale | behaves like common init_recurring_sale transaction |
sale | behaves like common sale transaction |
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>google_pay</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<payment_subtype>authorize</payment_subtype>
<recurring_type>initial</recurring_type>
<payment_token>
{
"signature":"...",
"intermediateSigningKey":{
"signedKey":"{
"keyValue": "...",
"keyExpiration": "..."
}",
"signatures":[...]
},
"protocolVersion":"...",
"signedMessage":"{
"encryptedMessage": "...",
"ephemeralPublicKey": "...",
"tag": "..."
}"
}
</payment_token>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<business_attributes>
<event_start_date>17-02-2025</event_start_date>
<event_end_date>26-02-2025</event_end_date>
<event_organizer_id>20192375</event_organizer_id>
<event_id>1912</event_id>
</business_attributes>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
</payment_transaction>'
Asynchronous 3 D Sv2 Challenge With 3 Ds Method Request
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>google_pay</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<payment_subtype>authorize</payment_subtype>
<payment_token>
{
"signature":"...",
"intermediateSigningKey":{
"signedKey":"{
"keyValue": "...",
"keyExpiration": "..."
}",
"signatures":[...]
},
"protocolVersion":"...",
"signedMessage":"{
"encryptedMessage": "...",
"ephemeralPublicKey": "...",
"tag": "..."
}"
}
</payment_token>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<business_attributes>
<event_start_date>17-02-2025</event_start_date>
<event_end_date>26-02-2025</event_end_date>
<event_organizer_id>20192375</event_organizer_id>
<event_id>1912</event_id>
</business_attributes>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<notification_url>https://www.example.com/notification</notification_url>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<threeds_v2_params>
<threeds_method>
<callback_url>https://www.example.com/threeds/threeds_method/callback</callback_url>
</threeds_method>
<control>
<device_type>browser</device_type>
<challenge_window_size>full_screen</challenge_window_size>
<challenge_indicator>preference</challenge_indicator>
</control>
<purchase>
<category>service</category>
</purchase>
<recurring>
<expiration_date>17-07-2025</expiration_date>
<frequency>30</frequency>
</recurring>
<merchant_risk>
<shipping_indicator>verified_address</shipping_indicator>
<delivery_timeframe>electronic</delivery_timeframe>
<reorder_items_indicator>reordered</reorder_items_indicator>
<pre_order_purchase_indicator>merchandise_available</pre_order_purchase_indicator>
<pre_order_date>17-02-2025</pre_order_date>
<gift_card>true</gift_card>
<gift_card_count>2</gift_card_count>
</merchant_risk>
<card_holder_account>
<creation_date>17-01-2024</creation_date>
<update_indicator>more_than_60days</update_indicator>
<last_change_date>17-10-2024</last_change_date>
<password_change_indicator>no_change</password_change_indicator>
<password_change_date>02-01-2025</password_change_date>
<shipping_address_usage_indicator>current_transaction</shipping_address_usage_indicator>
<shipping_address_date_first_used>12-01-2025</shipping_address_date_first_used>
<transactions_activity_last_24_hours>2</transactions_activity_last_24_hours>
<transactions_activity_previous_year>10</transactions_activity_previous_year>
<provision_attempts_last_24_hours>1</provision_attempts_last_24_hours>
<purchases_count_last_6_months>5</purchases_count_last_6_months>
<suspicious_activity_indicator>no_suspicious_observed</suspicious_activity_indicator>
<registration_indicator>30_to_60_days</registration_indicator>
<registration_date>17-01-2023</registration_date>
</card_holder_account>
<browser>
<accept_header>*/*</accept_header>
<java_enabled>false</java_enabled>
<language>en-GB</language>
<color_depth>24</color_depth>
<screen_height>900</screen_height>
<screen_width>1440</screen_width>
<time_zone_offset>-120</time_zone_offset>
<user_agent>Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36</user_agent>
</browser>
<sdk>
<interface>native</interface>
<ui_types>
<ui_type>multi_select</ui_type>
</ui_types>
<application_id>fc1650c0-5778-0138-8205-2cbc32a32d65</application_id>
<encrypted_data>encrypted-data-here</encrypted_data>
<ephemeral_public_key_pair>public-key-pair</ephemeral_public_key_pair>
<max_timeout>10</max_timeout>
<reference_number>sdk-reference-number-here</reference_number>
</sdk>
</threeds_v2_params>
</payment_transaction>'
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>google_pay</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<payment_subtype>authorize</payment_subtype>
<payment_token>
{
"signature":"...",
"intermediateSigningKey":{
"signedKey":"{
"keyValue": "...",
"keyExpiration": "..."
}",
"signatures":[...]
},
"protocolVersion":"...",
"signedMessage":"{
"encryptedMessage": "...",
"ephemeralPublicKey": "...",
"tag": "..."
}"
}
</payment_token>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>0</amount>
<currency>USD</currency>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<business_attributes>
<event_start_date>17-02-2025</event_start_date>
<event_end_date>26-02-2025</event_end_date>
<event_organizer_id>20192375</event_organizer_id>
<event_id>1912</event_id>
</business_attributes>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: google_pay |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
payment_token | required | Encrypted Payment Token | |
payment_subtype | required | Use either authorize for Authorize or sale for Sale transactions. | |
recurring_type | optional | string(255) | Specifies recurring type of the transaction. Use initial. |
usage | optional | string(255) | Description of the transaction for later use. |
amount | required | integer >= 0 | Transaction amount in minor currency unit, see Currency and Amount Handling for details. In certain cases, it is possible to submit a transaction with a zero-value amount to act as an account verification transaction - Contact tech-support@emerchantpay.com for more details regarding this scenario. |
currency | required | string(3) | Currency code in ISO 4217 |
customer_email | required* | e-mail address | Must contain valid e-mail of customer |
customer_phone | required* | string(32) | Must contain valid phone number of customer |
birth_date | required* | dd-mm-yyyy | Required when MCC is a Financial Services one (e.g. MCC 6012) and either card brand is Visa or Mastercard/Maestro with UK-based merchant, UK-based bin (domestic), and DEBIT card type |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
document_id | required* | string(255) | Document ID value. |
business_attributes | required* | Check business attributes section. | |
event_start_date | required* | dd-mm-yyyy | The date when event starts in format dd-mm-yyyy |
event_end_date | required* | dd-mm-yyyy | The date when event ends in format dd-mm-yyyy |
event_organizer_id | required* | string | |
event_id | required* | string | |
date_of_order | required* | dd-mm-yyyy | The date when order was placed in format dd-mm-yyyy |
delivery_date | required* | dd-mm-yyyy | Date of the expected delivery in format dd-mm-yyyy |
name_of_the_supplier | required* | string | |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required* | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
neighborhood | optional | string(255) | Neighborhood |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
notification_url | required* | url | URL at merchant where gateway sends outcome of transaction. |
return_success_url | required* | url | URL where customer is sent to after successful payment |
return_failure_url | required* | url | URL where customer is sent to after unsuccessful payment |
funding | optional | Funding Transaction Params | |
identifier_type | required* | string | This is only required in case of Mastercard. Type of Funding Transaction. Please check Identifier Types |
business_application_identifier | required* | string | This is only required in case of VISA. Type of VISA Funding Transaction. Please check BAI |
receiver | optional | Funding Transaction Receiver details | |
first_name | required* | string | First name of the receiver |
last_name | required* | string | Last name of the receiver |
country | required* | string(2) | Country code in ISO 3166 |
account_number | required* | string | Receiver account number. Mandatory for Mastercard. If Sender Reference Number is provided then it becomes optional for VISA |
account_number_type | required* | string | This is only required in case of Mastercard. Receiver account number type. Please check Receiver Account Types |
address | required* | string | Receiver address. Only required in case of VISA and Canadian cards |
state | required* | string | Receiver state. Only required in case of VISA and Canadian cards |
city | required* | string | Receiver city. Only required in case of VISA and Canadian cards |
sender | optional | Funding Transaction Sender details | |
name | required* | string | Sender name. Only required in case of VISA |
reference_number | required* | string | Sender Reference Number. Only required in case of VISA. This is option if Receiver Account Number is provided |
country | required* | string | Sender country. Only required in case of VISA. If not provided billing address is used |
address | required* | string | Sender address. Only required in case of VISA. If not provided billing address is used |
state | required* | string | Sender state. Only required in case of VISA and Canadian card. If not provided billing address is used |
city | required* | string | Sender city. Only required in case of VISA. If not provided billing address is used |
threeds_v2_params | required* | 3DSv2 async parameters. They must be submitted in order to use the 3DSv2 authentication protocol in asynchronous workflow | |
threeds_method | optional | 3DS-Method related parameters for any callbacks and notifications. | |
callback_url | optional | url | Specific 3DS-Method callback URL after the 3DS-Method completes. The actual status will be provided via HTTP POST to that URL. For more information, go to 3DSv2 method params |
control | required* | General params for preferences in authentication flow and providing device interface information. | |
device_type | required* | string | Identifies the device channel of the consumer, required in the 3DSv2 authentication protocol. For more information, go to 3DSv2 control params |
challenge_window_size | required* | string | Identifies the size of the challenge window for the consumer. For more information, go to 3DSv2 control params |
challenge_indicator | optional | string | The value has weight and might impact the decision whether a challenge will be required for the transaction or not. If not provided, it will be interpreted as no_preference. For more information, go to 3DSv2 control params |
purchase | optional | Purchase related params providing with additional information regarding the order. | |
category | optional | string | Identifies the type of transaction being authenticated. This field is required in some markets.Accepted values are: goods, service, check_acceptance, account_funding, quasi_cash, prepaid_activation, loan. |
merchant_risk | recommended | Merchant risk assessment params. They are all optional, but recommended. | |
shipping_indicator | optional | string(16) | Indicator code that most accurately describes the shipping method for the cardholder specific transaction. If one or more items are included in the sale, use the Shipping Indicator code for the physical goods. If all digital goods, use the code that describes the most expensive item. Accepted values are: same_as_billing, stored_address, verified_address, pick_up, digital_goods, travel, event_tickets, other. |
delivery_timeframe | optional | string(11) | Indicates the merchandise delivery timeframe. Accepted values are: electronic, same_day, over_night, another_day. |
reorder_items_indicator | optional | string(10) | Indicates whether the cardholder is reordering previously purchased merchandise. Accepted values are: first_time, reordered. |
pre_order_purchase_indicator | optional | string(21) | Indicates whether cardholder is placing an order for merchandise with a future-availability or release date. Accepted values are: merchandise_available, future_availability. |
pre_order_date | optional | dd-mm-yyyy | For a pre-ordered purchase, the expected date that the merchandise will be available. |
gift_card | optional | 'true' | Prepaid or gift card purchase. |
gift_card_count | optional | integer | For prepaid or gift card purchase, total count of individual prepaid or gift cards/codes purchased. The value is limited to 99. |
card_holder_account | recommended | Cardholder account additional information. They are all optional, but recommended, because they have a significant impact on approval rates | |
creation_date | optional | dd-mm-yyyy | Date that the cardholder opened the account with the 3DS Requester. |
update_indicator | optional | string(19) | Length of time since the cardholder’s account information with the 3DS Requestor was last changed. Includes Billing or Shipping address, new payment account, or new user(s) added. Accepted values are: current_transaction, less_than_30days, 30_to_60_days, more_than_60days. |
last_change_date | optional | dd-mm-yyyy | Date that the cardholder’s account with the 3DS Requestor was last changed. Including Billing or Shipping address, new payment accout, or new user(s) added. |
password_change_indicator | optional | string(18) | Length of time since the cardholder account with the 3DS Requestor had a password change or account reset. Accepted values are: no_change, during_transaction, less_than_30days, 30_to_60_days, more_than_60days. |
password_change_date | optional | dd-mm-yyyy | Date that cardholder’s account with the 3DS Requestor had a password change or account reset. |
shipping_address_usage_indicator | optional | string(19) | Indicates when the shipping address used for this transaction was first used with the 3DS Requestor. Accepted values are: current_transaction, less_than_30days, 30_to_60_days, more_than_60days. |
shipping_address_date_first_used | optional | dd-mm-yyyy | Date when the shipping address used for this transaction was first used with the 3DS Requestor. |
transactions_activity_last_24_hours | optional | integer | Number of transactions (successful and abandoned) for this cardholder account with the 3DS Requestor across all payment accounts in the previous 24 hours. |
transactions_activity_previous_year | optional | integer | Number of transactions (successful and abandoned) for this cardholder account with the 3DS Requestor across all payment accounts in the previous year. |
provision_attempts_last_24_hours | optional | integer | Number of Add Card attempts in the last 24 hours. |
purchases_count_last_6_months | optional | integer | Number of purchases with this cardholder account during the previous six months. |
suspicious_activity_indicator | optional | string(22) | Indicates whether the 3DS Requestor has experienced suspicious activity (including previous fraud) on the cardholder account. Accepted values are: no_suspicious_observed, suspicious_observed. |
registration_indicator | optional | string(19) | Indicates the length of time that the payment account was enrolled in the cardholder’s account with the 3DS Requester. Accepted values are: guest_checkout, current_transaction, less_than_30days, 30_to_60_days, more_than_60days. |
registration_date | optional | dd-mm-yyyy | Date that the payment account was enrolled in the cardholder’s account with the 3DS Requestor. |
browser | required* | For browser-based transactions. They are all required in case the device_type is set to browser | |
accept_header | required* | string(2048) | The exact content of the HTTP ACCEPT header as sent to the 3DS Requester from the Cardholder browser. Any other header different than the ACCEPT header will be rejected. Example: application/json,text/plain,text/html,*/* . |
java_enabled | required* | boolean | Boolean that represents the ability of the cardholder browser to execute Java. The value can be retrieved by accessing a property of the navigator with JavaScript, navigator.javaEnabled . |
language | required* | string(8) | Value representing the browser language as defined in IETF BCP47. Note that only one browser language tag is about to be submitted as per the above IETF BCP47. Numeric chars are also allowed in the subtag and will represent the region.Example: en-GB , zh-guoyu , fil-PH , gsw , es-419 , de-1996 , etc. The value can be retrieved by accessing a property of the navigator with JavaScript, navigator.language . |
color_depth | required* | integer | Value representing the bit depth of the colour palette for displaying images, in bits per pixel. Obtained from Cardholder browser using the screen.colorDepth property. The value as per EMVCo specs can be one of 1, 4, 8, 15, 16, 24, 32, 48. In case, an unsupported color_depth is determined, the nearest supported value that is less than the actual one needs to be submitted. For example, if the obtained value is 30, which is not supported as per EMVCo specs, 24 has to be submitted. |
screen_height | required* | integer | Total height of the Cardholder's screen in pixels. Value is returned from the screen.height property. |
screen_width | required* | integer | Total width of the Cardholder's screen in pixels. Value is returned from the screen.width property. |
time_zone_offset | required* | string(5) | Time difference between UTC time and the Cardholder browser local time, in minutes. Note that the offset is positive if the local time zone is behind UTC and negative if it is ahead. If UTC -5 hours then submit 300 or +300 , If UTC +2 hours then -120 . The value can be retrieved using Javascript getTimezoneOffset() method over Date object. |
user_agent | required* | string(2048) | Exact content of the HTTP user-agent header. |
sdk | required* | For application-based transactions. They are all required in case the device_type is set to application | |
interface | required* | string(6) | SDK Interface types that the device of the consumer supports for displaying specific challenge interfaces within the SDK. Accepted values are: native, html, both. |
ui_types | required* | Lists all UI types that the device of the consumer supports for displaying specific challenge interfaces within the SDK. | |
ui_type | required* | string(13) | UI type that the device of the consumer supports for displaying specific challenge interface. Accepted values are: text, single_select, multi_select, out_of_bag, other_html. |
application_id | required* | string(36) | Universally unique ID created upon all installations and updates of the 3DS Requestor APp on a Customer Device. This will be newly generated and stored by the 3DS SDK for each installation or update. The field is limited to 36 characters and it shall have a canonical format as defined in IETF RFC 4122. |
encrypted_data | required* | string(64000) | JWE Object as defined Section 6.2.2.1 containing data encrypted by the SDK for the DS to decrypt. The data will be present when sending to DS, but not present from DS to ACS. |
ephemeral_public_key_pair | required* | string(256) | Public key component of the ephemeral key pair generated by the 3DS SDK and used to establish session keys between the 3DS SDK and ACS. In AReq, this data element is contained within the ACS Signed Content JWS Object. The field is limited to maximum 256 characters. |
max_timeout | required* | integer | Indicates the maximum amount of time (in minutes) for all exchanges. The field shall have value greater or equals than 05. |
reference_number | required* | string(32) | Identifies the vendor and version of the 3DS SDK that is integrated in a 3DS Requestor App, assigned by EMVCo when the 3DS SDK is approved. The field is limited to 32 characters. |
recurring | optional | Additional recurring details. | |
expiration_date | optional | dd-mm-yyyy | A future date indicating the end date for any further subsequent transactions. For more information, go to 3DSv2 recurring params |
frequency | optional | integer | Indicates the minimum number of days between subsequent transactions. An empty value indicates the payment frequency is not set.For more information, go to 3DSv2 recurring params |
dynamic_descriptor_params | optional | ||
merchant_name | optional | string(25) | Allows to dynamically override the charge descriptor |
merchant_city | optional | string(13) | Allows to dynamically override the merchant phone number |
sub_merchant_id | optional | string(15) | Allows to dynamically override the sub-merchant ID. |
merchant_country | optional | string(3) | Allows to dynamically override the merchant country. |
merchant_state | optional | string(3) | Allows to dynamically override the merchant subdivision code. |
merchant_zip_code | optional | string(10) | Allows to dynamically override the merchant zip/postal code. Required for VISA OCT transactions with Australian and Canadian card bins. |
merchant_address | optional | string(48) | Allows to dynamically override the merchant address. |
merchant_url | optional | string(60) | Allows to dynamically override the merchant URL |
merchant_phone | optional | string(16) | Allows to dynamically override the merchant phone number. |
merchant_service_city | optional | string(13) | Allows to dynamically override the merchant service city. |
merchant_service_country | optional | string(3) | Allows to dynamically override the merchant service country. |
merchant_service_state | optional | string(3) | Allows to dynamically override the merchant service subdivision code. |
merchant_service_zip_code | optional | string(10) | Allows to dynamically override the merchant service zip/postal code. |
merchant_service_phone | optional | string(16) | Allows to dynamically override the merchant service phone number. |
merchant_geo_coordinates | optional | string(20) | Allows to dynamically override the merchant geographic coordinates. |
merchant_service_geo_coordinates | optional | string(20) | Allows to dynamically override the merchant service geographic coordinates. |
required* = conditionally required
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>google_pay</transaction_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<consumer_id>123456</consumer_id>
<avs_response_code>5I</avs_response_code>
<avs_response_text>Response provided by issuer processor; Address information not verified</avs_response_text>
<authorization_code>345678</authorization_code>
<response_code>00</response_code>
<timestamp>2025-01-16T10:23:58Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
<scheme_transaction_identifier>019091214161031</scheme_transaction_identifier>
<payment_account_reference>50019P9LBXOLHN9G7QMU5VN520YSY</payment_account_reference>
</payment_response>
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>google_pay</transaction_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<consumer_id>123456</consumer_id>
<avs_response_code>5I</avs_response_code>
<avs_response_text>Response provided by issuer processor; Address information not verified</avs_response_text>
<authorization_code>345678</authorization_code>
<response_code>00</response_code>
<timestamp>2025-01-16T10:23:58Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>0</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
<scheme_transaction_identifier>019091214161031</scheme_transaction_identifier>
<payment_account_reference>50019P9LBXOLHN9G7QMU5VN520YSY</payment_account_reference>
</payment_response>
Challenge Without 3 Ds Mеthod Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>google_pay</transaction_type>
<status>pending_async</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<consumer_id>123456</consumer_id>
<token>ee946db8-d7db-4bb7-b608-b65b153e127d</token>
<redirect_url>https://staging.gate.emerchantpay.net/threeds/authentication/44177a21403427eb96664a6d7e5d5d48</redirect_url>
<redirect_url_type>3ds_v2_challenge</redirect_url_type>
<timestamp>2025-01-16T10:23:58Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Asynchronous 3 D Sv2 Challenge With 3 Ds Method Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>google_pay</transaction_type>
<status>pending_async</status>
<mode>test</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<threeds_method_url>https://staging.gate.emerchantpay.net/threeds/threeds_method</threeds_method_url>
<threeds_method_continue_url>https://staging.gate.emerchantpay.net/threeds/threeds_method/44177a21403427eb96664a6d7e5d5d48</threeds_method_continue_url>
<timestamp>2025-01-16T10:23:58Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
consumer_id | string(10) | Consumer unique reference. See Consumers |
gaming | 'true' | Signifies whether a gaming transaction is performed. Gaming transactions usually use MCC 7995, contact tech support for more details. |
avs_response_code | string(255) | Generated by the card network on trying to match the billing address when performing the address verification. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
avs_response_text | string(255) | Gives the human response text for the AVS response code above. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
authorization_code | string(6) | Generated by the card network when an authorisation has occurred, used to identify that auth. Consists of 6 alphanumeric chars |
response_code | string(2) | Defines the result of a transaction with the acquirer, the status of a message or some action taken or required. Contact tech-support@emerchantpay.com for more details. |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
redirect_url | url | URL where user has to be redirected to complete payment process. It is available for asynchronous mode |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
partial_approval | string(4) | Optional, set to ’true’ if partial approval happened. Partially approved amount is then in the amount field. Check Partial Approvals for details |
sent_to_acquirer | string(255) | "true" or "false" |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
scheme_transaction_identifier | string(32) | Id defined by card schemes. Corresponds to NETWORK DATA (field 63) for MasterCard or TRANS ID (field 62.2/125) for VISA. |
payment_account_reference | string(255) | Payment Account Reference value returned from the schemes. Links tokenized and PAN-based transactions. |
Error Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>google_pay</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>340</code>
<technical_message>expiration_year is invalid</technical_message>
<message>expiration_year is invalid</message>
<timestamp>2025-01-16T10:23:58Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
gaming | 'true' | Signifies whether a gaming transaction is performed. Gaming transactions usually use MCC 7995, contact tech support for more details. |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
Supported countries
Country Name | Country Code |
---|---|
Albania | AL |
Algeria | DZ |
American Samoa | AS |
Andorra | AD |
Angola | AO |
Antigua and Barbuda | AG |
Argentina | AR |
Armenia | AM |
Australia | AU |
Austria | AT |
Azerbaijan | AZ |
Bahamas | BS |
Bahrain | BH |
Bangladesh | BD |
Barbados | BB |
Belarus | BY |
Belgium | BE |
Belize | BZ |
Benin | BJ |
Bhutan | BT |
Bolivia | BO |
Bosnia and Herzegovina | BA |
Botswana | BW |
Brazil | BR |
Brunei | BN |
Bulgaria | BG |
Burkina Faso | BF |
Burundi | BI |
Cambodia | KH |
Cameroon | CM |
Canada | CA |
Cape Verde | CV |
Central African Republic | CF |
Chad | TD |
Chile | CL |
China | CN |
Colombia | CO |
Comoros | KM |
Congo (Democratic Republic) | CD |
Congo (Republic) | CG |
Costa Rica | CR |
Croatia | HR |
Cyprus | CY |
Czech Republic | CZ |
Czechia | CZ |
Denmark | DK |
Djibouti | DJ |
Dominica | DM |
Dominican Republic | DO |
Ecuador | EC |
Egypt | EG |
El Salvador | SV |
Equatorial Guinea | GQ |
Eritrea | ER |
Estonia | EE |
Eswatini | SZ |
Ethiopia | ET |
Fiji | FJ |
Finland | FI |
France | FR |
Gabon | GA |
Gambia | GM |
Georgia | GE |
Germany | DE |
Ghana | GH |
Greece | GR |
Grenada | GD |
Guatemala | GT |
Guinea | GN |
Guinea-Bissau | GW |
Guyana | GY |
Haiti | HT |
Honduras | HN |
Hong Kong | HK |
Hungary | HU |
Iceland | IS |
India | IN |
Indonesia | ID |
Iran | IR |
Iraq | IQ |
Ireland | IE |
Israel | IL |
Italy | IT |
Ivory Coast | CI |
Jamaica | JM |
Japan | JP |
Jordan | JO |
Kazakhstan | KZ |
Kenya | KE |
Kiribati | KI |
Kuwait | KW |
Kyrgyzstan | KG |
Laos | LA |
Latvia | LV |
Lebanon | LB |
Lesotho | LS |
Liberia | LR |
Libya | LY |
Liechtenstein | LI |
Lithuania | LT |
Luxembourg | LU |
Macao | MO |
Macedonia | MK |
Madagascar | MG |
Malawi | MW |
Malaysia | MY |
Maldives | MV |
Mali | ML |
Malta | MT |
Marshall Islands | MH |
Mauritania | MR |
Mauritius | MU |
Mexico | MX |
Micronesia | FM |
Moldova | MD |
Monaco | MC |
Mongolia | MN |
Montenegro | ME |
Morocco | MA |
Mozambique | MZ |
Myanmar | MM |
Namibia | NA |
Nauru | NR |
Nepal | NP |
Netherlands | NL |
New Zealand | NZ |
Nicaragua | NI |
Niger | NE |
Nigeria | NG |
Norway | NO |
Oman | OM |
Pakistan | PK |
Palau | PW |
Palestine | PS |
Panama | PA |
Papua New Guinea | PG |
Paraguay | PY |
Peru | PE |
Philippines | PH |
Poland | PL |
Portugal | PT |
Qatar | QA |
Romania | RO |
Russian Federation | RU |
Rwanda | RW |
Saint Kitts and Nevis | KN |
Saint Lucia | LC |
Saint Vincent and the Grenadines | VC |
Samoa | WS |
San Marino | SM |
São Tomé and Príncipe | ST |
Saudi Arabia | SA |
Senegal | SN |
Serbia | RS |
Seychelles | SC |
Sierra Leone | SL |
Singapore | SG |
Slovakia | SK |
Slovenia | SI |
Solomon Islands | SB |
Somalia | SO |
South Africa | ZA |
South Korea | KR |
Spain | ES |
Sri Lanka | LK |
Sudan | SD |
Suriname | SR |
Sweden | SE |
Switzerland | CH |
Syria | SY |
Taiwan | TW |
Tajikistan | TJ |
Tanzania | TZ |
Thailand | TH |
Togo | TG |
Tonga | TO |
Trinidad and Tobago | TT |
Tunisia | TN |
Turkey | TR |
Turkmenistan | TM |
Uganda | UG |
Ukraine | UA |
United Arab Emirates | AE |
United Kingdom | GB |
United States Minor Outlying Islands | UM |
United States of America | US |
Uruguay | UY |
Uzbekistan | UZ |
Vanuatu | VU |
Vatican City | VA |
Venezuela | VE |
Vietnam | VN |
Yemen | YE |
Zambia | ZM |
Zimbabwe | ZW |
African Mobile Sale
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>african_mobile_sale</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<amount>100</amount>
<currency>KES</currency>
<customer_email>barney.rubble@example.com</customer_email>
<customer_phone>254701123456</customer_phone>
<operator>SAFARICOM</operator>
<target>000010</target>
<billing_address>
<first_name>Barney</first_name>
<last_name>Rubble</last_name>
<address1>14, Nerazdelni str</address1>
<zip_code>1407</zip_code>
<city>Nairobi</city>
<country>KE</country>
</billing_address>
<risk_params>
<user_id>123456</user_id>
</risk_params>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: african_mobile_sale |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
operator | required | string(20) | Name of the Mobile network operator (MNO) which should process the transaction |
target | required | string(20) | Number of the Paybill for which the transaction is intended |
customer_email | required* | e-mail address | Must contain valid e-mail of customer |
customer_phone | required | string(32) | Must contain valid phone number of customer |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported countries, currencies, operators and payment method:
Country code | Currency code | Operator | Payment method |
---|---|---|---|
GH | GHS | VODACOM | M-PESA |
KE | KES | SAFARICOM | M-PESA |
UG | UGX | AIRTEL | Airtel Money |
UG | UGX | MTN | MTN Mobile Money |
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>african_mobile_sale</transaction_type>
<status>pending_async</status>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:58Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>KES</currency>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
Error Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>african_mobile_sale</transaction_type>
<status>error</status>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<message>Something went wrong, please contact support!</message>
<technical_message>operator is not supported</technical_message>
<timestamp>2025-01-16T10:23:58Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>KES</currency>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
message | string(255) | Human readable error message which can be displayed to users. |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
Russian Mobile Sale
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>russian_mobile_sale</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>152</usage>
<remote_ip>245.253.2.12</remote_ip>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<amount>100</amount>
<currency>RUB</currency>
<customer_email>barney.rubble@example.com</customer_email>
<customer_phone>79031234567</customer_phone>
<operator>megafon</operator>
<target>15472</target>
<billing_address>
<first_name>Barney</first_name>
<last_name>Rubble</last_name>
<address1>14, Nerazdelni str</address1>
<zip_code>1407</zip_code>
<city>Nairobi</city>
<country>RU</country>
</billing_address>
<risk_params>
<user_id>123456</user_id>
</risk_params>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: russian_mobile_sale |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | required | string(5) | Customer account number or order identificator in the merchant system. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
return_success_url | required | url | URL where customer is sent to after successful payment |
return_failure_url | required | url | URL where customer is sent to after unsuccessful payment |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
operator | required | string | Mobile network operator name (mtc, megafon, tele2 or beeline). |
target | required | integer | Merchant prefix. Unique for each mobile network operator assigned for the merchant. |
customer_email | optional | e-mail address | Must contain valid e-mail of customer |
customer_phone | required | string(32) | Must contain valid phone number of customer |
billing_address | required | See Required vs Optional API params for details | |
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Supported countries, currencies and operators:
Country code | Currency code | Operator |
---|---|---|
RU | RUB | МТС |
RU | RUB | Megafon |
RU | RUB | Tele2 |
RU | RUB | Beeline |
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>russian_mobile_sale</transaction_type>
<status>pending_async</status>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:23:58Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>RUB</currency>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
Error Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>russian_mobile_sale</transaction_type>
<status>error</status>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<message>Something went wrong, please contact support!</message>
<technical_message>operator is not supported</technical_message>
<timestamp>2025-01-16T10:23:58Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>RUB</currency>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
message | string(255) | Human readable error message which can be displayed to users. |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
Reversals
Reversal transactions serve to change the state of the original transaction and return money back to customer’s account. They can be used with Card, 3DS Card, and different APM transactions.
Refund
Refunds allow to return already billed amounts to customers.
The amount can be fully or partially refunded. Refunds can only be done as follow transactions on former successfully processed transactions:
- Card transactions
- 3DS Card transactions
- Wallets
- Vouchers
- Online Banking ePayments
- Cash payments
- Gift Cards
Therefore, the reference id for the corresponding transaction is mandatory.
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Refund');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReferenceId('43672')
->setAmount('100')
->setCurrency('USD');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.RefundRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
RefundRequest request = new RefundRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setReferenceId("43672");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.refund(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"reference_id": "43672",
"amount": "100",
"currency": "USD"
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>refund</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<reference_id>43672</reference_id>
<amount>100</amount>
<currency>USD</currency>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: refund |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
reference_id | required | string(32) | Unique id returned by corresponding transaction |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
beneficiary_bank_code | required* | string | The bank code of the beneficiary's bank. |
beneficiary_name | required* | string | The name of the beneficiary's bank. |
beneficiary_account_number | required* | string | The account number of the beneficiary in his bank. |
bank | optional | string | Name of the customer's bank |
bank_branch | optional | string | Name of the Bank branch |
bank_account | optional | string | Bank account number of the customer. |
bank_account_type | optional | string(1) | The type of account. C: for Checking accounts, S: for Savings accounts, I: for International accounts |
required* = conditionally required
Successful Response
stdClass Object
(
[transaction_type] => refund
[status] => approved
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[authorization_code] => 345678
[retrieval_reference_number] => 016813015184
[response_code] => 00
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:59.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
)
<payment_response content=[
<transaction_type content=[refund]>
<status content=[approved]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<authorization_code content=[345678]>
<retrieval_reference_number content=[016813015184]>
<response_code content=[00]>
<timestamp content=[2025-01-16T10:23:59Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
]>
{
transaction_type: "refund",
status: "approved",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
authorization_code: "345678",
retrieval_reference_number: "016813015184",
response_code: "00",
timestamp: "2025-01-16T10:23:59Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>refund</transaction_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<authorization_code>345678</authorization_code>
<retrieval_reference_number>016813015184</retrieval_reference_number>
<response_code>00</response_code>
<timestamp>2025-01-16T10:23:59Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
authorization_code | string(6) | Generated by the card network when an authorisation has occurred, used to identify that auth. Consists of 6 alphanumeric chars |
retrieval_reference_number | string(255) | A reference number used for tracking all messages related to a given cardholder transaction returned by some acquirers. |
response_code | string(2) | Defines the result of a transaction with the acquirer, the status of a message or some action taken or required. Contact tech-support@emerchantpay.com for more details. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
Error Response
stdClass Object
(
[transaction_type] => refund
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 410
[technical_message] => no approved reference transaction found
[message] => no approved reference transaction found
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:59.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
)
<payment_response content=[
<transaction_type content=[refund]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<code content=[410]>
<technical_message content=[no approved reference transaction found]>
<message content=[no approved reference transaction found]>
<timestamp content=[2025-01-16T10:23:59Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
]>
{
transaction_type: "refund",
status: "error",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
code: "410",
technical_message: "no approved reference transaction found",
message: "no approved reference transaction found",
timestamp: "2025-01-16T10:23:59Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>refund</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>410</code>
<technical_message>no approved reference transaction found</technical_message>
<message>no approved reference transaction found</message>
<timestamp>2025-01-16T10:23:59Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
response_code | string(2) | Defines the result of a transaction with the acquirer, the status of a message or some action taken or required. Contact tech-support@emerchantpay.com for more details. |
code | integer | Error code according to Error code table |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
Async Refund
Async Refunds allow to return already billed amounts to customers where the transaction is confirmed asynchronously (i.e. the transaction is sent for processing without the client being blocked waiting and once the transaction is complete the client is notified about the result).
The amount can be fully or partially refunded. Async Refunds are only required for a few APMs. Please contact tech-support@emerchantpay.com for more details.
Similarly to ordinary Refunds, the reference id for the corresponding transaction is mandatory.
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>async_refund</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<reference_id>43672</reference_id>
<amount>100</amount>
<currency>USD</currency>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: async_refund |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
reference_id | required | string(32) | Unique id returned by corresponding transaction |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
beneficiary_bank_code | required* | string | The bank code of the beneficiary's bank. |
beneficiary_name | required* | string | The name of the beneficiary's bank. |
beneficiary_account_number | required* | string | The account number of the beneficiary in his bank. |
bank | optional | string | Name of the customer's bank |
bank_branch | optional | string | Name of the Bank branch |
bank_account | optional | string | Bank account number of the customer. |
bank_account_type | optional | string(1) | The type of account. C: for Checking accounts, S: for Savings accounts, I: for International accounts |
required* = conditionally required
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>async_refund</transaction_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<authorization_code>345678</authorization_code>
<response_code>00</response_code>
<timestamp>2025-01-16T10:23:59Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
authorization_code | string(6) | Generated by the card network when an authorisation has occurred, used to identify that auth. Consists of 6 alphanumeric chars |
response_code | string(2) | Defines the result of a transaction with the acquirer, the status of a message or some action taken or required. Contact tech-support@emerchantpay.com for more details. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
Error Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>async_refund</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>410</code>
<technical_message>no approved reference transaction found</technical_message>
<message>no approved reference transaction found</message>
<timestamp>2025-01-16T10:23:59Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
response_code | string(2) | Defines the result of a transaction with the acquirer, the status of a message or some action taken or required. Contact tech-support@emerchantpay.com for more details. |
code | integer | Error code according to Error code table |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
Void
Void transactions undo other transactions.
Transactions of types authorize, capture, sale, refund, recurring sale, and init recurring sale along with their 3D variants can be reversed on the same day the transaction took place. The transaction will not show up on the customer’s credit card statement if voided on the same day.
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cancel');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReferenceId('43672');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.VoidRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
VoidRequest request = new VoidRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setReferenceId("43672");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.cancel(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"reference_id": "43672"
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>void</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<reference_id>43672</reference_id>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: void |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
reference_id | required | string(32) | Unique id returned by corresponding transaction |
required* = conditionally required
Successful Response
stdClass Object
(
[transaction_type] => void
[status] => approved
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[authorization_code] => 345678
[retrieval_reference_number] => 016813015184
[response_code] => 00
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:59.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[void]>
<status content=[approved]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<authorization_code content=[345678]>
<retrieval_reference_number content=[016813015184]>
<response_code content=[00]>
<timestamp content=[2025-01-16T10:23:59Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "void",
status: "approved",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
authorization_code: "345678",
retrieval_reference_number: "016813015184",
response_code: "00",
timestamp: "2025-01-16T10:23:59Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>void</transaction_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<authorization_code>345678</authorization_code>
<retrieval_reference_number>016813015184</retrieval_reference_number>
<response_code>00</response_code>
<timestamp>2025-01-16T10:23:59Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
authorization_code | string(6) | Generated by the card network when an authorisation has occurred, used to identify that auth. Consists of 6 alphanumeric chars |
retrieval_reference_number | string(255) | A reference number used for tracking all messages related to a given cardholder transaction returned by some acquirers. |
response_code | string(2) | Defines the result of a transaction with the acquirer, the status of a message or some action taken or required. Contact tech-support@emerchantpay.com for more details. |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => void
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 420
[technical_message] => can not do void on void reference
[message] => can not do void on void reference
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:59.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => false
)
<payment_response content=[
<transaction_type content=[void]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<code content=[420]>
<technical_message content=[can not do void on void reference]>
<message content=[can not do void on void reference]>
<timestamp content=[2025-01-16T10:23:59Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[false]>
]>
{
transaction_type: "void",
status: "error",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
code: "420",
technical_message: "can not do void on void reference",
message: "can not do void on void reference",
timestamp: "2025-01-16T10:23:59Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "false",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>void</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>420</code>
<technical_message>can not do void on void reference</technical_message>
<message>can not do void on void reference</message>
<timestamp>2025-01-16T10:23:59Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
response_code | string(2) | Defines the result of a transaction with the acquirer, the status of a message or some action taken or required. Contact tech-support@emerchantpay.com for more details. |
code | integer | Error code according to Error code table |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Invoice Refund
Invoice Refunds allow to return already billed amounts to customers.
The amount can be fully or partially refunded. Invoice refunds can only be done on former Invoice Capture (settled) transactions.
Therefore, the reference_id
for the corresponding transaction is mandatory.
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>invoice_refund</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<payment_type>klarna</payment_type>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<reference_id>43672</reference_id>
<amount>60</amount>
<currency>EUR</currency>
<items>
<item>
<item_type>physical</item_type>
<reference>19-402-USA</reference>
<name>BatteryPowerPack</name>
<quantity>1</quantity>
<unit_price>60</unit_price>
<tax_rate>0</tax_rate>
<total_amount>60</total_amount>
<total_discount_amount>0</total_discount_amount>
<total_tax_amount>0</total_tax_amount>
<image_url>https://example.com/image_url</image_url>
<product_url>https://example.com/product_url</product_url>
<quantity_unit>pcs</quantity_unit>
<merchant_data>
<marketplace_seller_info>Electronic gadgets</marketplace_seller_info>
</merchant_data>
</item>
</items>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: invoice_refund |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
payment_type | required | string | Payment provider type: klarna / secure_invoice |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
reference_id | required | string(32) | Unique id returned by corresponding transaction |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
items | required | List with items | |
item_type | required | string(255) | Order line type. Possible values: Supported item types |
quantity | required | integer | Non-negative. The item quantity |
unit_price | required | integer | Minor units. Includes tax, excludes discount(max value: 100000000) |
total_amount | required | integer | Includes tax and discount. Must match (quantity unit price) - total discount amount divided by quantity (max value: 100000000) |
reference | optional | string(255) | Article number, SKU or similar |
name | optional | string(255) | Descriptive item name |
tax_rate | optional | integer | Non-negative. In percent, two implicit decimals. I.e 2500 = 25.00 percent |
total_discount_amount | optional | integer | Non-negative minor units. Includes tax |
total_tax_amount | optional | integer | Must be within 1 of total amount - total_amount * 10000 / (10000 + tax rate). Negative when type is discount |
image_url | optional | url | URL to an image that can be later embedded in communications between Klarna and the customer. (max 1024 characters) |
product_url | optional | url | URL to an image that can be later embedded in communications between Klarna and the customer. (max 1024 characters) |
quantity_unit | optional | string(8) | Unit used to describe the quantity, e.g. kg, pcs... If defined has to be 1-8 characters |
product_identifiers | optional | List with product identifiers | |
brand | optional | string(255) | The product's brand name as generally recognized by consumers. If no brand is available for a product, do not supply any value |
category_path | optional | string(255) | The product's category path as used in the merchant's webshop. Include the full and most detailed category and separate the segments with ' > ' |
global_trade_item_number | optional | string(255) | The product's Global Trade Item Number (GTIN). Common types of GTIN are EAN, ISBN or UPC. Exclude dashes and spaces, where possible |
manufacturer_part_number | optional | string(255) | The product's Manufacturer Part Number (MPN), which - together with the brand - uniquely identifies a product. Only submit MPNs assigned by a manufacturer and use the most specific MPN possible |
merchant_data | optional | List with merchant data | |
marketplace_seller_info | optional | string(255) | Information for merchant marketplace |
required* = conditionally required
Supported item types:
Item Types |
---|
physical |
discount |
shipping_fee |
sales_tax |
digital |
gift_card |
store_credit |
surcharge |
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>invoice_refund</transaction_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<timestamp>2025-01-16T10:23:59Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>60</amount>
<currency>EUR</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>invoice_refund</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>420</code>
<technical_message>can not do void on void reference</technical_message>
<message>can not do void on void reference</message>
<timestamp>2025-01-16T10:23:59Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>60</amount>
<currency>EUR</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
BitPay Refund
BitPay Refund is a custom refund method which will handle the asynchronous BitPay refund workflow. BitPay refunds can only be done on former transactions. Therefore, the reference id for the corresponding BitPay Sale transaction is mandatory.
BitPay Refund is an asynchronous transaction type.
When a BitPay Refund is requested, BitPay will send an email to the consumer with a request to provide the refund crypto address. This request will be valid for 3 days and will expire afterwards. When the crypto address is provided, the refund will be processed (processing usually takes 24 hours).
A Notification will be sent to the Merchant when the Bitpay refund is completed.
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Crypto\BitPay\Refund');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setReferenceId('43672')
->setAmount('100')
->setCurrency('USD');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>bitpay_refund</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<reference_id>43672</reference_id>
<amount>100</amount>
<currency>USD</currency>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: bitpay_refund |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
reference_id | required | string(32) | The reference_id must be a BitPay Sale transaction |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
required* = conditionally required
Successful Response
stdClass Object
(
[transaction_type] => bitpay_refund
[status] => approved
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:59.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>bitpay_refund</transaction_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<timestamp>2025-01-16T10:23:59Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
Error Response
stdClass Object
(
[transaction_type] => bitpay_refund
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 410
[technical_message] => no approved reference transaction found
[message] => no approved reference transaction found
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:59.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>bitpay_refund</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>410</code>
<technical_message>no approved reference transaction found</technical_message>
<message>no approved reference transaction found</message>
<timestamp>2025-01-16T10:23:59Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
response_code | string(2) | Defines the result of a transaction with the acquirer, the status of a message or some action taken or required. Contact tech-support@emerchantpay.com for more details. |
code | integer | Error code according to Error code table |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
Partial Reversal
Partial reversal transactions are used in the preauthorization workflow to release a part of the total authorized amount.
PayByLink
PayByLink is a frictionless payment via link. It provides merchants the ability to send a payment link to a customer via email or SMS (configurable), using Virtual Terminal.
Workflow
The merchant can generate a PayByLink payment from the Virtual Terminal (if feature is enabled) by customizing an email template for sending payment link or configuring preferred medium (email/SMS) for sending payment link. When all the needed fields are filled in and the mandatory initial payload is provided, a payment request to the WPF is initiated. As a result of this request (if successful) the response would include redirect URL, which would be sent either via email or SMS to the customer (channel and needed email/phone number should be provided by the merchant when initiating the PayByLink payment). The customer can complete the payment by following the provided URL. It redirects to the merchant's web payment form (WPF) where the redirection workflows are the same as the ones described in the WPF section. The WPF reconcile API could also be used to check the status of any PayByLink initiated payment.
Combination with Pay Later functionality
The PayByLink triggered payments could be easily combined with the 'Pay Later' functionality (available also for the WPF API). The PayByLink form provides the ability to choose whether the customer would have the option enabled to delay the payment and complete it later. It also gives the ability of enqueuing reminders based on pre-configured values. The reminders include the URL for payment completion as well.
Reminders configuration
- Up to 3 reminders can be configured for each payment.
- The available channels for sending reminders are
email
andsms
. - The time for sending a reminder is set in number of minutes after payment creation.
- The time for sending of each reminder shouldn't be greater that the configured payment lifetime.
For configuration options or any other additional questions you can always contact Tech Support at tech-support@emerchantpay.com.
Alternative Payment Method External Events
Introduction
For some alternative payment method (APM) transactions additional events may occur resulting from various actions from the part of the consumer or the merchant. Examples: returned/reversed bank transfers, funds not received, additional bank transfers made using the same transaction reference number etc.
In Genesis these are called external events and are handled in the following manner:
- A transaction note is created for the external event (visible under the ”Transaction Notes” section on the corresponding payment transaction page in the merchant console).
- An API notification is sent to the merchant notification endpoint
- An email notification is sent to the merchant admin email address
- The original transaction status might be updated depending on the nature of the external event
List of external events per alternative payment method
APM | External event | Description | Status change |
---|---|---|---|
InstaDebit Payin | instadebit_payin_return | Payment has been returned to the consumer | voided |
InstaDebit Payin | instadebit_payin_adjustment | Payment has been adjusted | none |
InstaDebit Payout | instadebit_payout_return | Payment has been returned to the consumer | voided |
InstaDebit Payout | instadebit_payout_adjustment | Payment has been adjusted | none |
iDebit Payin | idebit_payin_return | Payment has been returned to the consumer | voided |
iDebit Payin | idebit_payin_adjustment | Payment has been adjusted | none |
iDebit Payout | idebit_payout_return | Payment has been returned to the consumer | voided |
iDebit Payout | idebit_payout_adjustment | Payment has been adjusted | none |
P24 | p24_external_refund | Payment has been rescinded by the consumer or was never received | refunded |
Argencard | chargeback_external_event | Payment has been considered fraudulent by the card issuer and was reversed | chargebacked |
Aura | chargeback_external_event | Payment has been considered fraudulent by the card issuer and was reversed | chargebacked |
Cabal | chargeback_external_event | Payment has been considered fraudulent by the card issuer and was reversed | chargebacked |
Cencosud | chargeback_external_event | Payment has been considered fraudulent by the card issuer and was reversed | chargebacked |
Elo | chargeback_external_event | Payment has been considered fraudulent by the card issuer and was reversed | chargebacked |
Naranja | chargeback_external_event | Payment has been considered fraudulent by the card issuer and was reversed | chargebacked |
Nativa | chargeback_external_event | Payment has been considered fraudulent by the card issuer and was reversed | chargebacked |
Tarjeta Shopping | chargeback_external_event | Payment has been considered fraudulent by the card issuer and was reversed | chargebacked |
Email Notification
An email is sent to the merchant admin’s email address detailing the external event type and any other relevant details together with a link to the original payment transaction.
API Notification
Merchants will receive API notifications every time Genesis obtains information about APM external events. Notifications are transmitted via HTTP POST (application/x-www-form-urlencoded) to the notification url endpoint provided in the XML request or to the Notification URL from the merchant account
An example notification:
¬ification_type=apm_external_event
&signature=8216b1b4929c0a41ed44bf51726c10872a78f181b26d1427e15410da56803fc0a2f
&payment_transaction_unique_id=64216236bced683952325b6698b3954a
&category=citadel_payin_chargeback
&priority=info
&code=SDR
&info=Revoked+payment+due+to+instant+payment+funds+not+received
&message=A+Citadel+Payin+transaction+has+been+reversed%2Frevoked.+Payment+has+been+rescinded+by+the+consumer+or+funds+were+never+received+for+the+payment.
&payload=...
Parameters:
Name | Type | Description |
---|---|---|
notification_type | string | constant value ”apm external event” |
signature | string | the signature of the notification, should be used to verify the the notification was sent by Genesis |
payment_transaction_unique_id | string | unique id of the original transaction, generated by Genesis |
category | string | type of the external event |
priority | string | can be one of ”info”, ”normal” or ”urgent” |
code | string | code for the external event from the APM provider system |
info | string | a short description of the external event |
message | string | full short description of the external event |
payload | string | the raw response for the external event as received from the APM provider |
The signature is a security measure meant to ensure that the gateway is really the sender of the notification. It is generated by concatenating the unique id of the payment with your API password and generating a SHA-512 Hash (Hex) of the string:
SHA-512 Hash Hex of [payment_transaction_unique_id][Your Merchant API password]
Notification signature examples
payment_transaction_unique_id | API password | signature |
---|---|---|
26aa150ee68b1b2d6758a0e6c44fce4c | 50fd87e65eb415f42fb5af4c9cf497662e00b785 | c5219b3d385e74496b2b48a549 |
3f760162ef57a829011e5e2379b3fa17 | 50fd87e65eb415f42fb5af4c9cf497662e00b785 | 14519d0db2f7f8f407efccc9b09 |
<?xml version="1.0" encoding="UTF-8"?>
<notification_echo>
<unique_id>3f760162ef57a829011e5e2379b3fa17</unique_id>
</notification_echo>
When receiving the notification, you are required to render an XML page containing the transaction’s payment transaction unique id so that the gateway knows that you have accepted the notification. If the XML is not delivered, the notification is sent periodically as per the rules for notifications delivery.
Advanced risk management with RiskParams
The risk params section in the payment transaction xml allows you to pass user specific values along with the payment transaction. These values may be used by advanced risk management features and checked against a blacklist.
RiskParams can be used in any user triggered payment transaction. User triggered transactions types are Authorize, Authorize3d, Sale, Sale3d, InitRecurringSale, InitRecurringSale3d, and AccountVerification.
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Sale');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('4200000000000000')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
// Risk Params
->setRiskSsn('987-65-4320')
->setRiskMacAddress('12-34-56-78-9A-BC')
->setRiskSessionId('1DA53551-5C60-498C-9C18-8456BDBA74A9')
->setRiskUserId('1002547')
->setRiskUserLevel('vip')
->setRiskEmail('test@example.com')
->setRiskPhone('+49301234567')
->setRiskRemoteIp('245.253.2.12');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.SaleRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
SaleRequest request = new SaleRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4200000000000000");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
// Risk Params
request.setRiskSsn("987-65-4320");
request.setRiskMacAddress("12-34-56-78-9A-BC");
request.setRiskSessionId("1DA53551-5C60-498C-9C18-8456BDBA74A9");
request.setRiskUserId("1002547");
request.setRiskUserLevel("vip");
request.setRiskEmail("test@example.com");
request.setRiskPhone("+49301234567");
request.setRiskRemoteIp("245.253.2.12");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.sale(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "4200000000000000",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"risk_params": {
"ssn": "987-65-4320",
"mac_address": "12-34-56-78-9A-BC",
"session_id": "1DA53551-5C60-498C-9C18-8456BDBA74A9",
"user_id": "1002547",
"user_level": "vip",
"email": "test@example.com",
"phone": "+49301234567",
"remote_ip": "245.253.2.12"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>sale</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4200000000000000</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<risk_params>
<ssn>987-65-4320</ssn>
<mac_address>12-34-56-78-9A-BC</mac_address>
<session_id>1DA53551-5C60-498C-9C18-8456BDBA74A9</session_id>
<user_id>1002547</user_id>
<user_level>vip</user_level>
<email>test@example.com</email>
<phone>+49301234567</phone>
<remote_ip>245.253.2.12</remote_ip>
</risk_params>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
risk_params | optional | ||
ssn | optional | string(128) | Social Security number or equivalent value for non US customers. |
mac_address | optional | string(128) | The customers mac address. |
session_id | optional | string(128) | The customers session_id. |
user_id | optional | string(128) | The customers user_id. |
user_level | optional | string(128) | A value describing the customers trust level, may be used by the risk management for configurable differentiated limits. |
optional | string(128) | The customers email. | |
phone | optional | string(128) | The customers phone. |
remote_ip | optional | string(128) | The customers ip address. |
serial_number | optional | string(128) | Custom serial number. |
pan_tail | optional | string(128) | The last 4 digits of the card number. |
bin | optional | string(128) | The first 6 digits of the card number. |
first_name | optional | string(128) | Customer first name. |
last_name | optional | string(128) | Customer last name. |
country | optional | string(128) | The country of the customer. |
pan | optional | string(128) | The PAN hash of the customer card number. |
forwarded_ip | optional | string(128) | MaxMind specific risk param. |
username | optional | string(128) | MaxMind specific risk param. |
password | optional | string(128) | MaxMind specific risk param. |
bin_name | optional | string(128) | MaxMind specific risk param. |
bin_phone | optional | string(128) | MaxMind specific risk param. |
required* = conditionally required
To use these values for risk management please contact our Risk team.
Credential On File (COF)
As the payment ecosystem has evolved, instances in which a transaction is initiated with a stored credential based on cardholder consent for future use have significantly increased. Growth in digital commerce, together with the emergence of new business models, has increased the number of transactions where a merchant or its agent, a payment facilitator (PF), or a staged digital wallet operator (SDWO) uses cardholder payment credentials (i.e., account details) that they previously stored for future purchases.
In Genesis, the COF indicator can be used for the following transaction types: Account Verification, Authorize, Authorize3D, Sale, Sale3D, InitRecurringSale, InitRecurringSale3D, Payout to mark a transaction as initial customer initiated, subsequent customer initiated or as unscheduled merchant initiated (UCOF).
The UCOF transaction uses a previously stored credential for a fixed or variable amount and it does not occur on a scheduled or regularly occurring transaction date. With it, the cardholder has provided consent to the merchant to initiate one or more future transactions. An example of such a transaction is an account auto-top up.
Supported options for Credential On File (COF) field:
COF | Description |
---|---|
initial_customer_initiated | Initial transaction used to store payment credentials for future customer initiated payments while processing. Required for external tokenization, and optional for gateway-based tokenization |
subsequent_customer_initiated | Subsequent customer initiated transaction using previously stored payment credentials. Required for external tokenization, and optional for gateway-based tokenization |
merchant_unscheduled | For UCOF transaction, the scheme transaction identifier of the initial transaction must be sent in the transaction request. For MasterCard or Maestro UCOF, the scheme settlement date in MMDD format (e.g. 0117) of the initial transaction must be sent in the transaction request. |
Currency and Amount Handling
The gateway handles all types of processing currencies, with exponents ranging from 0 (e.g. JPY), 2 (e.g. CNY, USD, EUR, GBP), to 3 (e.g. KWD). Processing currencies are configured on terminal level.
Transaction amounts on the API level should be submitted in the minor currency unit for the given currency, e.g.:
Amount currencies:
Name | Type | Description |
---|---|---|
USD | 100.33 | Should be submitted as 10033 in the amount API field (exponent 2) |
EUR | 3 | Should be submitted as 300 in the amount API field (exponent 2) |
JPY | 150 | Should be submitted as 150 in the amount API field (exponent 0) |
KWD | 100.333 | Should be submitted as 100333 in the amount API field (exponent 3) |
Amount limits: Amount has to be provided within limit for listed transaction types and currencies:
Transaction Type | Currency | minimum | maximum |
---|---|---|---|
Global limit | All | 0.01 | 1,000,000,000.00 |
alipay | CNY | 0.01 | 50,000.00 |
EUR | 0.01 | 6,529.00 | |
davivienda | USD | 0.01 | 3,000.00 |
banco de chile | USD | 0.01 | 3,000.00 |
webpay | USD | 0.01 | 3,000.00 |
pago facil | USD | 0.01 | 3,000.00 |
rapi pago | USD | 0.01 | 3,000.00 |
link | USD | 0.01 | 3,000.00 |
santander | USD | 0.01 | 3,000.00 |
aura | USD | 0.01 | 3,000.00 |
cabal | USD | 0.01 | 3,000.00 |
nativa | USD | 0.01 | 3,000.00 |
naranja | USD | 0.01 | 3,000.00 |
cencosud | USD | 0.01 | 3,000.00 |
tarjeta shopping | USD | 0.01 | 3,000.00 |
redpagos | USD | 0.01 | 3,000.00 |
bcmc | EUR | 1,00 | 1,000,000.00 |
elo | USD | 0.01 | 3,000.00 |
oxxo | USD | 0.01 | 3,000.00 |
bradesco | USD | 0.01 | 3,000.00 |
cartao mercado livre | USD | 0.01 | 3,000.00 |
efecty | USD | 0.01 | 3,000.00 |
boleto | USD | 2.50 | 2,500.00 |
itau | USD | 0.01 | 3,000.00 |
multibanco | USD | 0.01 | 99,999.99 |
banco do brasil | USD | 0.01 | 3,000.00 |
argencard | USD | 0.01 | 3,000.00 |
banco de occidente | USD | 0.01 | 3,000.00 |
bancomer | USD | 0.01 | 3,000.00 |
baloto | USD | 0.01 | 3,000.00 |
eps | EUR | 1.00 | 1,000,000.00 |
sofort | EUR | 1.00 | 5,000.00 |
sdd sale | All | 0.10 | 24,999.99 |
sct payout | All | 0.10 | 24,999.99 |
sdd init recurring sale | All | 0.10 | 24,999.99 |
sdd refund | All | 0.10 | 24,999.99 |
neosurf | All | 0.01 | 9,999.99 |
p24 | EUR | 0.01 | 15,000.00 |
rpn payment | All | 0.10 | 100,000.00 |
rpn payout | All | 100.00 | 1,000,000.00 |
citadel payin | EUR | 0.01 | 10,000.00 |
citadel payout | EUR | 0.01 | 10,000.00 |
idebit payin | CAD | 0.01 | 1,500.00 |
idebit payout | CAD | 0.01 | 1,500.00 |
online banking | CNY* | 10.00 | 50,000.00 |
THB | 10.00 | 500,000.00 | |
IDR | 10,000.00 | 50,000,000.00 | |
MYR | 10.00 | 20,000.00 | |
bank payout | CNY | 60.00 | 49,000.00 |
THB | 350.00 | 175,000.00 | |
IDR | 50,000.00 | 25,000,000.00 | |
MYR | 50.00 | 20,000.00 | |
All | 10.00 | 3,000.00 | |
ezeecard payout | EUR | 10.00 | 800.00 |
paysafecard | EUR | 0.01 | 1,000.00 |
poli | AUD | 0.01 | 9,999.00 |
insta debit payin | CAD | 0.01 | 1,500.00 |
bitpay | USD | 1.00 | 950,000.00 |
bitpay sale | USD | 1.00 | 950,000.00 |
bitpay payout | USD | 1.00 | 950,000.00 |
pse | USD | 0.01 | 3,000.00 |
* = Depends on the setup
Check the ISO 4217 standard for details on currencies and their exponents/minor currency units.
Dynamic Descriptor
Dynamic descriptor functionality is available as part of the gateway. It is enabled on terminal level, so contact the IT Support team at tech-support@emerchantpay.com if you wish to use it.
Currently, the transactions types that support dynamic descriptor parameters are Authorize, Authorize3d, Sale, Sale3d, InitRecurringSale, InitRecurringSale3d and Payout.
WPF payments also support dynamic descriptor.
The currently supported dynamic descriptor parameters are:
Name | Type | Description |
---|---|---|
merchant_name | string(25) | Needed by merchants/PSPs to change the charge description. |
merchant_city | string(13) | Contains the city of the merchant or the merchant phone number for CNP merchants. For master or Intl Maestro%, send the phone number in 'merchant_service_phone' field. |
merchant_country | string(3) | Country code of the merchant country in ISO 3166 format. |
merchant_state | string(3) | The value should be the merchant country subdivision code defined in ISO 3166-2. Invalid values submitted NOT as per the ISO might lead to data integrity issues. |
merchant_zip_code | string(10) | Merchant zip/postal code. Required for VISA OCT transactions with Australian and Canadian card bins. |
merchant_address | string(48) | Merchant address. |
merchant_url | string(60) | Merchant url. |
merchant_phone | string(16) | Merchant phone. |
merchant_service_city | string(13) | Merchant service city. |
merchant_service_country | string(3) | Country code of the merchant service country in ISO 3166 format. |
merchant_service_state | string(3) | The value should be the merchant service country subdivision code defined in ISO 3166-2. Invalid values submitted NOT as per the ISO might lead to data integrity issues. |
merchant_service_zip_code | string(10) | Merchant service zip/postal code. |
merchant_service_phone | string(16) | Merchant service phone. |
sub_merchant_id | string(15) | Sub-merchant ID assigned by the Payment Facilitator. |
merchant_geo_coordinates | string(20) | Merchant service geographic coordinates. Length of geographic coordinates is a range of 15-20 symbols. Latitude and Longitude separated by a comma. Example: 40.73061,-73.93524 |
merchant_service_geo_coordinates | string(20) | Merchant service geographic coordinates. Length of geographic coordinates is a range of 15-20 symbols. Latitude and Longitude separated by a comma. Example: 40.73061,-73.93524 |
If the terminal is configured with dynamic descriptor, but the merchant does not send the dynamic descriptor parameter in question at all or sends whitespace, this defaults the given dynamic descriptor parameter to the static descriptor configured on MID level when submitted to the schemes.
If the value is less than max chars, it is right padded with whitespace before sent to the schemes. Note also that the dynamic descriptor params section with the properly formatted individual dynamic descriptor params is returned in the payment transaction response on the API if those params have been submitted in the transaction API request beforehand.
Regarding reference-based transactions, since they do not accept any dynamic descriptor params in the request, there is no dynamic descriptor params section in the response as well. Reference-based transactions reuse the dynamic descriptor params of their original transaction.
The sub-merchant ID should be provided by all merchants that are processing under Payment Facilitator. If the terminal does not support dynamic descriptor, a static value can be configured on a merchant level.
Electronic Commerce Indicator
Electronic Commerce Indicator (ECI) is a value that is returned from the Directory Server (Visa, MasterCard, etc.) to indicate the authentication results of your customer’s credit card payment on 3D Secure.
Visa/JCB/Diners/American Express/Rupay
ECI Code | Description |
---|---|
05 | Both cardholder and card issuing bank are 3D enabled. 3D card authentication is successful |
06 | Either cardholder or card issuing bank is not 3D enrolled. 3D card authentication is unsuccessful, in sample situations as: 1. 3D cardholder not enrolled 2. Card issuing bank is not 3D Secure ready |
07 | Authentication is unsuccessful or not attempted. The credit card is either a non-3D card or card issuing bank does not handle it as a 3D transaction |
MasterCard/Maestro
ECI Code | Description |
---|---|
02 | Both cardholder and card issuing bank are 3D enabled. 3D card authentication is successful |
01 | Either cardholder or card issuing bank is not 3D enrolled. 3D card authentication is unsuccessful, in sample situations as: 1. 3D Cardholder not enrolled 2. Card issuing bank is not 3D Secure ready |
00 (or empty) | Authentication is unsuccessful or not attempted. The credit card is either a non-3D card or card issuing bank does not handle it as a 3D transaction |
Scheme Response Codes
See below a list of Scheme response codes with the corresponding messages. Scheme response codes (scheme response code element) are different than the regular gateway codes (code element and response code element) - the scheme response code maps to the code returned by the schemes while the response code and code elements are acquirer or gateway internal code mapping and part of the API, as described in the Errors section. Transaction responses will return the relevant scheme response code (note that both scheme response code and authorization code are optional in the API responses and will be returned only if provided)
Visa
Code | Description |
---|---|
00 | Approved or completed successfully |
01 | Refer to card issuer |
02 | Refer to card issuer, special condition |
03 | Invalid merchant |
04 | Pickup card (no fraud) |
05 | Do not honour |
06 | Error |
07 | Pick up card, special condition (fraud account) |
10 | Partial Approval |
11 | Approved (V.I.P) |
12 | Invalid transaction |
13 | Invalid amount or currency conversion field overflow |
14 | Invalid account number (no such number) |
15 | No such issuer |
19 | Re-enter transaction |
21 | No action taken |
25 | Unable to locate record in file |
28 | File temporarily not available for update or unquiry |
39 | No credit account |
41 | Lost card, pick up (fraud account) |
43 | Stolen card, pick up (fraud account) |
46 | Closed account |
51 | Not sufficient funds |
52 | No checking account |
53 | No savings account |
54 | Expired card or expiration date is missing |
55 | Incorrect PIN or PIN missing |
57 | Transaction not permitted to cardholder |
58 | Transaction not allowed at terminal |
59 | Suspected fraud |
61 | Exceeds approval amount limit |
62 | Restricted card (card invalid in this region or country) |
63 | Security violation (source is not correct issuer) |
64 | Transaction does not fulfil AML requirement |
65 | Exceeds withdrawal frequency limit |
70 | PIN data required |
74 | Different value than that used for PIN encryption errors |
75 | Allowable number of PIN entry tries exceeded |
76 | Unsolicited reversal |
78 | “Blocked, first used”—Transaction from new cardholder, and card not properly unblocked |
79 | Already reversed (by Switch) |
80 | No financial impact |
81 | Cryptographic error found in PIN |
82 | Negative CAM, dCVV, iCVV, or CVV results |
85 | No reason to decline a request for address verification, CVV2 verification, or a credit voucher or merchandise return |
86 | Cannot verify PIN; for example, no PVV |
89 | Ineligible to receive financial position information (GIV) |
91 | Issuer or switch inoperative and STIP not applicable or not available for this transaction; Time-out when no stand-in; POS Check Service: Destination unavailable; Credit Voucher and Merchandise Return Authorizations: V.I.P. sent the transaction to the issuer, but the issuer was unavailable. |
92 | Financial institution or intermediate network facility cannot be found for routing (receiving institution ID is invalid) |
93 | Transaction cannot be completed - violation of law |
96 | System malfunction |
1A | Additional customer authentication required. Soft decline. |
6P | Verification data failed |
B1 | Surcharge amount not permitted on Visa cards or EBT food stamps (U.S. acquirers only) |
B2 | Surcharge amount not supported by debit network issuer. |
N0 | Force STIP |
N3 | Cash service not available |
N4 | Cash request exceeds issuer or approved limit |
N5 | Ineligible for resubmission |
N7 | Decline for CVV2 failure |
N8 | Transaction amount exceeds preauthorized approval amount |
P5 | Denied PIN unblock—PIN change or unblock request declined by issuer |
P6 | Denied PIN change—requested PIN unsafe |
Q1 | Card Authentication failed |
R0 | Stop Payment Order |
R1 | Revocation of authorisation order |
R2 | Transaction does not qualify for Visa PIN |
R3 | Revocation of all authorizations order |
Z3 | Unable to go online; offline-declined |
Mastercard and Maestro
ISO Code | Description |
---|---|
00 | Approved or completed successfully |
01 | Refer to card issuer |
03 | Invalid merchant |
04 | Capture card |
05 | Do not honour |
08 | Honour with ID |
10 | Partial Approval |
12 | Invalid transaction |
13 | Invalid amount |
14 | Invalid card number |
15 | Invalid issuer |
30 | Format error |
41 | Lost card |
43 | Stolen card |
51 | Insufficient funds/over credit limit |
54 | Expired card |
55 | Invalid PIN |
57 | Transaction not permitted to issuer/cardholder |
58 | Transaction not allowed at acquirer/terminal |
61 | Exceeds withdrawal amount limit |
62 | Restricted card |
63 | Security violation |
65 | Exceeds withdrawal count limit OR Identity Check Soft-Decline of EMV 3DS Authentication (merchant should Resubmit authentication with 3DS) |
70 | Contact Card Issuer |
71 | PIN Not Changed |
75 | Allowable number of PIN tries exceeded |
76 | Invalid/nonexistent “To Account” specified |
77 | Invalid/nonexistent “From Account” specified |
78 | Invalid/nonexistent account specified (general) |
79 | Life cycle (Mastercard use only) |
80 | System not available |
81 | Domestic Debit Transaction Not Allowed (Regional use only) |
82 | Policy (Mastercard use only) |
83 | Fraud/Security (Mastercard use only) |
84 | Invalid Authorization Life Cycle |
85 | Not declined |
86 | PIN Validation not possible |
87 | Purchase Amount Only, No Cash Back Allowed |
88 | Cryptographic failure |
89 | Unacceptable PIN—Transaction Declined—Retry |
90 | Cutoff is in progress |
91 | Authorization System or issuer system inoperative |
92 | Unable to route transaction |
94 | Duplication transaction detected |
96 | System error |
1Z | Authorization System or issuer system inoperative |
Scheme Account Number Indicator Codes
The table below lists the possible Account Number Indicator (ANI) codes returned by MasterCard for scheme-tokenized transactions like Apple Pay, Google Pay, and Tokenized e-commerce via the Processing and the Web Payment Form APIs. The code is provided in the scheme_pan_indicator
attribute and indicates the type of PAN associated with the token. The Account Number Indicator is returned together with the scheme_pan_tail
attribute.
Account Number Indicator | Description |
---|---|
C | MasterCard Digital Enablement Service Secure Element Token |
E | Embossed Account Number Provided by Issuer |
F | MasterCard Digital Enablement Service Card on File Token |
H | MasterCard Digital Enablement Service Cloud-based Payments Token |
L | Pay with Rewards Loyalty Program Operator [LPO] Card |
M | Primary Account Number |
P | Contactless Account Number |
R | Pay with Rewards Card |
V | Virtual Card Number |
Manually Reviewed Transactions
Under certain conditions, transactions can be stopped for manual review by the Risk team. This happens when the appropriate risk rules have been enabled for the merchant in question. Feel free to discuss enabling of manual reviews for transactions with our Risk team. Transactions that are stopped for manual review are returned with status ’pending review’ in the API response, together with a detailed message specifying a manual review of this transaction. Note that transactions will be manually reviewed by the Risk team in the next 24 hours. In the process, each transaction will be manually approved or manually declined, and at this point the merchant will receive a notification with the status of the transaction, see Notifications.
Special case for manual reviewing is when the transaction is 3D async, in this case the merchant receives one notification if the transaction is manually declined by the Risk team, and two notifications if the transaction is manually approved. On manual approval, the first notification is sent once the transaction is manually approved and is sent for enrollment check to the MPI provider - the notification will contain status pending asyc together with the redirect url where the consumer needs to be redirected to by the merchant. The second notification is the standard 3D notification, once a consumer has been redirected to the given redirect url, has entered his/her MPI password, and contains the final status of the transaction whether it is approved by the issuer, or declined for invalid 3D password, and so on
The format of the first notification for manual review and following approval is:
?transaction_id=82803B4C-70CC-43BD-8B21-FD0395285B40
&unique_id=44177a21403427eb96664a6d7e5d5d48
&transaction_type=sale3d
&terminal_token=394f2ebc3646d3c017fa1e1cbc4a1e20
&status=pending_async
&amount=500
&signature=088e16a1019277b15d58faf0541e11910eb756f6
&eci=06
&redirect_url=http://example.com/redirect_url
The second notification is the same as the typical 3D notifications for final statuses after the consumer has performed the 3D workflow.
Partial Approvals
Credit cards that do not have sufficient funds in their account for the full purchase amount may be provided with a partial approval response from the issuer. When a partial approval happens, there will be a flag confirming the partial approval in the response (partial approval set to ’true’) and the amount field in the response will contain the actual partially approved amount instead of the requested one in the API request. The cardholder can then choose to use a supplemental payment method to pay the balance and complete the purchase, if so desired. Merchants that accept partial approvals should note that issuers may return a partial approval response on a pre-paid/debit card at any time, and issuers may also respond with a partial approval response amount that is equal to the requested amount.
Have in mind that full/partial refunds or captures need to reference the partially approved initial transaction, you will get a workflow error if trying to capture or refund more than the partially approved amount. So make sure you check for the partial approval flag in the API response for the relevant transaction types, and handle follow-up transaction amounts properly.
With 3-D secure transactions, if a partial approval happened, the partially approved amount will be returned in the async API notification to the merchant. This is because actual communication with the acquirers happen after 3D authentication by the cardholder, in the initial API response the merchant will get the requested amount with the status ’pending async’ for the transaction.
Note that partial approval support is disabled by default, feel free to contact our Risk team to enable it.
Preauthorizations
Preauthorizations are used to request Approval for an estimated transaction amount because the final transaction amount will only be known some time later. This type of message is typically sent for transactions such as car rentals, hotel rooms and petrol. The reason for the preauthorization is to authenticate the card and the cardholder and also to check funds availability.
They are similar to the final authorizations, but have longer authorize time-frame and allow amount to be extended (restricted per card brand).
Basic Workflow
Preauthorization
Preauthorization transaction can be submitted via normal Authorize or Authorize3d transaction with additional request param preauthorization.
To enable this, please contact tech-support@emerchantpay.com.
Supported Card brands
Visa
Visa Lodging Preauthorization Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Authorize');
$request = $genesis->request();
$request
->setTransactionId('TrxID_5a801bfd4c1bf815c4a6b62548699333')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('5000')
->setCurrency('USD')
->setPreauthorization('true')
->setCardHolder('Travis Pastrana')
->setCardNumber('4200000000000000')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.AuthorizeRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
AuthorizeRequest request = new AuthorizeRequest();
request.setTransactionId("TrxID_5a801bfd4c1bf815c4a6b62548699333");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(5000));
request.setCurrency("USD");
request.setPreauthorization("true");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4200000000000000");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.authorize(
{
"transaction_id": "TrxID_5a801bfd4c1bf815c4a6b62548699333",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": 5000,
"currency": "USD",
"preauthorization": true,
"card_holder": "Travis Pastrana",
"card_number": "4200000000000000",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>authorize</transaction_type>
<transaction_id>TrxID_5a801bfd4c1bf815c4a6b62548699333</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>5000</amount>
<currency>USD</currency>
<preauthorization>true</preauthorization>
<card_holder>Travis Pastrana</card_holder>
<card_number>4200000000000000</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
</payment_transaction>'
Successful Response
stdClass Object
(
[transaction_type] => authorize
[status] => approved
[mode] => live
[transaction_id] => TrxID_5a801bfd4c1bf815c4a6b62548699333
[unique_id] => 1cb26fd5b9991d84471cc741b73b0950
[avs_response_code] => 5I
[avs_response_text] => Response provided by issuer processor; Address information not verified
[cvv_result_code] => M
[authorization_code] => 964779
[response_code] => 00
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:59.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 5000
[currency] => USD
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[authorize]>
<status content=[approved]>
<mode content=[live]>
<transaction_id content=[TrxID_5a801bfd4c1bf815c4a6b62548699333]>
<unique_id content=[1cb26fd5b9991d84471cc741b73b0950]>
<avs_response_code content=[5I]>
<avs_response_text content=[Response provided by issuer processor; Address information not verified]>
<cvv_result_code content=[M]>
<authorization_code content=[964779]>
<response_code content=[00]>
<timestamp content=[2025-01-16T10:23:59Z]>
<descriptor content=[Descriptor one]>
<amount content=[5000]>
<currency content=[USD]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "authorize",
status: "approved",
mode: "live",
transaction_id: "TrxID_5a801bfd4c1bf815c4a6b62548699333",
unique_id: "1cb26fd5b9991d84471cc741b73b0950",
avs_response_code: "5I",
avs_response_text: "Response provided by issuer processor; Address information not verified",
cvv_result_code: "M",
authorization_code: "964779",
response_code: "00",
timestamp: "2025-01-16T10:23:59Z",
descriptor: "Descriptor one",
amount: "5000",
currency: "USD",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>authorize</transaction_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>TrxID_5a801bfd4c1bf815c4a6b62548699333</transaction_id>
<unique_id>1cb26fd5b9991d84471cc741b73b0950</unique_id>
<avs_response_code>5I</avs_response_code>
<avs_response_text>Response provided by issuer processor; Address information not verified</avs_response_text>
<cvv_result_code>M</cvv_result_code>
<authorization_code>964779</authorization_code>
<response_code>00</response_code>
<timestamp>2025-01-16T10:23:59Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>5000</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Reconcile Visa Preauthorization Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('NonFinancial\Reconcile\Transaction');
$request = $genesis->request();
$request
->setUniqueId('1cb26fd5b9991d84471cc741b73b0950');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.nonfinancial.reconcile.ReconcileRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
ReconcileRequest request = new ReconcileRequest();
request.setUniqueId("1cb26fd5b9991d84471cc741b73b0950");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.reconcile(
{
"unique_id": "1cb26fd5b9991d84471cc741b73b0950"
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/reconcile/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<reconcile>
<unique_id>1cb26fd5b9991d84471cc741b73b0950</unique_id>
</reconcile>'
Successful Preauthorization Reconciliation Response
stdClass Object
(
[transaction_type] => authorize
[status] => approved
[authorization_code] => 964779
[retrieval_reference_number] => 016813015184
[payment_account_reference] => Q1HJZ28RKA1EBL470G9XYG90R5D3E
[response_code] => 00
[unique_id] => 1cb26fd5b9991d84471cc741b73b0950
[transaction_id] => TrxID_5a801bfd4c1bf815c4a6b62548699333
[mode] => live
[timestamp] => 2025-01-16T10:23:59Z
[descriptor] => Descriptor one
[amount] => 5000
[currency] => USD
[card_brand] => visa
[card_number] => 420000...0000
[card_type] => CREDIT
[card_subtype] => CARD SUBTYPE
[card_issuing_bank] => Issuing Bank
[card_issuing_country] => Exact Issuing country
[bank_account_number] => Bank Account Number
[bank_identifier_code] => Bank Identifier Code
[sent_to_acquirer] => true
[arn] => 74537605259536043849425
[scheme_response_code] => 00
[scheme_transaction_link_id] => TLINKIDENTIFIER4521412
[scheme_max_settlement_date] => 2024-07-31
[scheme_authentication_data_quality] => true
[threeds] =>
[preauthorization] => true
[preauthorization_expires_at] => 2025-02-16T10:23:59Z
[preauthorization_total_amount] => 5000
[capturable_amount] => 5750
[captured_amount] => 0
[reversed_amount] => 0
[reversible_amount] => 5000
)
<payment_response content=[
<transaction_type content=[authorize]>
<status content=[approved]>
<authorization_code content=[964779]>
<retrieval_reference_number content=[016813015184]>
<payment_account_reference content=[Q1HJZ28RKA1EBL470G9XYG90R5D3E]>
<response_code content=[00]>
<unique_id content=[1cb26fd5b9991d84471cc741b73b0950]>
<transaction_id content=[TrxID_5a801bfd4c1bf815c4a6b62548699333]>
<mode content=[live]>
<timestamp content=[2025-01-16T10:23:59Z]>
<descriptor content=[Descriptor one]>
<amount content=[5000]>
<currency content=[USD]>
<card_brand content=[visa]>
<card_number content=[420000...0000]>
<card_type content=[CREDIT]>
<card_subtype content=[CARD SUBTYPE]>
<card_issuing_bank content=[Issuing Bank]>
<card_issuing_country content=[Exact Issuing country]>
<bank_account_number content=[Bank Account Number]>
<bank_identifier_code content=[Bank Identifier Code]>
<sent_to_acquirer content=[true]>
<arn content=[74537605259536043849425]>
<scheme_response_code content=[00]>
<scheme_transaction_link_id content=[TLINKIDENTIFIER4521412]>
<scheme_max_settlement_date content=[2024-07-31]>
<scheme_authentication_data_quality content=[true]>
<threeds content=[]>
<preauthorization content=[true]>
<preauthorization_expires_at content=[2025-02-16T10:23:59Z]>
<preauthorization_total_amount content=[5000]>
<capturable_amount content=[5750]>
<captured_amount content=[0]>
<reversed_amount content=[0]>
<reversible_amount content=[5000]>
]>
{
transaction_type: "authorize",
status: "approved",
authorization_code: "964779",
retrieval_reference_number: "016813015184",
payment_account_reference: "Q1HJZ28RKA1EBL470G9XYG90R5D3E",
response_code: "00",
unique_id: "1cb26fd5b9991d84471cc741b73b0950",
transaction_id: "TrxID_5a801bfd4c1bf815c4a6b62548699333",
mode: "live",
timestamp: "2025-01-16T10:23:59Z",
descriptor: "Descriptor one",
amount: "5000",
currency: "USD",
card_brand: "visa",
card_number: "420000...0000",
card_type: "CREDIT",
card_subtype: "CARD SUBTYPE",
card_issuing_bank: "Issuing Bank",
card_issuing_country: "Exact Issuing country",
bank_account_number: "Bank Account Number",
bank_identifier_code: "Bank Identifier Code",
sent_to_acquirer: "true",
arn: "74537605259536043849425",
scheme_response_code: "00",
scheme_transaction_link_id: "TLINKIDENTIFIER4521412",
scheme_max_settlement_date: "2024-07-31",
scheme_authentication_data_quality: "true",
threeds: "",
preauthorization: "true",
preauthorization_expires_at: "2025-02-16T10:23:59Z",
preauthorization_total_amount: "5000",
capturable_amount: "5750",
captured_amount: "0",
reversed_amount: "0",
reversible_amount: "5000",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>authorize</transaction_type>
<status>approved</status>
<authorization_code>964779</authorization_code>
<retrieval_reference_number>016813015184</retrieval_reference_number>
<payment_account_reference>Q1HJZ28RKA1EBL470G9XYG90R5D3E</payment_account_reference>
<response_code>00</response_code>
<unique_id>1cb26fd5b9991d84471cc741b73b0950</unique_id>
<transaction_id>TrxID_5a801bfd4c1bf815c4a6b62548699333</transaction_id>
<mode>live</mode>
<timestamp>2025-01-16T10:23:59Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>5000</amount>
<currency>USD</currency>
<card_brand>visa</card_brand>
<card_number>420000...0000</card_number>
<card_type>CREDIT</card_type>
<card_subtype>CARD SUBTYPE</card_subtype>
<card_issuing_bank>Issuing Bank</card_issuing_bank>
<card_issuing_country>Exact Issuing country</card_issuing_country>
<bank_account_number>Bank Account Number</bank_account_number>
<bank_identifier_code>Bank Identifier Code</bank_identifier_code>
<sent_to_acquirer>true</sent_to_acquirer>
<arn>74537605259536043849425</arn>
<scheme_response_code>00</scheme_response_code>
<scheme_transaction_link_id>TLINKIDENTIFIER4521412</scheme_transaction_link_id>
<scheme_max_settlement_date>2024-07-31</scheme_max_settlement_date>
<scheme_authentication_data_quality>true</scheme_authentication_data_quality>
<payment_response>threeds</payment_response>
<preauthorization>true</preauthorization>
<preauthorization_expires_at>2025-02-16T10:23:59Z</preauthorization_expires_at>
<preauthorization_total_amount>5000</preauthorization_total_amount>
<capturable_amount>5750</capturable_amount>
<captured_amount>0</captured_amount>
<reversed_amount>0</reversed_amount>
<reversible_amount>5000</reversible_amount>
</payment_response>
- MCC Restriction - NO
- Authorization timeframe - 7 days (depends on the MCC and merchant region)
- Authorize timeframe extension - not supported
- Capture tolerance - percent or amount. Navigate to the Capture section to learn more.
MCC | Segment | Authorization timeframe | Amount tolerance |
---|---|---|---|
3501-3999, 7011 | Lodging | 31 days | 15% |
3351-3500, 7512 | Car Rental | 31 days | 15% |
4411 | Steamship and Cruise Lines | 31 days | 15% |
7513 | Truck Rentals | 7 days | 15% |
7033 | Trailer Parks and Campgrounds | 7 days | 15% |
7519 | Motor Home and Recreational Vehicle Rentals | 7 days | 15% |
5552 | Electric Vehicle Charging | 7 days | 15% |
7523 | Parking and Garages | 7 days | 15% |
7394 | Equipment, Tool, Furniture and Appliance Rental | 7 days | none |
7999 | Recreation Services | 7 days | none |
7996 | Amusement Parks, Carnivals, Circuses, Fortune Tellers | 7 days | none |
5599 | Miscellaneous Automotive, Aircraft, and Farm Equipment Dealers | 7 days | none |
4457 | Boat Rentals and Leasing | 7 days | none |
5571 | Motorcycle Shops and Dealers | 7 days | none |
4111 | Local and Suburban Commuter, Passenger Transportation, including Ferries | 7 days1 | 25 USD3 |
4112 | Passenger Railways | 7 days1 | 25 USD3 |
4131 | Bus Lines | 7 days1 | 25 USD3 |
5812 | Eating Places and Restaurants | end of approval day2 | 20% |
5813 | Drinking Places, Bars, Taverns, Cocktail Lounges, Nightclubs, Discotheques | end of approval day2 | 20% |
4121 | Taxicabs and Limousines (Card-Absent Environment only) | end of approval day2 | 20% |
7 days1 - 7 days (3 days for US merchant region)
end of approval day2 - end of approval day (in the acquirer's timezone)
25 USD3 - a capture with amount up to 25 USD can be requested without a need of additional incremental authorization. Just in case the authorized amount is less than 25 USD (15 USD for merchants in the US region). The respective amount will be exchanged to the transaction currency in case the currency is different than USD.
Mastercard
Master Lodging Preauthorization Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Authorize');
$request = $genesis->request();
$request
->setTransactionId('TrxID_42ea99c7a52b285b3510132445877b55')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('5000')
->setCurrency('USD')
->setPreauthorization('true')
->setCardHolder('Travis Pastrana')
->setCardNumber('5555555555554444')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.AuthorizeRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
AuthorizeRequest request = new AuthorizeRequest();
request.setTransactionId("TrxID_42ea99c7a52b285b3510132445877b55");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(5000));
request.setCurrency("USD");
request.setPreauthorization("true");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("5555555555554444");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.authorize(
{
"transaction_id": "TrxID_42ea99c7a52b285b3510132445877b55",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": 5000,
"currency": "USD",
"preauthorization": true,
"card_holder": "Travis Pastrana",
"card_number": "5555555555554444",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>authorize</transaction_type>
<transaction_id>TrxID_42ea99c7a52b285b3510132445877b55</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>5000</amount>
<currency>USD</currency>
<preauthorization>true</preauthorization>
<card_holder>Travis Pastrana</card_holder>
<card_number>5555555555554444</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
</payment_transaction>'
Successful Response
stdClass Object
(
[transaction_type] => authorize
[status] => approved
[mode] => live
[transaction_id] => TrxID_42ea99c7a52b285b3510132445877b55
[unique_id] => af25a3a9d06b42f553dedcde2ba8a2bb
[avs_response_code] => 5I
[avs_response_text] => Response provided by issuer processor; Address information not verified
[cvv_result_code] => M
[authorization_code] => 117972
[response_code] => 00
[timestamp] => DateTime Object
(
[date] => 2025-01-15 10:23:59.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 5000
[currency] => USD
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[authorize]>
<status content=[approved]>
<mode content=[live]>
<transaction_id content=[TrxID_42ea99c7a52b285b3510132445877b55]>
<unique_id content=[af25a3a9d06b42f553dedcde2ba8a2bb]>
<avs_response_code content=[5I]>
<avs_response_text content=[Response provided by issuer processor; Address information not verified]>
<cvv_result_code content=[M]>
<authorization_code content=[117972]>
<response_code content=[00]>
<timestamp content=[2025-01-15T10:23:59Z]>
<descriptor content=[Descriptor one]>
<amount content=[5000]>
<currency content=[USD]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "authorize",
status: "approved",
mode: "live",
transaction_id: "TrxID_42ea99c7a52b285b3510132445877b55",
unique_id: "af25a3a9d06b42f553dedcde2ba8a2bb",
avs_response_code: "5I",
avs_response_text: "Response provided by issuer processor; Address information not verified",
cvv_result_code: "M",
authorization_code: "117972",
response_code: "00",
timestamp: "2025-01-15T10:23:59Z",
descriptor: "Descriptor one",
amount: "5000",
currency: "USD",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>authorize</transaction_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>TrxID_42ea99c7a52b285b3510132445877b55</transaction_id>
<unique_id>af25a3a9d06b42f553dedcde2ba8a2bb</unique_id>
<avs_response_code>5I</avs_response_code>
<avs_response_text>Response provided by issuer processor; Address information not verified</avs_response_text>
<cvv_result_code>M</cvv_result_code>
<authorization_code>117972</authorization_code>
<response_code>00</response_code>
<timestamp>2025-01-15T10:23:59Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>5000</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Reconcile Master Preauthorization Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('NonFinancial\Reconcile\Transaction');
$request = $genesis->request();
$request
->setUniqueId('af25a3a9d06b42f553dedcde2ba8a2bb');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.nonfinancial.reconcile.ReconcileRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
ReconcileRequest request = new ReconcileRequest();
request.setUniqueId("af25a3a9d06b42f553dedcde2ba8a2bb");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.reconcile(
{
"unique_id": "af25a3a9d06b42f553dedcde2ba8a2bb"
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/reconcile/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<reconcile>
<unique_id>af25a3a9d06b42f553dedcde2ba8a2bb</unique_id>
</reconcile>'
Successful Preauthorization Reconciliation Response
stdClass Object
(
[transaction_type] => authorize
[status] => approved
[authorization_code] => 117972
[retrieval_reference_number] => 016813015184
[payment_account_reference] => Q1HJZ28RKA1EBL470G9XYG90R5D3E
[response_code] => 00
[unique_id] => af25a3a9d06b42f553dedcde2ba8a2bb
[transaction_id] => TrxID_42ea99c7a52b285b3510132445877b55
[mode] => live
[timestamp] => 2025-01-15T10:23:59Z
[descriptor] => Descriptor one
[amount] => 5000
[currency] => USD
[card_brand] => master
[card_number] => 555555...4444
[card_type] => CREDIT
[card_subtype] => CARD SUBTYPE
[card_issuing_bank] => Issuing Bank
[card_issuing_country] => Exact Issuing country
[bank_account_number] => Bank Account Number
[bank_identifier_code] => Bank Identifier Code
[sent_to_acquirer] => true
[arn] => 74537605259536043849425
[scheme_response_code] => 00
[scheme_transaction_link_id] => TLINKIDENTIFIER4521412
[scheme_max_settlement_date] => 2024-07-31
[scheme_authentication_data_quality] => true
[threeds] =>
[preauthorization] => true
[preauthorization_expires_at] => 2025-02-14T10:23:59Z
[preauthorization_total_amount] => 5000
[capturable_amount] => 5000
[captured_amount] => 0
[reversed_amount] => 0
[reversible_amount] => 5000
)
<payment_response content=[
<transaction_type content=[authorize]>
<status content=[approved]>
<authorization_code content=[117972]>
<retrieval_reference_number content=[016813015184]>
<payment_account_reference content=[Q1HJZ28RKA1EBL470G9XYG90R5D3E]>
<response_code content=[00]>
<unique_id content=[af25a3a9d06b42f553dedcde2ba8a2bb]>
<transaction_id content=[TrxID_42ea99c7a52b285b3510132445877b55]>
<mode content=[live]>
<timestamp content=[2025-01-15T10:23:59Z]>
<descriptor content=[Descriptor one]>
<amount content=[5000]>
<currency content=[USD]>
<card_brand content=[master]>
<card_number content=[555555...4444]>
<card_type content=[CREDIT]>
<card_subtype content=[CARD SUBTYPE]>
<card_issuing_bank content=[Issuing Bank]>
<card_issuing_country content=[Exact Issuing country]>
<bank_account_number content=[Bank Account Number]>
<bank_identifier_code content=[Bank Identifier Code]>
<sent_to_acquirer content=[true]>
<arn content=[74537605259536043849425]>
<scheme_response_code content=[00]>
<scheme_transaction_link_id content=[TLINKIDENTIFIER4521412]>
<scheme_max_settlement_date content=[2024-07-31]>
<scheme_authentication_data_quality content=[true]>
<threeds content=[]>
<preauthorization content=[true]>
<preauthorization_expires_at content=[2025-02-14T10:23:59Z]>
<preauthorization_total_amount content=[5000]>
<capturable_amount content=[5000]>
<captured_amount content=[0]>
<reversed_amount content=[0]>
<reversible_amount content=[5000]>
]>
{
transaction_type: "authorize",
status: "approved",
authorization_code: "117972",
retrieval_reference_number: "016813015184",
payment_account_reference: "Q1HJZ28RKA1EBL470G9XYG90R5D3E",
response_code: "00",
unique_id: "af25a3a9d06b42f553dedcde2ba8a2bb",
transaction_id: "TrxID_42ea99c7a52b285b3510132445877b55",
mode: "live",
timestamp: "2025-01-15T10:23:59Z",
descriptor: "Descriptor one",
amount: "5000",
currency: "USD",
card_brand: "master",
card_number: "555555...4444",
card_type: "CREDIT",
card_subtype: "CARD SUBTYPE",
card_issuing_bank: "Issuing Bank",
card_issuing_country: "Exact Issuing country",
bank_account_number: "Bank Account Number",
bank_identifier_code: "Bank Identifier Code",
sent_to_acquirer: "true",
arn: "74537605259536043849425",
scheme_response_code: "00",
scheme_transaction_link_id: "TLINKIDENTIFIER4521412",
scheme_max_settlement_date: "2024-07-31",
scheme_authentication_data_quality: "true",
threeds: "",
preauthorization: "true",
preauthorization_expires_at: "2025-02-14T10:23:59Z",
preauthorization_total_amount: "5000",
capturable_amount: "5000",
captured_amount: "0",
reversed_amount: "0",
reversible_amount: "5000",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>authorize</transaction_type>
<status>approved</status>
<authorization_code>117972</authorization_code>
<retrieval_reference_number>016813015184</retrieval_reference_number>
<payment_account_reference>Q1HJZ28RKA1EBL470G9XYG90R5D3E</payment_account_reference>
<response_code>00</response_code>
<unique_id>af25a3a9d06b42f553dedcde2ba8a2bb</unique_id>
<transaction_id>TrxID_42ea99c7a52b285b3510132445877b55</transaction_id>
<mode>live</mode>
<timestamp>2025-01-15T10:23:59Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>5000</amount>
<currency>USD</currency>
<card_brand>master</card_brand>
<card_number>555555...4444</card_number>
<card_type>CREDIT</card_type>
<card_subtype>CARD SUBTYPE</card_subtype>
<card_issuing_bank>Issuing Bank</card_issuing_bank>
<card_issuing_country>Exact Issuing country</card_issuing_country>
<bank_account_number>Bank Account Number</bank_account_number>
<bank_identifier_code>Bank Identifier Code</bank_identifier_code>
<sent_to_acquirer>true</sent_to_acquirer>
<arn>74537605259536043849425</arn>
<scheme_response_code>00</scheme_response_code>
<scheme_transaction_link_id>TLINKIDENTIFIER4521412</scheme_transaction_link_id>
<scheme_max_settlement_date>2024-07-31</scheme_max_settlement_date>
<scheme_authentication_data_quality>true</scheme_authentication_data_quality>
<payment_response>threeds</payment_response>
<preauthorization>true</preauthorization>
<preauthorization_expires_at>2025-02-14T10:23:59Z</preauthorization_expires_at>
<preauthorization_total_amount>5000</preauthorization_total_amount>
<capturable_amount>5000</capturable_amount>
<captured_amount>0</captured_amount>
<reversed_amount>0</reversed_amount>
<reversible_amount>5000</reversible_amount>
</payment_response>
- MCC Restriction - NO
- Authorize timeframe - 30 days
- Authorize timeframe extension - supported via Incremental authorize
- Capture tolerance - YES, but only for the MCCs below. Navigate to the Capture section to learn more.
MCC | Segment | Authorization timeframe | Amount tolerance |
---|---|---|---|
5812 | Eating Places, Restaurants | 30 days | 20% |
5814 | Fast Food Restaurants | 30 days | 20% |
Maestro
Intl Maestro Lodging Preauthorization Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Authorize');
$request = $genesis->request();
$request
->setTransactionId('TrxID_52d3571f06d449e8e5c1f70ef904448a')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('5000')
->setCurrency('USD')
->setPreauthorization('true')
->setCardHolder('Travis Pastrana')
->setCardNumber('6759411100000008')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.AuthorizeRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
AuthorizeRequest request = new AuthorizeRequest();
request.setTransactionId("TrxID_52d3571f06d449e8e5c1f70ef904448a");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(5000));
request.setCurrency("USD");
request.setPreauthorization("true");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("6759411100000008");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.authorize(
{
"transaction_id": "TrxID_52d3571f06d449e8e5c1f70ef904448a",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": 5000,
"currency": "USD",
"preauthorization": true,
"card_holder": "Travis Pastrana",
"card_number": "6759411100000008",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>authorize</transaction_type>
<transaction_id>TrxID_52d3571f06d449e8e5c1f70ef904448a</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>5000</amount>
<currency>USD</currency>
<preauthorization>true</preauthorization>
<card_holder>Travis Pastrana</card_holder>
<card_number>6759411100000008</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
</payment_transaction>'
Successful Response
stdClass Object
(
[transaction_type] => authorize
[status] => approved
[mode] => live
[transaction_id] => TrxID_52d3571f06d449e8e5c1f70ef904448a
[unique_id] => 670542826016b218aaecc8a2b4905077
[avs_response_code] => 5I
[avs_response_text] => Response provided by issuer processor; Address information not verified
[cvv_result_code] => M
[authorization_code] => 803873
[response_code] => 00
[timestamp] => DateTime Object
(
[date] => 2025-01-14 10:23:59.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 5000
[currency] => USD
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[authorize]>
<status content=[approved]>
<mode content=[live]>
<transaction_id content=[TrxID_52d3571f06d449e8e5c1f70ef904448a]>
<unique_id content=[670542826016b218aaecc8a2b4905077]>
<avs_response_code content=[5I]>
<avs_response_text content=[Response provided by issuer processor; Address information not verified]>
<cvv_result_code content=[M]>
<authorization_code content=[803873]>
<response_code content=[00]>
<timestamp content=[2025-01-14T10:23:59Z]>
<descriptor content=[Descriptor one]>
<amount content=[5000]>
<currency content=[USD]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "authorize",
status: "approved",
mode: "live",
transaction_id: "TrxID_52d3571f06d449e8e5c1f70ef904448a",
unique_id: "670542826016b218aaecc8a2b4905077",
avs_response_code: "5I",
avs_response_text: "Response provided by issuer processor; Address information not verified",
cvv_result_code: "M",
authorization_code: "803873",
response_code: "00",
timestamp: "2025-01-14T10:23:59Z",
descriptor: "Descriptor one",
amount: "5000",
currency: "USD",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>authorize</transaction_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>TrxID_52d3571f06d449e8e5c1f70ef904448a</transaction_id>
<unique_id>670542826016b218aaecc8a2b4905077</unique_id>
<avs_response_code>5I</avs_response_code>
<avs_response_text>Response provided by issuer processor; Address information not verified</avs_response_text>
<cvv_result_code>M</cvv_result_code>
<authorization_code>803873</authorization_code>
<response_code>00</response_code>
<timestamp>2025-01-14T10:23:59Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>5000</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Reconcile Intl Maestro Preauthorization Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('NonFinancial\Reconcile\Transaction');
$request = $genesis->request();
$request
->setUniqueId('670542826016b218aaecc8a2b4905077');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.nonfinancial.reconcile.ReconcileRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
ReconcileRequest request = new ReconcileRequest();
request.setUniqueId("670542826016b218aaecc8a2b4905077");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.reconcile(
{
"unique_id": "670542826016b218aaecc8a2b4905077"
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/reconcile/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<reconcile>
<unique_id>670542826016b218aaecc8a2b4905077</unique_id>
</reconcile>'
Successful Preauthorization Reconciliation Response
stdClass Object
(
[transaction_type] => authorize
[status] => approved
[authorization_code] => 803873
[retrieval_reference_number] => 016813015184
[payment_account_reference] => Q1HJZ28RKA1EBL470G9XYG90R5D3E
[response_code] => 00
[unique_id] => 670542826016b218aaecc8a2b4905077
[transaction_id] => TrxID_52d3571f06d449e8e5c1f70ef904448a
[mode] => live
[timestamp] => 2025-01-14T10:23:59Z
[descriptor] => Descriptor one
[amount] => 5000
[currency] => USD
[card_brand] => Intl Maestro
[card_number] => 675941...0008
[card_type] => CREDIT
[card_subtype] => CARD SUBTYPE
[card_issuing_bank] => Issuing Bank
[card_issuing_country] => Exact Issuing country
[bank_account_number] => Bank Account Number
[bank_identifier_code] => Bank Identifier Code
[sent_to_acquirer] => true
[arn] => 74537605259536043849425
[scheme_response_code] => 00
[scheme_transaction_link_id] => TLINKIDENTIFIER4521412
[scheme_max_settlement_date] => 2024-07-31
[scheme_authentication_data_quality] => true
[threeds] =>
[preauthorization] => true
[preauthorization_expires_at] => 2025-01-21T10:23:59Z
[preauthorization_total_amount] => 5000
[capturable_amount] => 5000
[captured_amount] => 0
[reversed_amount] => 0
[reversible_amount] => 5000
)
<payment_response content=[
<transaction_type content=[authorize]>
<status content=[approved]>
<authorization_code content=[803873]>
<retrieval_reference_number content=[016813015184]>
<payment_account_reference content=[Q1HJZ28RKA1EBL470G9XYG90R5D3E]>
<response_code content=[00]>
<unique_id content=[670542826016b218aaecc8a2b4905077]>
<transaction_id content=[TrxID_52d3571f06d449e8e5c1f70ef904448a]>
<mode content=[live]>
<timestamp content=[2025-01-14T10:23:59Z]>
<descriptor content=[Descriptor one]>
<amount content=[5000]>
<currency content=[USD]>
<card_brand content=[Intl Maestro]>
<card_number content=[675941...0008]>
<card_type content=[CREDIT]>
<card_subtype content=[CARD SUBTYPE]>
<card_issuing_bank content=[Issuing Bank]>
<card_issuing_country content=[Exact Issuing country]>
<bank_account_number content=[Bank Account Number]>
<bank_identifier_code content=[Bank Identifier Code]>
<sent_to_acquirer content=[true]>
<arn content=[74537605259536043849425]>
<scheme_response_code content=[00]>
<scheme_transaction_link_id content=[TLINKIDENTIFIER4521412]>
<scheme_max_settlement_date content=[2024-07-31]>
<scheme_authentication_data_quality content=[true]>
<threeds content=[]>
<preauthorization content=[true]>
<preauthorization_expires_at content=[2025-01-21T10:23:59Z]>
<preauthorization_total_amount content=[5000]>
<capturable_amount content=[5000]>
<captured_amount content=[0]>
<reversed_amount content=[0]>
<reversible_amount content=[5000]>
]>
{
transaction_type: "authorize",
status: "approved",
authorization_code: "803873",
retrieval_reference_number: "016813015184",
payment_account_reference: "Q1HJZ28RKA1EBL470G9XYG90R5D3E",
response_code: "00",
unique_id: "670542826016b218aaecc8a2b4905077",
transaction_id: "TrxID_52d3571f06d449e8e5c1f70ef904448a",
mode: "live",
timestamp: "2025-01-14T10:23:59Z",
descriptor: "Descriptor one",
amount: "5000",
currency: "USD",
card_brand: "Intl Maestro",
card_number: "675941...0008",
card_type: "CREDIT",
card_subtype: "CARD SUBTYPE",
card_issuing_bank: "Issuing Bank",
card_issuing_country: "Exact Issuing country",
bank_account_number: "Bank Account Number",
bank_identifier_code: "Bank Identifier Code",
sent_to_acquirer: "true",
arn: "74537605259536043849425",
scheme_response_code: "00",
scheme_transaction_link_id: "TLINKIDENTIFIER4521412",
scheme_max_settlement_date: "2024-07-31",
scheme_authentication_data_quality: "true",
threeds: "",
preauthorization: "true",
preauthorization_expires_at: "2025-01-21T10:23:59Z",
preauthorization_total_amount: "5000",
capturable_amount: "5000",
captured_amount: "0",
reversed_amount: "0",
reversible_amount: "5000",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>authorize</transaction_type>
<status>approved</status>
<authorization_code>803873</authorization_code>
<retrieval_reference_number>016813015184</retrieval_reference_number>
<payment_account_reference>Q1HJZ28RKA1EBL470G9XYG90R5D3E</payment_account_reference>
<response_code>00</response_code>
<unique_id>670542826016b218aaecc8a2b4905077</unique_id>
<transaction_id>TrxID_52d3571f06d449e8e5c1f70ef904448a</transaction_id>
<mode>live</mode>
<timestamp>2025-01-14T10:23:59Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>5000</amount>
<currency>USD</currency>
<card_brand>Intl Maestro</card_brand>
<card_number>675941...0008</card_number>
<card_type>CREDIT</card_type>
<card_subtype>CARD SUBTYPE</card_subtype>
<card_issuing_bank>Issuing Bank</card_issuing_bank>
<card_issuing_country>Exact Issuing country</card_issuing_country>
<bank_account_number>Bank Account Number</bank_account_number>
<bank_identifier_code>Bank Identifier Code</bank_identifier_code>
<sent_to_acquirer>true</sent_to_acquirer>
<arn>74537605259536043849425</arn>
<scheme_response_code>00</scheme_response_code>
<scheme_transaction_link_id>TLINKIDENTIFIER4521412</scheme_transaction_link_id>
<scheme_max_settlement_date>2024-07-31</scheme_max_settlement_date>
<scheme_authentication_data_quality>true</scheme_authentication_data_quality>
<payment_response>threeds</payment_response>
<preauthorization>true</preauthorization>
<preauthorization_expires_at>2025-01-21T10:23:59Z</preauthorization_expires_at>
<preauthorization_total_amount>5000</preauthorization_total_amount>
<capturable_amount>5000</capturable_amount>
<captured_amount>0</captured_amount>
<reversed_amount>0</reversed_amount>
<reversible_amount>5000</reversible_amount>
</payment_response>
- MCC Restriction - NO
- Authorize timeframe - 7 days
- Authorize timeframe extension - supported via Incremental authorize
- Capture tolerance - YES, but only for the MCCs below. Navigate to the Capture section to learn more.
MCC | Segment | Authorization timeframe | Amount tolerance |
---|---|---|---|
5812 | Eating Places, Restaurants | 7 days | 20% |
5814 | Fast Food Restaurants | 7 days | 20% |
Reconcile the preauthorization to retrieve the Preauthorization specifics:
- Preauthorization expiration
- Total preauthorized amount
- Capturable amount
- Captured amount
Incremental Authorize
Incremental authorizations are used in preauthorization workflow to:
- extend the preauthorization amount
- extend the preauthorization time-frame
An incremental authorization transaction can be submitted in case:
- Preauthorization is approved and preauthorization time-frame is not expired
- Preauthorization has not been captured
Extend Preauthorization Timeframe & Amount
Mastercard Incremental Authorization Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Preauthorization\IncrementalAuthorize');
$request = $genesis->request();
$request
->setTransactionId('TrxID_d73c2753546a97bf33d397234972c2ce')
->setUsage('20469237 extend hotel rezervation')
->setRemoteIp('245.253.2.12')
->setAmount('1000')
->setReferenceId('af25a3a9d06b42f553dedcde2ba8a2bb');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>incremental_authorize</transaction_type>
<transaction_id>TrxID_d73c2753546a97bf33d397234972c2ce</transaction_id>
<usage>20469237 extend hotel rezervation</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>1000</amount>
<reference_id>af25a3a9d06b42f553dedcde2ba8a2bb</reference_id>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: incremental_authorize |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | required* | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
amount | required | integer >= 0 | Topup amount in minor currency unit, see Currency and Amount Handling for details |
reference_id | required | string(32) | Unique id of the corresponding preauthorization transaction |
required* = conditionally required
Successful Response
stdClass Object
(
[transaction_type] => incremental_authorize
[status] => approved
[mode] => live
[transaction_id] => TrxID_d73c2753546a97bf33d397234972c2ce
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[avs_response_code] => 5I
[avs_response_text] => Response provided by issuer processor; Address information not verified
[authorization_code] => 485335
[retrieval_reference_number] => 016813015184
[response_code] => 00
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:59.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 1000
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>incremental_authorize</transaction_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>TrxID_d73c2753546a97bf33d397234972c2ce</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<avs_response_code>5I</avs_response_code>
<avs_response_text>Response provided by issuer processor; Address information not verified</avs_response_text>
<authorization_code>485335</authorization_code>
<retrieval_reference_number>016813015184</retrieval_reference_number>
<response_code>00</response_code>
<timestamp>2025-01-16T10:23:59Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>1000</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
gaming | 'true' | Signifies whether a gaming transaction is performed. Gaming transactions usually use MCC 7995, contact tech support for more details. |
moto | 'true' | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech support for more details. |
avs_response_code | string(255) | Generated by the card network on trying to match the billing address when performing the address verification. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
avs_response_text | string(255) | Gives the human response text for the AVS response code above. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
authorization_code | string(6) | Generated by the card network when an authorisation has occurred, used to identify that auth. Consists of 6 alphanumeric chars |
retrieval_reference_number | string(255) | A reference number used for tracking all messages related to a given cardholder transaction returned by some acquirers. |
response_code | string(2) | Defines the result of a transaction with the acquirer, the status of a message or some action taken or required. Contact tech-support@emerchantpay.com for more details. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
partial_approval | string(4) | Optional, set to ’true’ if partial approval happened. Partially approved amount is then in the amount field. Check Partial Approvals for details |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => incremental_authorize
[status] => error
[mode] => live
[transaction_id] => TrxID_d73c2753546a97bf33d397234972c2ce
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 400
[technical_message] => Preauthorization has been captured, no further incremental authorizations allowed
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:59.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 1000
[currency] => USD
[sent_to_acquirer] => false
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>incremental_authorize</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>TrxID_d73c2753546a97bf33d397234972c2ce</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>400</code>
<technical_message>Preauthorization has been captured, no further incremental authorizations allowed</technical_message>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:59Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>1000</amount>
<currency>USD</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
gaming | 'true' | Signifies whether a gaming transaction is performed. Gaming transactions usually use MCC 7995, contact tech support for more details. |
moto | 'true' | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech support for more details. |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
dynamic_descriptor_params | section | Optional, returned only if dynamic desc params are submitted on the API. Note here that the formatted dyn desc params are returned - as they would be submitted to the schemes for settlement. |
Example Xml For Extending The Time Frame Only
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Preauthorization\IncrementalAuthorize');
$request = $genesis->request();
$request
->setTransactionId('TrxID_d73c2753546a97bf33d397234972c2ce')
->setUsage('204692378 extend the preauthorization validity timeframe')
->setRemoteIp('245.253.2.12')
->setAmount('0')
->setReferenceId('1cb26fd5b9991d84471cc741b73b0950');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>incremental_authorize</transaction_type>
<transaction_id>TrxID_d73c2753546a97bf33d397234972c2ce</transaction_id>
<usage>204692378 extend the preauthorization validity timeframe</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>0</amount>
<reference_id>1cb26fd5b9991d84471cc741b73b0950</reference_id>
</payment_transaction>'
Error Response
stdClass Object
(
[transaction_type] => incremental_authorize
[status] => error
[mode] => live
[transaction_id] => TrxID_d73c2753546a97bf33d397234972c2ce
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 400
[technical_message] => Incremental authorizations with no financial impact are currently not supported by card brand
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:23:59.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 0
[currency] => USD
[sent_to_acquirer] => false
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>incremental_authorize</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>TrxID_d73c2753546a97bf33d397234972c2ce</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>400</code>
<technical_message>Incremental authorizations with no financial impact are currently not supported by card brand</technical_message>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:23:59Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>0</amount>
<currency>USD</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Reconcile Preauthorization By Unique Id Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('NonFinancial\Reconcile\Transaction');
$request = $genesis->request();
$request
->setUniqueId('af25a3a9d06b42f553dedcde2ba8a2bb');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.nonfinancial.reconcile.ReconcileRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
ReconcileRequest request = new ReconcileRequest();
request.setUniqueId("af25a3a9d06b42f553dedcde2ba8a2bb");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.reconcile(
{
"unique_id": "af25a3a9d06b42f553dedcde2ba8a2bb"
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/reconcile/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<reconcile>
<unique_id>af25a3a9d06b42f553dedcde2ba8a2bb</unique_id>
</reconcile>'
Successful Preauthorization Reconciliation Response
stdClass Object
(
[transaction_type] => authorize
[status] => approved
[authorization_code] => 485335
[retrieval_reference_number] => 016813015184
[payment_account_reference] => 50019P9LBXOLHN9G7QMU5VN520YSY
[response_code] => 00
[unique_id] => af25a3a9d06b42f553dedcde2ba8a2bb
[transaction_id] => TrxID_d73c2753546a97bf33d397234972c2ce
[mode] => live
[timestamp] => 2025-01-16T10:24:00Z
[descriptor] => Descriptor one
[amount] => 5000
[currency] => USD
[card_brand] => master
[card_number] => 555555...4444
[card_type] => CREDIT
[card_subtype] => CARD SUBTYPE
[card_issuing_bank] => Issuing Bank
[card_issuing_country] => Exact Issuing country
[bank_account_number] => Bank Account Number
[bank_identifier_code] => Bank Identifier Code
[sent_to_acquirer] => true
[arn] => 74537605259536043849425
[scheme_response_code] => 00
[scheme_transaction_link_id] => TLINKIDENTIFIER4521412
[scheme_max_settlement_date] => 2024-07-31
[scheme_authentication_data_quality] => true
[threeds] =>
[preauthorization] => true
[preauthorization_expires_at] => 2025-03-16T10:23:59Z
[preauthorization_total_amount] => 6000
[capturable_amount] => 6000
[captured_amount] => 0
[payment_account_reference] => 50019P9LBXOLHN9G7QMU5VN520YSY
)
<payment_response content=[
<transaction_type content=[authorize]>
<status content=[approved]>
<authorization_code content=[485335]>
<retrieval_reference_number content=[016813015184]>
<payment_account_reference content=[50019P9LBXOLHN9G7QMU5VN520YSY]>
<response_code content=[00]>
<unique_id content=[af25a3a9d06b42f553dedcde2ba8a2bb]>
<transaction_id content=[TrxID_d73c2753546a97bf33d397234972c2ce]>
<mode content=[live]>
<timestamp content=[2025-01-16T10:24:00Z]>
<descriptor content=[Descriptor one]>
<amount content=[5000]>
<currency content=[USD]>
<card_brand content=[master]>
<card_number content=[555555...4444]>
<card_type content=[CREDIT]>
<card_subtype content=[CARD SUBTYPE]>
<card_issuing_bank content=[Issuing Bank]>
<card_issuing_country content=[Exact Issuing country]>
<bank_account_number content=[Bank Account Number]>
<bank_identifier_code content=[Bank Identifier Code]>
<sent_to_acquirer content=[true]>
<arn content=[74537605259536043849425]>
<scheme_response_code content=[00]>
<scheme_transaction_link_id content=[TLINKIDENTIFIER4521412]>
<scheme_max_settlement_date content=[2024-07-31]>
<scheme_authentication_data_quality content=[true]>
<threeds content=[]>
<preauthorization content=[true]>
<preauthorization_expires_at content=[2025-03-16T10:23:59Z]>
<preauthorization_total_amount content=[6000]>
<capturable_amount content=[6000]>
<captured_amount content=[0]>
<payment_account_reference content=[50019P9LBXOLHN9G7QMU5VN520YSY]>
]>
{
transaction_type: "authorize",
status: "approved",
authorization_code: "485335",
retrieval_reference_number: "016813015184",
payment_account_reference: "50019P9LBXOLHN9G7QMU5VN520YSY",
response_code: "00",
unique_id: "af25a3a9d06b42f553dedcde2ba8a2bb",
transaction_id: "TrxID_d73c2753546a97bf33d397234972c2ce",
mode: "live",
timestamp: "2025-01-16T10:24:00Z",
descriptor: "Descriptor one",
amount: "5000",
currency: "USD",
card_brand: "master",
card_number: "555555...4444",
card_type: "CREDIT",
card_subtype: "CARD SUBTYPE",
card_issuing_bank: "Issuing Bank",
card_issuing_country: "Exact Issuing country",
bank_account_number: "Bank Account Number",
bank_identifier_code: "Bank Identifier Code",
sent_to_acquirer: "true",
arn: "74537605259536043849425",
scheme_response_code: "00",
scheme_transaction_link_id: "TLINKIDENTIFIER4521412",
scheme_max_settlement_date: "2024-07-31",
scheme_authentication_data_quality: "true",
threeds: "",
preauthorization: "true",
preauthorization_expires_at: "2025-03-16T10:23:59Z",
preauthorization_total_amount: "6000",
capturable_amount: "6000",
captured_amount: "0",
payment_account_reference: "50019P9LBXOLHN9G7QMU5VN520YSY",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>authorize</transaction_type>
<status>approved</status>
<authorization_code>485335</authorization_code>
<retrieval_reference_number>016813015184</retrieval_reference_number>
<payment_account_reference>50019P9LBXOLHN9G7QMU5VN520YSY</payment_account_reference>
<response_code>00</response_code>
<unique_id>af25a3a9d06b42f553dedcde2ba8a2bb</unique_id>
<transaction_id>TrxID_d73c2753546a97bf33d397234972c2ce</transaction_id>
<mode>live</mode>
<timestamp>2025-01-16T10:24:00Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>5000</amount>
<currency>USD</currency>
<card_brand>master</card_brand>
<card_number>555555...4444</card_number>
<card_type>CREDIT</card_type>
<card_subtype>CARD SUBTYPE</card_subtype>
<card_issuing_bank>Issuing Bank</card_issuing_bank>
<card_issuing_country>Exact Issuing country</card_issuing_country>
<bank_account_number>Bank Account Number</bank_account_number>
<bank_identifier_code>Bank Identifier Code</bank_identifier_code>
<sent_to_acquirer>true</sent_to_acquirer>
<arn>74537605259536043849425</arn>
<scheme_response_code>00</scheme_response_code>
<scheme_transaction_link_id>TLINKIDENTIFIER4521412</scheme_transaction_link_id>
<scheme_max_settlement_date>2024-07-31</scheme_max_settlement_date>
<scheme_authentication_data_quality>true</scheme_authentication_data_quality>
<payment_response>threeds</payment_response>
<preauthorization>true</preauthorization>
<preauthorization_expires_at>2025-03-16T10:23:59Z</preauthorization_expires_at>
<preauthorization_total_amount>6000</preauthorization_total_amount>
<capturable_amount>6000</capturable_amount>
<captured_amount>0</captured_amount>
</payment_response>
Capture
Preauthorizations can be captured using the standard Capture transaction with the correct reference_id
of the Preauthorization.
An additional incremental authorization will be necessary when the requested capture amount is greater than:
the total authorized amount including the calculated amount tolerance (% of the total authorized amount)
the predefined amount tolerance in value exchanged to the appropriate currency (check the amount tolerance mer MCC in the Preauthorization section)
Reconcile Visa Preauthorization Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('NonFinancial\Reconcile\Transaction');
$request = $genesis->request();
$request
->setUniqueId('1cb26fd5b9991d84471cc741b73b0950');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.nonfinancial.reconcile.ReconcileRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
ReconcileRequest request = new ReconcileRequest();
request.setUniqueId("1cb26fd5b9991d84471cc741b73b0950");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.reconcile(
{
"unique_id": "1cb26fd5b9991d84471cc741b73b0950"
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/reconcile/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<reconcile>
<unique_id>1cb26fd5b9991d84471cc741b73b0950</unique_id>
</reconcile>'
Successful Preauthorization Reconciliation Response
stdClass Object
(
[transaction_type] => authorize
[status] => approved
[authorization_code] => 005645
[retrieval_reference_number] => 016813015184
[payment_account_reference] => Q1HJZ28RKA1EBL470G9XYG90R5D3E
[response_code] => 00
[unique_id] => 1cb26fd5b9991d84471cc741b73b0950
[transaction_id] => 119643250547501c79d8295
[mode] => live
[timestamp] => 2025-01-16T10:23:59Z
[descriptor] => Descriptor one
[amount] => 3000
[currency] => USD
[card_brand] => visa
[card_number] => 420000...0000
[card_type] => CREDIT
[card_subtype] => CARD SUBTYPE
[card_issuing_bank] => Issuing Bank
[card_issuing_country] => Exact Issuing country
[bank_account_number] => Bank Account Number
[bank_identifier_code] => Bank Identifier Code
[sent_to_acquirer] => true
[arn] => 74537605259536043849425
[scheme_response_code] => 00
[scheme_transaction_link_id] => TLINKIDENTIFIER4521412
[scheme_max_settlement_date] => 2024-07-31
[scheme_authentication_data_quality] => true
[threeds] =>
[preauthorization] => true
[preauthorization_expires_at] => 2025-02-16T10:23:59Z
[preauthorization_total_amount] => 5000
[capturable_amount] => 5750
[captured_amount] => 0
[reversed_amount] => 0
[reversible_amount] => 5000
)
<payment_response content=[
<transaction_type content=[authorize]>
<status content=[approved]>
<authorization_code content=[005645]>
<retrieval_reference_number content=[016813015184]>
<payment_account_reference content=[Q1HJZ28RKA1EBL470G9XYG90R5D3E]>
<response_code content=[00]>
<unique_id content=[1cb26fd5b9991d84471cc741b73b0950]>
<transaction_id content=[119643250547501c79d8295]>
<mode content=[live]>
<timestamp content=[2025-01-16T10:23:59Z]>
<descriptor content=[Descriptor one]>
<amount content=[3000]>
<currency content=[USD]>
<card_brand content=[visa]>
<card_number content=[420000...0000]>
<card_type content=[CREDIT]>
<card_subtype content=[CARD SUBTYPE]>
<card_issuing_bank content=[Issuing Bank]>
<card_issuing_country content=[Exact Issuing country]>
<bank_account_number content=[Bank Account Number]>
<bank_identifier_code content=[Bank Identifier Code]>
<sent_to_acquirer content=[true]>
<arn content=[74537605259536043849425]>
<scheme_response_code content=[00]>
<scheme_transaction_link_id content=[TLINKIDENTIFIER4521412]>
<scheme_max_settlement_date content=[2024-07-31]>
<scheme_authentication_data_quality content=[true]>
<threeds content=[]>
<preauthorization content=[true]>
<preauthorization_expires_at content=[2025-02-16T10:23:59Z]>
<preauthorization_total_amount content=[5000]>
<capturable_amount content=[5750]>
<captured_amount content=[0]>
<reversed_amount content=[0]>
<reversible_amount content=[5000]>
]>
{
transaction_type: "authorize",
status: "approved",
authorization_code: "005645",
retrieval_reference_number: "016813015184",
payment_account_reference: "Q1HJZ28RKA1EBL470G9XYG90R5D3E",
response_code: "00",
unique_id: "1cb26fd5b9991d84471cc741b73b0950",
transaction_id: "119643250547501c79d8295",
mode: "live",
timestamp: "2025-01-16T10:23:59Z",
descriptor: "Descriptor one",
amount: "3000",
currency: "USD",
card_brand: "visa",
card_number: "420000...0000",
card_type: "CREDIT",
card_subtype: "CARD SUBTYPE",
card_issuing_bank: "Issuing Bank",
card_issuing_country: "Exact Issuing country",
bank_account_number: "Bank Account Number",
bank_identifier_code: "Bank Identifier Code",
sent_to_acquirer: "true",
arn: "74537605259536043849425",
scheme_response_code: "00",
scheme_transaction_link_id: "TLINKIDENTIFIER4521412",
scheme_max_settlement_date: "2024-07-31",
scheme_authentication_data_quality: "true",
threeds: "",
preauthorization: "true",
preauthorization_expires_at: "2025-02-16T10:23:59Z",
preauthorization_total_amount: "5000",
capturable_amount: "5750",
captured_amount: "0",
reversed_amount: "0",
reversible_amount: "5000",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>authorize</transaction_type>
<status>approved</status>
<authorization_code>005645</authorization_code>
<retrieval_reference_number>016813015184</retrieval_reference_number>
<payment_account_reference>Q1HJZ28RKA1EBL470G9XYG90R5D3E</payment_account_reference>
<response_code>00</response_code>
<unique_id>1cb26fd5b9991d84471cc741b73b0950</unique_id>
<transaction_id>119643250547501c79d8295</transaction_id>
<mode>live</mode>
<timestamp>2025-01-16T10:23:59Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>3000</amount>
<currency>USD</currency>
<card_brand>visa</card_brand>
<card_number>420000...0000</card_number>
<card_type>CREDIT</card_type>
<card_subtype>CARD SUBTYPE</card_subtype>
<card_issuing_bank>Issuing Bank</card_issuing_bank>
<card_issuing_country>Exact Issuing country</card_issuing_country>
<bank_account_number>Bank Account Number</bank_account_number>
<bank_identifier_code>Bank Identifier Code</bank_identifier_code>
<sent_to_acquirer>true</sent_to_acquirer>
<arn>74537605259536043849425</arn>
<scheme_response_code>00</scheme_response_code>
<scheme_transaction_link_id>TLINKIDENTIFIER4521412</scheme_transaction_link_id>
<scheme_max_settlement_date>2024-07-31</scheme_max_settlement_date>
<scheme_authentication_data_quality>true</scheme_authentication_data_quality>
<payment_response>threeds</payment_response>
<preauthorization>true</preauthorization>
<preauthorization_expires_at>2025-02-16T10:23:59Z</preauthorization_expires_at>
<preauthorization_total_amount>5000</preauthorization_total_amount>
<capturable_amount>5750</capturable_amount>
<captured_amount>0</captured_amount>
<reversed_amount>0</reversed_amount>
<reversible_amount>5000</reversible_amount>
</payment_response>
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Capture');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('Check out from the Hotel')
->setRemoteIp('245.253.2.12')
->setReferenceId('43672')
->setAmount('5500')
->setCurrency('USD');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.CaptureRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
CaptureRequest request = new CaptureRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("Check out from the Hotel");
request.setRemoteIp("245.253.2.12");
request.setReferenceId("43672");
request.setAmount(new BigDecimal(5500));
request.setCurrency("USD");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.capture(
{
"transaction_id": "119643250547501c79d8295",
"usage": "Check out from the Hotel",
"remote_ip": "245.253.2.12",
"reference_id": "43672",
"amount": 5500,
"currency": "USD"
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>capture</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>Check out from the Hotel</usage>
<remote_ip>245.253.2.12</remote_ip>
<reference_id>43672</reference_id>
<amount>5500</amount>
<currency>USD</currency>
</payment_transaction>'
Successful Response
stdClass Object
(
[transaction_type] => capture
[status] => approved
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[authorization_code] => 345678
[response_code] => 00
[technical_message] => Transaction successful!
[message] => Transaction successful!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:24:00.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 5500
[currency] => USD
[sent_to_acquirer] => true
)
<payment_response content=[
<transaction_type content=[capture]>
<status content=[approved]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<authorization_code content=[345678]>
<response_code content=[00]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<timestamp content=[2025-01-16T10:24:00Z]>
<descriptor content=[Descriptor one]>
<amount content=[5500]>
<currency content=[USD]>
<sent_to_acquirer content=[true]>
]>
{
transaction_type: "capture",
status: "approved",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
authorization_code: "345678",
response_code: "00",
technical_message: "Transaction successful!",
message: "Transaction successful!",
timestamp: "2025-01-16T10:24:00Z",
descriptor: "Descriptor one",
amount: "5500",
currency: "USD",
sent_to_acquirer: "true",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>capture</transaction_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<authorization_code>345678</authorization_code>
<response_code>00</response_code>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2025-01-16T10:24:00Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>5500</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Error Response
stdClass Object
(
[transaction_type] => capture
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 420
[technical_message] => partial reversal is required first for the rest amount
[message] => Transaction declined.
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:24:00.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 4000
[currency] => USD
[sent_to_acquirer] => false
)
<payment_response content=[
<transaction_type content=[capture]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<code content=[420]>
<technical_message content=[partial reversal is required first for the rest amount]>
<message content=[Transaction declined.]>
<timestamp content=[2025-01-16T10:24:00Z]>
<descriptor content=[Descriptor one]>
<amount content=[4000]>
<currency content=[USD]>
<sent_to_acquirer content=[false]>
]>
{
transaction_type: "capture",
status: "error",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
code: "420",
technical_message: "partial reversal is required first for the rest amount",
message: "Transaction declined.",
timestamp: "2025-01-16T10:24:00Z",
descriptor: "Descriptor one",
amount: "4000",
currency: "USD",
sent_to_acquirer: "false",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>capture</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>420</code>
<technical_message>partial reversal is required first for the rest amount</technical_message>
<message>Transaction declined.</message>
<timestamp>2025-01-16T10:24:00Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>4000</amount>
<currency>USD</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Reconcile Visa Preauthorization Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('NonFinancial\Reconcile\Transaction');
$request = $genesis->request();
$request
->setUniqueId('1cb26fd5b9991d84471cc741b73b0950');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.nonfinancial.reconcile.ReconcileRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
ReconcileRequest request = new ReconcileRequest();
request.setUniqueId("1cb26fd5b9991d84471cc741b73b0950");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.reconcile(
{
"unique_id": "1cb26fd5b9991d84471cc741b73b0950"
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/reconcile/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<reconcile>
<unique_id>1cb26fd5b9991d84471cc741b73b0950</unique_id>
</reconcile>'
Successful Preauthorization Reconciliation Response
stdClass Object
(
[transaction_type] => authorize
[status] => approved
[authorization_code] => 005645
[retrieval_reference_number] => 016813015184
[payment_account_reference] => Q1HJZ28RKA1EBL470G9XYG90R5D3E
[response_code] => 00
[unique_id] => 1cb26fd5b9991d84471cc741b73b0950
[transaction_id] => 119643250547501c79d8295
[mode] => live
[timestamp] => 2025-01-16T10:23:59Z
[descriptor] => Descriptor one
[amount] => 3000
[currency] => USD
[card_brand] => visa
[card_number] => 420000...0000
[card_type] => CREDIT
[card_subtype] => CARD SUBTYPE
[card_issuing_bank] => Issuing Bank
[card_issuing_country] => Exact Issuing country
[bank_account_number] => Bank Account Number
[bank_identifier_code] => Bank Identifier Code
[sent_to_acquirer] => true
[arn] => 74537605259536043849425
[scheme_response_code] => 00
[scheme_transaction_link_id] => TLINKIDENTIFIER4521412
[scheme_max_settlement_date] => 2024-07-31
[scheme_authentication_data_quality] => true
[threeds] =>
[preauthorization] => true
[preauthorization_expires_at] => 2025-02-16T10:23:59Z
[preauthorization_total_amount] => 5000
[capturable_amount] => 0
[captured_amount] => 5500
[reversed_amount] => 0
[reversible_amount] => 0
)
<payment_response content=[
<transaction_type content=[authorize]>
<status content=[approved]>
<authorization_code content=[005645]>
<retrieval_reference_number content=[016813015184]>
<payment_account_reference content=[Q1HJZ28RKA1EBL470G9XYG90R5D3E]>
<response_code content=[00]>
<unique_id content=[1cb26fd5b9991d84471cc741b73b0950]>
<transaction_id content=[119643250547501c79d8295]>
<mode content=[live]>
<timestamp content=[2025-01-16T10:23:59Z]>
<descriptor content=[Descriptor one]>
<amount content=[3000]>
<currency content=[USD]>
<card_brand content=[visa]>
<card_number content=[420000...0000]>
<card_type content=[CREDIT]>
<card_subtype content=[CARD SUBTYPE]>
<card_issuing_bank content=[Issuing Bank]>
<card_issuing_country content=[Exact Issuing country]>
<bank_account_number content=[Bank Account Number]>
<bank_identifier_code content=[Bank Identifier Code]>
<sent_to_acquirer content=[true]>
<arn content=[74537605259536043849425]>
<scheme_response_code content=[00]>
<scheme_transaction_link_id content=[TLINKIDENTIFIER4521412]>
<scheme_max_settlement_date content=[2024-07-31]>
<scheme_authentication_data_quality content=[true]>
<threeds content=[]>
<preauthorization content=[true]>
<preauthorization_expires_at content=[2025-02-16T10:23:59Z]>
<preauthorization_total_amount content=[5000]>
<capturable_amount content=[0]>
<captured_amount content=[5500]>
<reversed_amount content=[0]>
<reversible_amount content=[0]>
]>
{
transaction_type: "authorize",
status: "approved",
authorization_code: "005645",
retrieval_reference_number: "016813015184",
payment_account_reference: "Q1HJZ28RKA1EBL470G9XYG90R5D3E",
response_code: "00",
unique_id: "1cb26fd5b9991d84471cc741b73b0950",
transaction_id: "119643250547501c79d8295",
mode: "live",
timestamp: "2025-01-16T10:23:59Z",
descriptor: "Descriptor one",
amount: "3000",
currency: "USD",
card_brand: "visa",
card_number: "420000...0000",
card_type: "CREDIT",
card_subtype: "CARD SUBTYPE",
card_issuing_bank: "Issuing Bank",
card_issuing_country: "Exact Issuing country",
bank_account_number: "Bank Account Number",
bank_identifier_code: "Bank Identifier Code",
sent_to_acquirer: "true",
arn: "74537605259536043849425",
scheme_response_code: "00",
scheme_transaction_link_id: "TLINKIDENTIFIER4521412",
scheme_max_settlement_date: "2024-07-31",
scheme_authentication_data_quality: "true",
threeds: "",
preauthorization: "true",
preauthorization_expires_at: "2025-02-16T10:23:59Z",
preauthorization_total_amount: "5000",
capturable_amount: "0",
captured_amount: "5500",
reversed_amount: "0",
reversible_amount: "0",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>authorize</transaction_type>
<status>approved</status>
<authorization_code>005645</authorization_code>
<retrieval_reference_number>016813015184</retrieval_reference_number>
<payment_account_reference>Q1HJZ28RKA1EBL470G9XYG90R5D3E</payment_account_reference>
<response_code>00</response_code>
<unique_id>1cb26fd5b9991d84471cc741b73b0950</unique_id>
<transaction_id>119643250547501c79d8295</transaction_id>
<mode>live</mode>
<timestamp>2025-01-16T10:23:59Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>3000</amount>
<currency>USD</currency>
<card_brand>visa</card_brand>
<card_number>420000...0000</card_number>
<card_type>CREDIT</card_type>
<card_subtype>CARD SUBTYPE</card_subtype>
<card_issuing_bank>Issuing Bank</card_issuing_bank>
<card_issuing_country>Exact Issuing country</card_issuing_country>
<bank_account_number>Bank Account Number</bank_account_number>
<bank_identifier_code>Bank Identifier Code</bank_identifier_code>
<sent_to_acquirer>true</sent_to_acquirer>
<arn>74537605259536043849425</arn>
<scheme_response_code>00</scheme_response_code>
<scheme_transaction_link_id>TLINKIDENTIFIER4521412</scheme_transaction_link_id>
<scheme_max_settlement_date>2024-07-31</scheme_max_settlement_date>
<scheme_authentication_data_quality>true</scheme_authentication_data_quality>
<payment_response>threeds</payment_response>
<preauthorization>true</preauthorization>
<preauthorization_expires_at>2025-02-16T10:23:59Z</preauthorization_expires_at>
<preauthorization_total_amount>5000</preauthorization_total_amount>
<capturable_amount>0</capturable_amount>
<captured_amount>5500</captured_amount>
<reversed_amount>0</reversed_amount>
<reversible_amount>0</reversible_amount>
</payment_response>
Full Reversal
Full reversal of a preauthorization can be submitted using the standard Void transaction.
Reconcile request can be used to determine when the preauthorization is about to expire.
Reconcile Master Preauthorization Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('NonFinancial\Reconcile\Transaction');
$request = $genesis->request();
$request
->setUniqueId('af25a3a9d06b42f553dedcde2ba8a2bb');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.nonfinancial.reconcile.ReconcileRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
ReconcileRequest request = new ReconcileRequest();
request.setUniqueId("af25a3a9d06b42f553dedcde2ba8a2bb");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.reconcile(
{
"unique_id": "af25a3a9d06b42f553dedcde2ba8a2bb"
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/reconcile/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<reconcile>
<unique_id>af25a3a9d06b42f553dedcde2ba8a2bb</unique_id>
</reconcile>'
Successful Preauthorization Reconciliation Response
stdClass Object
(
[transaction_type] => authorize
[status] => approved
[authorization_code] => 005645
[retrieval_reference_number] => 016813015184
[payment_account_reference] => Q1HJZ28RKA1EBL470G9XYG90R5D3E
[response_code] => 00
[unique_id] => af25a3a9d06b42f553dedcde2ba8a2bb
[transaction_id] => 119643250547501c79d8295
[mode] => live
[timestamp] => 2025-01-15T10:23:59Z
[descriptor] => Descriptor one
[amount] => 3000
[currency] => USD
[card_brand] => master
[card_number] => 555555...4444
[card_type] => CREDIT
[card_subtype] => CARD SUBTYPE
[card_issuing_bank] => Issuing Bank
[card_issuing_country] => Exact Issuing country
[bank_account_number] => Bank Account Number
[bank_identifier_code] => Bank Identifier Code
[sent_to_acquirer] => true
[arn] => 74537605259536043849425
[scheme_response_code] => 00
[scheme_transaction_link_id] => TLINKIDENTIFIER4521412
[scheme_max_settlement_date] => 2024-07-31
[scheme_authentication_data_quality] => true
[threeds] =>
[preauthorization] => true
[preauthorization_expires_at] => 2025-02-14T10:23:59Z
[preauthorization_total_amount] => 5000
[capturable_amount] => 5000
[captured_amount] => 0
[reversed_amount] => 0
[reversible_amount] => 5000
)
<payment_response content=[
<transaction_type content=[authorize]>
<status content=[approved]>
<authorization_code content=[005645]>
<retrieval_reference_number content=[016813015184]>
<payment_account_reference content=[Q1HJZ28RKA1EBL470G9XYG90R5D3E]>
<response_code content=[00]>
<unique_id content=[af25a3a9d06b42f553dedcde2ba8a2bb]>
<transaction_id content=[119643250547501c79d8295]>
<mode content=[live]>
<timestamp content=[2025-01-15T10:23:59Z]>
<descriptor content=[Descriptor one]>
<amount content=[3000]>
<currency content=[USD]>
<card_brand content=[master]>
<card_number content=[555555...4444]>
<card_type content=[CREDIT]>
<card_subtype content=[CARD SUBTYPE]>
<card_issuing_bank content=[Issuing Bank]>
<card_issuing_country content=[Exact Issuing country]>
<bank_account_number content=[Bank Account Number]>
<bank_identifier_code content=[Bank Identifier Code]>
<sent_to_acquirer content=[true]>
<arn content=[74537605259536043849425]>
<scheme_response_code content=[00]>
<scheme_transaction_link_id content=[TLINKIDENTIFIER4521412]>
<scheme_max_settlement_date content=[2024-07-31]>
<scheme_authentication_data_quality content=[true]>
<threeds content=[]>
<preauthorization content=[true]>
<preauthorization_expires_at content=[2025-02-14T10:23:59Z]>
<preauthorization_total_amount content=[5000]>
<capturable_amount content=[5000]>
<captured_amount content=[0]>
<reversed_amount content=[0]>
<reversible_amount content=[5000]>
]>
{
transaction_type: "authorize",
status: "approved",
authorization_code: "005645",
retrieval_reference_number: "016813015184",
payment_account_reference: "Q1HJZ28RKA1EBL470G9XYG90R5D3E",
response_code: "00",
unique_id: "af25a3a9d06b42f553dedcde2ba8a2bb",
transaction_id: "119643250547501c79d8295",
mode: "live",
timestamp: "2025-01-15T10:23:59Z",
descriptor: "Descriptor one",
amount: "3000",
currency: "USD",
card_brand: "master",
card_number: "555555...4444",
card_type: "CREDIT",
card_subtype: "CARD SUBTYPE",
card_issuing_bank: "Issuing Bank",
card_issuing_country: "Exact Issuing country",
bank_account_number: "Bank Account Number",
bank_identifier_code: "Bank Identifier Code",
sent_to_acquirer: "true",
arn: "74537605259536043849425",
scheme_response_code: "00",
scheme_transaction_link_id: "TLINKIDENTIFIER4521412",
scheme_max_settlement_date: "2024-07-31",
scheme_authentication_data_quality: "true",
threeds: "",
preauthorization: "true",
preauthorization_expires_at: "2025-02-14T10:23:59Z",
preauthorization_total_amount: "5000",
capturable_amount: "5000",
captured_amount: "0",
reversed_amount: "0",
reversible_amount: "5000",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>authorize</transaction_type>
<status>approved</status>
<authorization_code>005645</authorization_code>
<retrieval_reference_number>016813015184</retrieval_reference_number>
<payment_account_reference>Q1HJZ28RKA1EBL470G9XYG90R5D3E</payment_account_reference>
<response_code>00</response_code>
<unique_id>af25a3a9d06b42f553dedcde2ba8a2bb</unique_id>
<transaction_id>119643250547501c79d8295</transaction_id>
<mode>live</mode>
<timestamp>2025-01-15T10:23:59Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>3000</amount>
<currency>USD</currency>
<card_brand>master</card_brand>
<card_number>555555...4444</card_number>
<card_type>CREDIT</card_type>
<card_subtype>CARD SUBTYPE</card_subtype>
<card_issuing_bank>Issuing Bank</card_issuing_bank>
<card_issuing_country>Exact Issuing country</card_issuing_country>
<bank_account_number>Bank Account Number</bank_account_number>
<bank_identifier_code>Bank Identifier Code</bank_identifier_code>
<sent_to_acquirer>true</sent_to_acquirer>
<arn>74537605259536043849425</arn>
<scheme_response_code>00</scheme_response_code>
<scheme_transaction_link_id>TLINKIDENTIFIER4521412</scheme_transaction_link_id>
<scheme_max_settlement_date>2024-07-31</scheme_max_settlement_date>
<scheme_authentication_data_quality>true</scheme_authentication_data_quality>
<payment_response>threeds</payment_response>
<preauthorization>true</preauthorization>
<preauthorization_expires_at>2025-02-14T10:23:59Z</preauthorization_expires_at>
<preauthorization_total_amount>5000</preauthorization_total_amount>
<capturable_amount>5000</capturable_amount>
<captured_amount>0</captured_amount>
<reversed_amount>0</reversed_amount>
<reversible_amount>5000</reversible_amount>
</payment_response>
Partial Reversal
Partial reversal transactions are used in the preauthorization workflow to release a part of the total authorized amount. A transaction of this type should refer to the preauthorization directly.
Extend Preauthorization Timeframe & Amount
Partial Reversal Request Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Preauthorization\PartialReversal');
$request = $genesis->request();
$request
->setTransactionId('TrxID_e5945004cc8de704629cdb0743e71896')
->setUsage('40208 hotel reservation changed')
->setRemoteIp('245.253.2.12')
->setAmount('500')
->setReferenceId('af25a3a9d06b42f553dedcde2ba8a2bb');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>partial_reversal</transaction_type>
<transaction_id>TrxID_e5945004cc8de704629cdb0743e71896</transaction_id>
<usage>40208 hotel reservation changed</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>500</amount>
<reference_id>af25a3a9d06b42f553dedcde2ba8a2bb</reference_id>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_type | required | string(255) | The transaction type: partial_reversal |
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | required* | string(255) | Description of the transaction for later use. |
remote_ip | required* | IPv4 or IPv6 address | IPv4 or IPv6 address of customer |
amount | required | integer > 0 | The amount to be reversed in minor currency unit, see Currency and Amount Handling for details. |
reference_id | required | string(32) | Unique id of the corresponding preauthorization transaction |
required* = conditionally required
Successful Response
stdClass Object
(
[transaction_type] => partial_reversal
[status] => approved
[authorization_code] => 629324
[retrieval_reference_number] => 016813015184
[response_code] => 00
[transaction_id] => TrxID_e5945004cc8de704629cdb0743e71896
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:24:00.000000
[timezone_type] => 2
[timezone] => Z
)
[mode] => live
[descriptor] => Descriptor one
[amount] => 500
[currency] => USD
[sent_to_acquirer] => true
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>partial_reversal</transaction_type>
<status>approved</status>
<authorization_code>629324</authorization_code>
<retrieval_reference_number>016813015184</retrieval_reference_number>
<response_code>00</response_code>
<transaction_id>TrxID_e5945004cc8de704629cdb0743e71896</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<timestamp>2025-01-16T10:24:00Z</timestamp>
<mode>live</mode>
<descriptor>Descriptor one</descriptor>
<amount>500</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
gaming | 'true' | Signifies whether a gaming transaction is performed. Gaming transactions usually use MCC 7995, contact tech support for more details. |
moto | 'true' | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech support for more details. |
avs_response_code | string(255) | Generated by the card network on trying to match the billing address when performing the address verification. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
avs_response_text | string(255) | Gives the human response text for the AVS response code above. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
authorization_code | string(6) | Generated by the card network when an authorisation has occurred, used to identify that auth. Consists of 6 alphanumeric chars |
retrieval_reference_number | string(255) | A reference number used for tracking all messages related to a given cardholder transaction returned by some acquirers. |
response_code | string(2) | Defines the result of a transaction with the acquirer, the status of a message or some action taken or required. Contact tech-support@emerchantpay.com for more details. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
partial_approval | string(4) | Optional, set to ’true’ if partial approval happened. Partially approved amount is then in the amount field. Check Partial Approvals for details |
sent_to_acquirer | string(255) | "true" or "false" |
Error Response
stdClass Object
(
[transaction_type] => partial_reversal
[status] => error
[mode] => live
[transaction_id] => TrxID_e5945004cc8de704629cdb0743e71896
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 410
[technical_message] => No approved preauthorization reference transaction found
[message] => Something went wrong, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:24:00.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 500
[currency] => USD
[sent_to_acquirer] => false
)
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>partial_reversal</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>TrxID_e5945004cc8de704629cdb0743e71896</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>410</code>
<technical_message>No approved preauthorization reference transaction found</technical_message>
<message>Something went wrong, please contact support!</message>
<timestamp>2025-01-16T10:24:00Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>500</amount>
<currency>USD</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
transaction_id | string(255) | Unique transaction id defined by merchant |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
sent_to_acquirer | string(255) | "true" or "false" |
Required vs Optional API params
There are some API params which can be configured as either optional or required on the terminal level. Contact the IT Support team at tech-support@emerchantpay.com if you wish to disable or enable some API params based on your business model and integration type. Note also that if all the billing address params are configured as optional, then the whole billing address XML tag can be dismissed and not sent in the API requests.
Name | Type | Description |
---|---|---|
customer_email | email address | By default, customer email is a required API param |
customer_phone | string(32) | By default, customer phone is an optional API param |
remote_ip | string(40) | By default, customer IP is a required API param |
first_name | string(255) | By default, customer first name is a required API param |
last_name | string(255) | By default, customer last name is a required API param |
address1 | string(255) | By default, primary address is a required API param. Cannot be configured as optional for account verification transaction type |
address2 | string(255) | By default, secondary address is an optional API param |
city | string(255) | By default, city is a required API param. Cannot be config- ured as optional for account verification transaction type |
zip_code | string | By default, zip code is a required API param. Cannot be con- figured as optional for account verification transaction type |
state | string(2) | By default, state is an optional API param (unless country is US or CA) |
country | string(2) | By default, country code is a required API param |
usage | string(255) | By default, usage will be configured as a required API param for SDD and P24, optional for the rest |
Transaction States
Transactions will have one of the following states. These will be returned by transaction responses, reconcile responses and will be shown in the browser interface
Status | Description |
---|---|
approved | Transaction was approved by the schemes and is successful. |
declined | Transaction was declined by the schemes or risk management. |
pending_async | An asynchronous transaction (3-D secure payment) has been initiated and is waiting for user input. Updates of this state will be sent to the notification url specified in request. |
pending_hold | An asynchronous transaction has been finalized by user but is waiting final update from provider. |
pending | The outcome of the transaction could not be determined, e.g. at a timeout situation. Transaction state will eventually change, so make a reconcile after a certain time frame. |
error | An error has occurred while negotiating with the schemes. |
refunded | Once an approved transaction is refunded the state changes to refunded. |
chargebacked | Once an approved transaction is chargebacked - the state changes to changebacked. Chargeback is the state of rejecting an accepted transaction (with funds transferred) by the cardholder or the issuer |
voided | Transaction was authorized, but later the merchant canceled it. |
chargeback_reversed | Once a chargebacked transaction is charged, the state changes to chargeback reversed. Chargeback has been canceled. |
represented | Once a chargebacked transaction is charged, the state changes to represented. Chargeback has been canceled. |
representment_reversed | Once a represented transaction is reversed, the state changes to representment reversed. |
second_chargebacked | Once a chargeback_reversed transaction is chargebacked the state changes to second chargebacked. |
pending_review | Transaction on hold, a manual review will be done |
partially_reversed | Relevant only for preauthorization transactions. Once partial amount (less than the full preauthorized amount) is returned to the customer, the transaction becomes partially reversed. |
Supported Card Brands
Card Brands are specific per acquirer. If you want to use a specific card brand you can contact tech-support@emerchantpay.com.
Supported card brands |
---|
Visa |
Master |
Intl Maestro |
Discover |
Diners |
AMEX |
JCB |
RuPay |
Elo |
Aura |
Hipercard |
Document ID Parameter
Document ID is consumer personal identification. It is different for every country and is described more specifically in the table below. Document ID is required for some of the acquirers, please contact the IT Support team at tech-support@emerchantpay.com for more information.
Country | Name | Type | Description |
---|---|---|---|
Argentina | document_id | string(255) | Consumer's Argentinian Identification Number(DNI or CUIT). Must be string between 7 to 9, or 11 digits. |
Brazil | document_id | string(255) | Consumer's Brazilian Identification Number(CPF or CNPJ). Must be string between 11 and 14 digits and to have full cpf validation. Example: 76484475687 |
Chile | document_id | string(255) | Consumer's Chilean Identification Number(CI/RUT). Must be string between 8 to 9 digits. |
Colombia | document_id | string(255) | Consumer's Colombian Identification Number(CC). Must be string between 6 to 10 digits. |
India | document_id | string(255) | Consumer's Indian PAN. Must be string with 10 alphanumeric letters. 5 letters, followed by 4 numbers, followed by 1 letter or number. Example: ABCDE1234F |
Mexico | document_id | string(255) | Consumer's Mexican Identification Number(CURP). Must be string between 10 and 18 digits. |
Paraguay | document_id | string(255) | Consumer's Paraguayan Identification Number(CI). Must be string between 5 and 20 digits. |
Peru | document_id | string(255) | Consumer's Peruvian Identification Number(DNI). Must be string between 8 and 9 digits. |
Turkey | document_id | string(255) | Consumer's Turkish Identification Number(T.C. Kimlik No.). Must be string between 5 and 20 digits. |
Uruguay | document_id | string(255) | Consumer's Uruguayan Identification Number(CI). Must be string between 6 and 8 digits. |
Business Attributes
Business attributes are groups of additional risk attributes which are in close relation with the merchant business category. Some/All of them can be required at our risk team's discretion and will be used for internal reporting only. These business attributes can be submitted with a standard card transaction on Processing API and WPF processing.
Business categories:
Segment | MCC |
---|---|
Airlines Air Carriers | |
Airlines, Air Carriers | 4511 |
Airlines | 3000 - 3302 |
Event Management | |
Consulting, Public Relations | 7392 |
Miscellaneous General Services | 7299 |
Theatrical Ticket Agencies | 7922 |
Direct Marketing - Other | 5969 |
Furniture | |
Furniture, Home Furnishings, and Equipment Stores, Except Appliances | 5712 |
Office and Commercial Furniture | 5021 |
Hotels and Real estate Rentals | |
Hotels/Motels/Inns/Resorts | 3501 - 3790 |
Real Estate Agents and Managers - Rentals | 6513 |
Lodging – Hotels, Motels, Resorts, Central Reservation Services (not elsewhere classified) | 7011 |
Timeshares | 7012 |
Car, plane and Boat rentals | |
Car Rental | 3351 - 3441 |
Taxicabs and Limousines | 4121 |
Bus Lines, Including Charters, Tour Buses | 4131 |
Boat Rentals and Leases | 4457 |
Transportation Services, (Not elsewhere classified) | 4789 |
Car Rental Companies | 7512 |
Truck and Utility Trailer Rentals | 7513 |
Motor Home and Recreational Vehicle Rentals | 7519 |
Cruise Lines | |
Cruise Lines | 4411 |
Travel Agencies | |
Travel Agencies | 4722 |
Package Tour Operators (For use in Germany only) | 4723 |
Direct Marketing - Travel-related Arrangement Services | 5962 |
Specific attributes for each business category can be found in the following table:
Attribute | Type | Description |
---|---|---|
Airlines Air Carriers | ||
flight_arrival_date | string | The date when the flight arrives in format dd-mm-yyyy |
flight_departure_date | string | The date when the flight departs in format dd-mm-yyyy |
airline_code | string | The code of Airline |
airline_flight_number | string | The flight number |
flight_ticket_number | string | The number of the flight ticket |
flight_origin_city | string | The origin city of the flight |
flight_destination_city | string | The destination city of the flight |
airline_tour_operator_name | string | The name of tour operator |
payment_type | string | The type of payment - can be either deposit or balance |
Event Management | ||
event_start_date | string | The date when event starts in format dd-mm-yyyy |
event_end_date | string | The date when event ends in format dd-mm-yyyy |
event_organizer_id | string | |
event_id | string | |
payment_type | string | The type of payment - can be either deposit or balance |
Furniture | ||
date_of_order | string | The date when order was placed in format dd-mm-yyyy |
delivery_date | string | Date of the expected delivery in format dd-mm-yyyy |
name_of_the_supplier | string | |
payment_type | string | The type of payment - can be either deposit or balance |
Hotels and Real estate rentals | ||
check_in_date | string | The data when the customer check-in in format dd-mm-yyyy |
check_out_date | string | The data when the customer check-out in format dd-mm-yyyy |
travel_agency_name | string | |
payment_type | string | The type of payment - can be either deposit or balance |
Car, Plane and Boat Rentals | ||
vehicle_pick_up_date | string | The date when customer takes the vehicle in format dd-mm-yyyy |
vehicle_return_date | string | The date when the customer returns the vehicle back in format dd-mm-yyyy |
supplier_name | string | The name of supplier/contractor |
payment_type | string | The type of payment - can be either deposit or balance |
Cruise Lines | ||
cruise_start_date | string | The date when cruise begins in format dd-mm-yyyy |
cruise_end_date | string | The date when cruise ends in format dd-mm-yyyy |
payment_type | string | The type of payment - can be either deposit or balance |
Travel Agencies | ||
arrival_date | string | The date of arrival in format dd-mm-yyyy |
departure_date | string | The date of departure in format dd-mm-yyyy |
carrier_code | string | The code of the carrier |
flight_number | string | The number of the flight |
ticket_number | string | The number of the ticket |
origin_city | string | The origin city |
destination_city | string | The destination city |
travel_agency | string | The name of the travel agency |
contractor_name | string | The name of the contractor |
atol_certificate | string | ATOL certificate number |
pick_up_date | string | Pick-up date in format dd-mm-yyyy |
return_date | string | Return date in format dd-mm-yyyy |
payment_type | string | The type of payment - can be either deposit or balance |
Transaction types with business attributes:
- authorize
- authorize3d
- capture
- sale
- sale3d
- init_recurring_sale
- init_recurring_sale3d
- recurring_sale
- trustly_sale
Recurring Advice
The recurring advice is an additional response code returned from the schemes. Specifies if the transaction can be retried in case of failure. Available codes:
Recurring Advice Code | Recurring Advice Text |
---|---|
01 | New Account Information available |
02 | Try again later |
03 | Do not try again |
04 | Token requirements not fulfilled for this token type |
21 | Recurring Payment Cancellation Service (the new fee applies with this one) |
22 | Merchant does not qualify for product code |
24 | Retry after 1 hour |
25 | Retry after 24 hours |
26 | Retry after 2 days |
27 | Retry after 4 days |
28 | Retry after 6 days |
29 | Retry after 8 days |
30 | Retry after 10 days |
31 | Retry later (max 15 attempts in 30 day period) |
40 | Consumer non-reloadable prepaid card |
41 | Consumer single-use virtual card number |
42 | Sanctions Scoring Service: Score Exceeds Applicable Threshold Value |
43 | Consumer multi-use Virtual Card Number (VCN) |
Tokenized e-commerce
Visa Synchronous 3 D Sv2 Scheme Tokenized Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Authorize3D');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('4012000000060085')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
->setSchemeTokenized('true')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
// MPI Synchronous 3DSv2
->setMpiEci('05')
->setMpiCavv('Y9Ri418AQCrkPp16sR+nMAACAAA=')
->setMpiProtocolVersion('2')
->setMpiProtocolSubVersion('2');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.Authorize3DRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
Authorize3DRequest request = new Authorize3DRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4012000000060085");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
request.setSchemeTokenized("true");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
// Mpi Synchronous V2
request.setMpiParams("{"eci"=>"05", "cavv"=>"Y9Ri418AQCrkPp16sR+nMAACAAA=", "protocol_version"=>"2", "protocol_sub_version"=>"2"}");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.authorize3d(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "4012000000060085",
"expiration_month": "12",
"expiration_year": 2026,
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"scheme_tokenized": "true",
"business_attributes": {
"event_start_date": "17-02-2025",
"event_end_date": "26-02-2025",
"event_organizer_id": "20192375",
"event_id": "1912"
},
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"mpi_params": {
"eci": "05",
"cavv": "Y9Ri418AQCrkPp16sR+nMAACAAA=",
"protocol_version": "2",
"protocol_sub_version": "2"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>authorize3d</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4012000000060085</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<scheme_tokenized>true</scheme_tokenized>
<business_attributes>
<event_start_date>17-02-2025</event_start_date>
<event_end_date>26-02-2025</event_end_date>
<event_organizer_id>20192375</event_organizer_id>
<event_id>1912</event_id>
</business_attributes>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<mpi_params>
<eci>05</eci>
<cavv>Y9Ri418AQCrkPp16sR+nMAACAAA=</cavv>
<protocol_version>2</protocol_version>
<protocol_sub_version>2</protocol_sub_version>
</mpi_params>
</payment_transaction>'
Master Synchronous 3 D Sv2 Scheme Tokenized Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Authorize3D');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('5555555555559997')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
->setSchemeTokenized('true')
// MPI Synchronous 3DSv2
->setMpiEci('02')
->setMpiCavv('AM1wRssmx0j1ABoxs1jIAoABFA==')
->setMpiProtocolVersion('2')
->setMpiProtocolSubVersion('2');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.Authorize3DRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
Authorize3DRequest request = new Authorize3DRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("5555555555559997");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
request.setSchemeTokenized("true");
// Mpi Synchronous V2
request.setMpiParams("{"eci"=>"02", "cavv"=>"AM1wRssmx0j1ABoxs1jIAoABFA==", "protocol_version"=>"2", "protocol_sub_version"=>"2"}");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.authorize3d(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "5555555555559997",
"expiration_month": "12",
"expiration_year": 2026,
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"business_attributes": {
"event_start_date": "17-02-2025",
"event_end_date": "26-02-2025",
"event_organizer_id": "20192375",
"event_id": "1912"
},
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"scheme_tokenized": "true",
"mpi_params": {
"eci": "02",
"cavv": "AM1wRssmx0j1ABoxs1jIAoABFA==",
"protocol_version": "2",
"protocol_sub_version": "2"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>authorize3d</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>5555555555559997</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<business_attributes>
<event_start_date>17-02-2025</event_start_date>
<event_end_date>26-02-2025</event_end_date>
<event_organizer_id>20192375</event_organizer_id>
<event_id>1912</event_id>
</business_attributes>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<scheme_tokenized>true</scheme_tokenized>
<mpi_params>
<eci>02</eci>
<cavv>AM1wRssmx0j1ABoxs1jIAoABFA==</cavv>
<protocol_version>2</protocol_version>
<protocol_sub_version>2</protocol_sub_version>
</mpi_params>
</payment_transaction>'
Successful Synchronous Response
stdClass Object
(
[transaction_type] => authorize3d
[status] => approved
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[authorization_code] => 345678
[retrieval_reference_number] => 016813015184
[response_code] => 00
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:24:00.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
[scheme_response_code] => 00
[scheme_transaction_identifier] => 019091214161031
[scheme_settlement_date] => 0117
[threeds] => {"eci"=>"05"}
)
<payment_response content=[
<transaction_type content=[authorize3d]>
<status content=[approved]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<authorization_code content=[345678]>
<retrieval_reference_number content=[016813015184]>
<response_code content=[00]>
<timestamp content=[2025-01-16T10:24:00Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[true]>
<scheme_response_code content=[00]>
<scheme_transaction_identifier content=[019091214161031]>
<scheme_settlement_date content=[0117]>
<threeds content=[{"eci"=>"05"}]>
]>
{
transaction_type: "authorize3d",
status: "approved",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
authorization_code: "345678",
retrieval_reference_number: "016813015184",
response_code: "00",
timestamp: "2025-01-16T10:24:00Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "true",
scheme_response_code: "00",
scheme_transaction_identifier: "019091214161031",
scheme_settlement_date: "0117",
threeds: "{"eci"=>"05"}",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>authorize3d</transaction_type>
<status>approved</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<authorization_code>345678</authorization_code>
<retrieval_reference_number>016813015184</retrieval_reference_number>
<response_code>00</response_code>
<timestamp>2025-01-16T10:24:00Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
<scheme_response_code>00</scheme_response_code>
<scheme_transaction_identifier>019091214161031</scheme_transaction_identifier>
<scheme_settlement_date>0117</scheme_settlement_date>
<threeds>
<eci>05</eci>
</threeds>
</payment_response>
E-commerce tokenization is a new way in the payment processing services that provides enhanced safety and convenience for all participants in the process. The technology is based on the replacement of sensitive payment data as PAN to DPAN (or token) and is known as Visa tokenization for Visa and Digital Secure Remote Payments (DSRP) for Mastercard.
In the case of using scheme tokenization with DPAN instead of FPAN, you need to add a special param scheme_tokenized
with a value of true
in the transaction API request.
There is also a clarification regarding the mpi_params
section (for 3D transactions only):
- The
directory_server_id
param is not required - The cryptogram is placed in the CAVV attribute inside the
mpi_params
and does not match any of the leading indicators for MasterCard Identity check.
On the right there are examples for Visa and Mastercard.
Scheme tokenized transactions are enabled on purpose, please contact Tech Support for more details.
Customer Identification Parameters
Customer Identification Parameters give additonal information to the acquirer about the customer of the payment.
Owner
Specifies if the document ID belongs to the sender or the receiver of the OCT.
Valid values |
---|
sender |
receiver |
Type
Specifies the type of the document ID.
Valid values |
---|
birth_date |
unspecified |
national |
passport_number |
driver_license |
tax |
company_registration_number |
proxy |
social_security_number |
alien_registration_number |
law_enforcement |
military |
travel |
phone_number |
Subtype
Specifies if the document ID is registered for business or individual usage.
Valid values |
---|
business |
individual |
Document ID
The document ID of the customer. See Document ID Parameter for more details.
In case the document_id
has a birth_date
type, the required format is yyyy-mm-dd
and must contain the valid birth date of the customer.
Issuing Country
The country that has issued the document ID and has to be a country code in ISO 3166.
Scheme Maximum Settlement Date
The Scheme Maximum Settlement Date is a date that the schemes authorities compute and return with authorization response messages indicating the final date an authorization could be captured. This date defines the authorization hold period. The feature can be used with all authorization and full financial messages for purchase and purchase return transactions. Currently, this field is only supported for VISA transactions. When merchants submit authorizations with Visa, Visa will compute and provide a final date by when an authorization must be captured. If the Scheme Maximum Settlement Date has not passed, the capture will be approved, otherwise the capture will be declined with an error. The card scheme will provide the Maximum Settlement Date for sale transactions as well. Furthermore, the system will return the “scheme_max_settlement_date” parameter for purchase transactions.
Reconcile
Reconcile can be used to retrieve data about a transaction. This can be useful if you want to retrieve information about a transaction whose status is timeout, which returned an error or has changed eg. has beed chargebacked.
Reconcile request are handled exactly like transaction requests via XML.
Single Transaction
The URL for single transaction reconciling is similar to the processing url:
https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/reconcile/TERMINAL-TOKEN
Reconcile By Unique Id Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('NonFinancial\Reconcile\Transaction');
$request = $genesis->request();
$request
->setUniqueId('44177a21403427eb96664a6d7e5d5d48');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.nonfinancial.reconcile.ReconcileRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
ReconcileRequest request = new ReconcileRequest();
request.setUniqueId("44177a21403427eb96664a6d7e5d5d48");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.reconcile(
{
"unique_id": "44177a21403427eb96664a6d7e5d5d48"
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/reconcile/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<reconcile>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
</reconcile>'
Reconcile By Arn Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('NonFinancial\Reconcile\Transaction');
$request = $genesis->request();
$request
->setArn('74537605248535042582882');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.nonfinancial.reconcile.ReconcileRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
ReconcileRequest request = new ReconcileRequest();
request.setArn("74537605248535042582882");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.reconcile(
{
"arn": "74537605248535042582882"
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/reconcile/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<reconcile>
<arn>74537605248535042582882</arn>
</reconcile>'
Reconcile By Transaction Id Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('NonFinancial\Reconcile\Transaction');
$request = $genesis->request();
$request
->setTransactionId('merchant-transaction-id-here');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.nonfinancial.reconcile.ReconcileRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
ReconcileRequest request = new ReconcileRequest();
request.setTransactionId("merchant-transaction-id-here");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.reconcile(
{
"transaction_id": "merchant-transaction-id-here"
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/reconcile/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<reconcile>
<transaction_id>merchant-transaction-id-here</transaction_id>
</reconcile>'
XML Request to reconcile:
Note that reconcile can be done via either unique_id, ARN or transaction_id
XML Response:
Response is a standard payment response like it would be returned by any transaction. It can have either state as shown in the states section.
Successful Sale Transaction Reconciliation Response
stdClass Object
(
[transaction_type] => sale
[status] => approved
[authorization_code] => 005645
[retrieval_reference_number] => 016813015184
[payment_account_reference] => Q1HJZ28RKA1EBL470G9XYG90R5D3E
[response_code] => 00
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[transaction_id] => 119643250547501c79d8295
[mode] => live
[timestamp] => 2025-01-16T10:24:00Z
[descriptor] => Descriptor one
[amount] => 9000
[currency] => USD
[card_brand] => visa
[card_number] => 420000...0000
[card_type] => CREDIT
[card_subtype] => CARD SUBTYPE
[card_issuing_bank] => Issuing Bank
[card_issuing_country] => Exact Issuing country
[bank_account_number] => Bank Account Number
[bank_identifier_code] => Bank Identifier Code
[sent_to_acquirer] => true
[arn] => 74537605259536043849425
[scheme_response_code] => 00
[scheme_transaction_link_id] => TLINKIDENTIFIER4521412
[scheme_max_settlement_date] => 2024-07-31
[scheme_authentication_data_quality] => true
[threeds] =>
[scheme_transaction_identifier] => 019091214161031
[scheme_settlement_date] => 0117
[reason_for_not_honoring_exemption] => 8A01
[sca_exemption_result] => 13
)
<payment_response content=[
<transaction_type content=[sale]>
<status content=[approved]>
<authorization_code content=[005645]>
<retrieval_reference_number content=[016813015184]>
<payment_account_reference content=[Q1HJZ28RKA1EBL470G9XYG90R5D3E]>
<response_code content=[00]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<transaction_id content=[119643250547501c79d8295]>
<mode content=[live]>
<timestamp content=[2025-01-16T10:24:00Z]>
<descriptor content=[Descriptor one]>
<amount content=[9000]>
<currency content=[USD]>
<card_brand content=[visa]>
<card_number content=[420000...0000]>
<card_type content=[CREDIT]>
<card_subtype content=[CARD SUBTYPE]>
<card_issuing_bank content=[Issuing Bank]>
<card_issuing_country content=[Exact Issuing country]>
<bank_account_number content=[Bank Account Number]>
<bank_identifier_code content=[Bank Identifier Code]>
<sent_to_acquirer content=[true]>
<arn content=[74537605259536043849425]>
<scheme_response_code content=[00]>
<scheme_transaction_link_id content=[TLINKIDENTIFIER4521412]>
<scheme_max_settlement_date content=[2024-07-31]>
<scheme_authentication_data_quality content=[true]>
<threeds content=[]>
<scheme_transaction_identifier content=[019091214161031]>
<scheme_settlement_date content=[0117]>
<reason_for_not_honoring_exemption content=[8A01]>
<sca_exemption_result content=[13]>
]>
{
transaction_type: "sale",
status: "approved",
authorization_code: "005645",
retrieval_reference_number: "016813015184",
payment_account_reference: "Q1HJZ28RKA1EBL470G9XYG90R5D3E",
response_code: "00",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
transaction_id: "119643250547501c79d8295",
mode: "live",
timestamp: "2025-01-16T10:24:00Z",
descriptor: "Descriptor one",
amount: "9000",
currency: "USD",
card_brand: "visa",
card_number: "420000...0000",
card_type: "CREDIT",
card_subtype: "CARD SUBTYPE",
card_issuing_bank: "Issuing Bank",
card_issuing_country: "Exact Issuing country",
bank_account_number: "Bank Account Number",
bank_identifier_code: "Bank Identifier Code",
sent_to_acquirer: "true",
arn: "74537605259536043849425",
scheme_response_code: "00",
scheme_transaction_link_id: "TLINKIDENTIFIER4521412",
scheme_max_settlement_date: "2024-07-31",
scheme_authentication_data_quality: "true",
threeds: "",
scheme_transaction_identifier: "019091214161031",
scheme_settlement_date: "0117",
reason_for_not_honoring_exemption: "8A01",
sca_exemption_result: "13",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>sale</transaction_type>
<status>approved</status>
<authorization_code>005645</authorization_code>
<retrieval_reference_number>016813015184</retrieval_reference_number>
<payment_account_reference>Q1HJZ28RKA1EBL470G9XYG90R5D3E</payment_account_reference>
<response_code>00</response_code>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<transaction_id>119643250547501c79d8295</transaction_id>
<mode>live</mode>
<timestamp>2025-01-16T10:24:00Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>9000</amount>
<currency>USD</currency>
<card_brand>visa</card_brand>
<card_number>420000...0000</card_number>
<card_type>CREDIT</card_type>
<card_subtype>CARD SUBTYPE</card_subtype>
<card_issuing_bank>Issuing Bank</card_issuing_bank>
<card_issuing_country>Exact Issuing country</card_issuing_country>
<bank_account_number>Bank Account Number</bank_account_number>
<bank_identifier_code>Bank Identifier Code</bank_identifier_code>
<sent_to_acquirer>true</sent_to_acquirer>
<arn>74537605259536043849425</arn>
<scheme_response_code>00</scheme_response_code>
<scheme_transaction_link_id>TLINKIDENTIFIER4521412</scheme_transaction_link_id>
<scheme_max_settlement_date>2024-07-31</scheme_max_settlement_date>
<scheme_authentication_data_quality>true</scheme_authentication_data_quality>
<payment_response>threeds</payment_response>
<scheme_transaction_identifier>019091214161031</scheme_transaction_identifier>
<scheme_settlement_date>0117</scheme_settlement_date>
<reason_for_not_honoring_exemption>8A01</reason_for_not_honoring_exemption>
<sca_exemption_result>13</sca_exemption_result>
</payment_response>
Successful Refund Transaction Reconciliation Response
stdClass Object
(
[transaction_type] => refund
[status] => approved
[authorization_code] => 005645
[retrieval_reference_number] => 016813015184
[payment_account_reference] => Q1HJZ28RKA1EBL470G9XYG90R5D3E
[response_code] => 00
[unique_id] => 5de39380bf7ac7e1fc31cbd7805dc0ec
[transaction_id] => 119643250547501c79d8295
[mode] => live
[timestamp] => 2025-01-16T10:24:00Z
[descriptor] => Descriptor one
[amount] => 9000
[currency] => USD
[card_brand] => visa
[card_number] => 420000...0000
[card_type] => CREDIT
[card_subtype] => CARD SUBTYPE
[card_issuing_bank] => Issuing Bank
[card_issuing_country] => Exact Issuing country
[bank_account_number] => Bank Account Number
[bank_identifier_code] => Bank Identifier Code
[sent_to_acquirer] => true
[arn] => 74537605259536043849425
[scheme_response_code] => 00
[scheme_transaction_link_id] => TLINKIDENTIFIER4521412
[scheme_max_settlement_date] => 2024-07-31
[scheme_authentication_data_quality] => true
[threeds] =>
[reference_transaction_unique_id] => 44177a21403427eb96664a6d7e5d5d48
[reason_for_not_honoring_exemption] => 8A01
[sca_exemption_result] => 13
)
<payment_response content=[
<transaction_type content=[refund]>
<status content=[approved]>
<authorization_code content=[005645]>
<retrieval_reference_number content=[016813015184]>
<payment_account_reference content=[Q1HJZ28RKA1EBL470G9XYG90R5D3E]>
<response_code content=[00]>
<unique_id content=[5de39380bf7ac7e1fc31cbd7805dc0ec]>
<transaction_id content=[119643250547501c79d8295]>
<mode content=[live]>
<timestamp content=[2025-01-16T10:24:00Z]>
<descriptor content=[Descriptor one]>
<amount content=[9000]>
<currency content=[USD]>
<card_brand content=[visa]>
<card_number content=[420000...0000]>
<card_type content=[CREDIT]>
<card_subtype content=[CARD SUBTYPE]>
<card_issuing_bank content=[Issuing Bank]>
<card_issuing_country content=[Exact Issuing country]>
<bank_account_number content=[Bank Account Number]>
<bank_identifier_code content=[Bank Identifier Code]>
<sent_to_acquirer content=[true]>
<arn content=[74537605259536043849425]>
<scheme_response_code content=[00]>
<scheme_transaction_link_id content=[TLINKIDENTIFIER4521412]>
<scheme_max_settlement_date content=[2024-07-31]>
<scheme_authentication_data_quality content=[true]>
<threeds content=[]>
<reference_transaction_unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<reason_for_not_honoring_exemption content=[8A01]>
<sca_exemption_result content=[13]>
]>
{
transaction_type: "refund",
status: "approved",
authorization_code: "005645",
retrieval_reference_number: "016813015184",
payment_account_reference: "Q1HJZ28RKA1EBL470G9XYG90R5D3E",
response_code: "00",
unique_id: "5de39380bf7ac7e1fc31cbd7805dc0ec",
transaction_id: "119643250547501c79d8295",
mode: "live",
timestamp: "2025-01-16T10:24:00Z",
descriptor: "Descriptor one",
amount: "9000",
currency: "USD",
card_brand: "visa",
card_number: "420000...0000",
card_type: "CREDIT",
card_subtype: "CARD SUBTYPE",
card_issuing_bank: "Issuing Bank",
card_issuing_country: "Exact Issuing country",
bank_account_number: "Bank Account Number",
bank_identifier_code: "Bank Identifier Code",
sent_to_acquirer: "true",
arn: "74537605259536043849425",
scheme_response_code: "00",
scheme_transaction_link_id: "TLINKIDENTIFIER4521412",
scheme_max_settlement_date: "2024-07-31",
scheme_authentication_data_quality: "true",
threeds: "",
reference_transaction_unique_id: "44177a21403427eb96664a6d7e5d5d48",
reason_for_not_honoring_exemption: "8A01",
sca_exemption_result: "13",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>refund</transaction_type>
<status>approved</status>
<authorization_code>005645</authorization_code>
<retrieval_reference_number>016813015184</retrieval_reference_number>
<payment_account_reference>Q1HJZ28RKA1EBL470G9XYG90R5D3E</payment_account_reference>
<response_code>00</response_code>
<unique_id>5de39380bf7ac7e1fc31cbd7805dc0ec</unique_id>
<transaction_id>119643250547501c79d8295</transaction_id>
<mode>live</mode>
<timestamp>2025-01-16T10:24:00Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>9000</amount>
<currency>USD</currency>
<card_brand>visa</card_brand>
<card_number>420000...0000</card_number>
<card_type>CREDIT</card_type>
<card_subtype>CARD SUBTYPE</card_subtype>
<card_issuing_bank>Issuing Bank</card_issuing_bank>
<card_issuing_country>Exact Issuing country</card_issuing_country>
<bank_account_number>Bank Account Number</bank_account_number>
<bank_identifier_code>Bank Identifier Code</bank_identifier_code>
<sent_to_acquirer>true</sent_to_acquirer>
<arn>74537605259536043849425</arn>
<scheme_response_code>00</scheme_response_code>
<scheme_transaction_link_id>TLINKIDENTIFIER4521412</scheme_transaction_link_id>
<scheme_max_settlement_date>2024-07-31</scheme_max_settlement_date>
<scheme_authentication_data_quality>true</scheme_authentication_data_quality>
<payment_response>threeds</payment_response>
<reference_transaction_unique_id>44177a21403427eb96664a6d7e5d5d48</reference_transaction_unique_id>
<reason_for_not_honoring_exemption>8A01</reason_for_not_honoring_exemption>
<sca_exemption_result>13</sca_exemption_result>
</payment_response>
Successful Sale3d 3 D Sv2 Transaction Reconciliation Response
stdClass Object
(
[transaction_type] => sale3d
[status] => approved
[authorization_code] => 005645
[retrieval_reference_number] => 016813015184
[payment_account_reference] => Q1HJZ28RKA1EBL470G9XYG90R5D3E
[response_code] => 00
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[transaction_id] => 119643250547501c79d8295
[mode] => live
[timestamp] => 2025-01-16T10:24:00Z
[descriptor] => Descriptor one
[amount] => 9000
[currency] => USD
[card_brand] => visa
[card_number] => 420000...0000
[card_type] => CREDIT
[card_subtype] => CARD SUBTYPE
[card_issuing_bank] => Issuing Bank
[card_issuing_country] => Exact Issuing country
[bank_account_number] => Bank Account Number
[bank_identifier_code] => Bank Identifier Code
[sent_to_acquirer] => true
[arn] => 74537605259536043849425
[scheme_response_code] => 00
[scheme_transaction_link_id] => TLINKIDENTIFIER4521412
[scheme_max_settlement_date] => 2024-07-31
[scheme_authentication_data_quality] => true
[threeds] => {:authentication_flow=>"frictionless", :threeds_method=>{:status=>"completed"}, :protocol=>{:target_version=>"2", :concrete_version=>"2", :sub_version=>"2"}, :eci=>"05"}
[threeds] => {:authentication_flow=>"frictionless", :threeds_method=>{:status=>"completed"}, :protocol=>{:target_version=>"2", :concrete_version=>"2", :sub_version=>"2"}, :eci=>"05"}
[reason_for_not_honoring_exemption] => 8A01
[sca_exemption_result] => 13
)
<payment_response content=[
<transaction_type content=[sale3d]>
<status content=[approved]>
<authorization_code content=[005645]>
<retrieval_reference_number content=[016813015184]>
<payment_account_reference content=[Q1HJZ28RKA1EBL470G9XYG90R5D3E]>
<response_code content=[00]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<transaction_id content=[119643250547501c79d8295]>
<mode content=[live]>
<timestamp content=[2025-01-16T10:24:00Z]>
<descriptor content=[Descriptor one]>
<amount content=[9000]>
<currency content=[USD]>
<card_brand content=[visa]>
<card_number content=[420000...0000]>
<card_type content=[CREDIT]>
<card_subtype content=[CARD SUBTYPE]>
<card_issuing_bank content=[Issuing Bank]>
<card_issuing_country content=[Exact Issuing country]>
<bank_account_number content=[Bank Account Number]>
<bank_identifier_code content=[Bank Identifier Code]>
<sent_to_acquirer content=[true]>
<arn content=[74537605259536043849425]>
<scheme_response_code content=[00]>
<scheme_transaction_link_id content=[TLINKIDENTIFIER4521412]>
<scheme_max_settlement_date content=[2024-07-31]>
<scheme_authentication_data_quality content=[true]>
<threeds content=[{:authentication_flow=>"frictionless", :threeds_method=>{:status=>"completed"}, :protocol=>{:target_version=>"2", :concrete_version=>"2", :sub_version=>"2"}, :eci=>"05"}]>
<threeds content=[{:authentication_flow=>"frictionless", :threeds_method=>{:status=>"completed"}, :protocol=>{:target_version=>"2", :concrete_version=>"2", :sub_version=>"2"}, :eci=>"05"}]>
<reason_for_not_honoring_exemption content=[8A01]>
<sca_exemption_result content=[13]>
]>
{
transaction_type: "sale3d",
status: "approved",
authorization_code: "005645",
retrieval_reference_number: "016813015184",
payment_account_reference: "Q1HJZ28RKA1EBL470G9XYG90R5D3E",
response_code: "00",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
transaction_id: "119643250547501c79d8295",
mode: "live",
timestamp: "2025-01-16T10:24:00Z",
descriptor: "Descriptor one",
amount: "9000",
currency: "USD",
card_brand: "visa",
card_number: "420000...0000",
card_type: "CREDIT",
card_subtype: "CARD SUBTYPE",
card_issuing_bank: "Issuing Bank",
card_issuing_country: "Exact Issuing country",
bank_account_number: "Bank Account Number",
bank_identifier_code: "Bank Identifier Code",
sent_to_acquirer: "true",
arn: "74537605259536043849425",
scheme_response_code: "00",
scheme_transaction_link_id: "TLINKIDENTIFIER4521412",
scheme_max_settlement_date: "2024-07-31",
scheme_authentication_data_quality: "true",
threeds: "{:authentication_flow=>"frictionless", :threeds_method=>{:status=>"completed"}, :protocol=>{:target_version=>"2", :concrete_version=>"2", :sub_version=>"2"}, :eci=>"05"}",
threeds: "{:authentication_flow=>"frictionless", :threeds_method=>{:status=>"completed"}, :protocol=>{:target_version=>"2", :concrete_version=>"2", :sub_version=>"2"}, :eci=>"05"}",
reason_for_not_honoring_exemption: "8A01",
sca_exemption_result: "13",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>sale3d</transaction_type>
<status>approved</status>
<authorization_code>005645</authorization_code>
<retrieval_reference_number>016813015184</retrieval_reference_number>
<payment_account_reference>Q1HJZ28RKA1EBL470G9XYG90R5D3E</payment_account_reference>
<response_code>00</response_code>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<transaction_id>119643250547501c79d8295</transaction_id>
<mode>live</mode>
<timestamp>2025-01-16T10:24:00Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>9000</amount>
<currency>USD</currency>
<card_brand>visa</card_brand>
<card_number>420000...0000</card_number>
<card_type>CREDIT</card_type>
<card_subtype>CARD SUBTYPE</card_subtype>
<card_issuing_bank>Issuing Bank</card_issuing_bank>
<card_issuing_country>Exact Issuing country</card_issuing_country>
<bank_account_number>Bank Account Number</bank_account_number>
<bank_identifier_code>Bank Identifier Code</bank_identifier_code>
<sent_to_acquirer>true</sent_to_acquirer>
<arn>74537605259536043849425</arn>
<scheme_response_code>00</scheme_response_code>
<scheme_transaction_link_id>TLINKIDENTIFIER4521412</scheme_transaction_link_id>
<scheme_max_settlement_date>2024-07-31</scheme_max_settlement_date>
<scheme_authentication_data_quality>true</scheme_authentication_data_quality>
<threeds>
<authentication_flow>frictionless</authentication_flow>
<threeds_method>
<status>completed</status>
</threeds_method>
<protocol>
<target_version>2</target_version>
<concrete_version>2</concrete_version>
<sub_version>2</sub_version>
</protocol>
<eci>05</eci>
</threeds>
<reason_for_not_honoring_exemption>8A01</reason_for_not_honoring_exemption>
<sca_exemption_result>13</sca_exemption_result>
</payment_response>
Successful Authorize Transaction Reconciliation Response
stdClass Object
(
[transaction_type] => authorize
[status] => approved
[authorization_code] => 005645
[retrieval_reference_number] => 016813015184
[payment_account_reference] => Q1HJZ28RKA1EBL470G9XYG90R5D3E
[response_code] => 00
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[transaction_id] => 119643250547501c79d8295
[mode] => live
[timestamp] => 2025-01-16T10:24:01Z
[descriptor] => Descriptor one
[amount] => 500
[currency] => USD
[card_brand] => visa
[card_number] => 420000...0000
[card_type] => CREDIT
[card_subtype] => CARD SUBTYPE
[card_issuing_bank] => Issuing Bank
[card_issuing_country] => Exact Issuing country
[bank_account_number] => Bank Account Number
[bank_identifier_code] => Bank Identifier Code
[sent_to_acquirer] => true
[arn] => 74537605259536043849425
[scheme_response_code] => 00
[scheme_transaction_link_id] => TLINKIDENTIFIER4521412
[scheme_max_settlement_date] => 2024-07-31
[scheme_authentication_data_quality] => true
[threeds] =>
[captured] => false
[capturable_amount] => 500
[scheme_transaction_identifier] => 019091214161031
[scheme_settlement_date] => 0117
[reason_for_not_honoring_exemption] => 8A01
[sca_exemption_result] => 13
)
<payment_response content=[
<transaction_type content=[authorize]>
<status content=[approved]>
<authorization_code content=[005645]>
<retrieval_reference_number content=[016813015184]>
<payment_account_reference content=[Q1HJZ28RKA1EBL470G9XYG90R5D3E]>
<response_code content=[00]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<transaction_id content=[119643250547501c79d8295]>
<mode content=[live]>
<timestamp content=[2025-01-16T10:24:01Z]>
<descriptor content=[Descriptor one]>
<amount content=[500]>
<currency content=[USD]>
<card_brand content=[visa]>
<card_number content=[420000...0000]>
<card_type content=[CREDIT]>
<card_subtype content=[CARD SUBTYPE]>
<card_issuing_bank content=[Issuing Bank]>
<card_issuing_country content=[Exact Issuing country]>
<bank_account_number content=[Bank Account Number]>
<bank_identifier_code content=[Bank Identifier Code]>
<sent_to_acquirer content=[true]>
<arn content=[74537605259536043849425]>
<scheme_response_code content=[00]>
<scheme_transaction_link_id content=[TLINKIDENTIFIER4521412]>
<scheme_max_settlement_date content=[2024-07-31]>
<scheme_authentication_data_quality content=[true]>
<threeds content=[]>
<captured content=[false]>
<capturable_amount content=[500]>
<scheme_transaction_identifier content=[019091214161031]>
<scheme_settlement_date content=[0117]>
<reason_for_not_honoring_exemption content=[8A01]>
<sca_exemption_result content=[13]>
]>
{
transaction_type: "authorize",
status: "approved",
authorization_code: "005645",
retrieval_reference_number: "016813015184",
payment_account_reference: "Q1HJZ28RKA1EBL470G9XYG90R5D3E",
response_code: "00",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
transaction_id: "119643250547501c79d8295",
mode: "live",
timestamp: "2025-01-16T10:24:01Z",
descriptor: "Descriptor one",
amount: "500",
currency: "USD",
card_brand: "visa",
card_number: "420000...0000",
card_type: "CREDIT",
card_subtype: "CARD SUBTYPE",
card_issuing_bank: "Issuing Bank",
card_issuing_country: "Exact Issuing country",
bank_account_number: "Bank Account Number",
bank_identifier_code: "Bank Identifier Code",
sent_to_acquirer: "true",
arn: "74537605259536043849425",
scheme_response_code: "00",
scheme_transaction_link_id: "TLINKIDENTIFIER4521412",
scheme_max_settlement_date: "2024-07-31",
scheme_authentication_data_quality: "true",
threeds: "",
captured: "false",
capturable_amount: "500",
scheme_transaction_identifier: "019091214161031",
scheme_settlement_date: "0117",
reason_for_not_honoring_exemption: "8A01",
sca_exemption_result: "13",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>authorize</transaction_type>
<status>approved</status>
<authorization_code>005645</authorization_code>
<retrieval_reference_number>016813015184</retrieval_reference_number>
<payment_account_reference>Q1HJZ28RKA1EBL470G9XYG90R5D3E</payment_account_reference>
<response_code>00</response_code>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<transaction_id>119643250547501c79d8295</transaction_id>
<mode>live</mode>
<timestamp>2025-01-16T10:24:01Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>500</amount>
<currency>USD</currency>
<card_brand>visa</card_brand>
<card_number>420000...0000</card_number>
<card_type>CREDIT</card_type>
<card_subtype>CARD SUBTYPE</card_subtype>
<card_issuing_bank>Issuing Bank</card_issuing_bank>
<card_issuing_country>Exact Issuing country</card_issuing_country>
<bank_account_number>Bank Account Number</bank_account_number>
<bank_identifier_code>Bank Identifier Code</bank_identifier_code>
<sent_to_acquirer>true</sent_to_acquirer>
<arn>74537605259536043849425</arn>
<scheme_response_code>00</scheme_response_code>
<scheme_transaction_link_id>TLINKIDENTIFIER4521412</scheme_transaction_link_id>
<scheme_max_settlement_date>2024-07-31</scheme_max_settlement_date>
<scheme_authentication_data_quality>true</scheme_authentication_data_quality>
<payment_response>threeds</payment_response>
<captured>false</captured>
<capturable_amount>500</capturable_amount>
<scheme_transaction_identifier>019091214161031</scheme_transaction_identifier>
<scheme_settlement_date>0117</scheme_settlement_date>
<reason_for_not_honoring_exemption>8A01</reason_for_not_honoring_exemption>
<sca_exemption_result>13</sca_exemption_result>
</payment_response>
Successful Transaction Reconciliation Response with funds status attribute
<?xml version='1.0' encoding='UTF-8'?>
<payment_response>
<transaction_type>aura</transaction_type>
<status>approved</status>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<transaction_id>119643250547501c79d8295</transaction_id>
<code>940</code>
<mode>live</mode>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<timestamp>2020-11-03T07:25:10Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>50</amount>
<currency>USD</currency>
<funds_status>SUCCEEDED</funds_status>
<account_holder>Name+Surname</account_holder>
</payment_response>
Declined Transaction Reconciliation Response
<?xml version='1.0' encoding='UTF-8'?>
<payment_response>
<transaction_type>sale3d</transaction_type>
<status>declined</status>
<exemption>low_risk</exemption>
<sca_exemption_result>23</sca_exemption_result>
<cvv_result_code>N</cvv_result_code>
<retrieval_reference_number>433524286054</retrieval_reference_number>
<scheme_response_code>N7</scheme_response_code>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<transaction_id>119643250547501c79d8295</transaction_id>
<response_code>N7</response_code>
<code>340</code>
<technical_message>CVV2 Failure</technical_message>
<message>Please check input data for errors!</message>
<mode>live</mode>
<timestamp>2020-11-03T07:25:10Z</timestamp>
<descriptor>eMPPay.com *eMPPay</descriptor>
<amount>100</amount>
<currency>EUR</currency>
<threeds>
<eci>06</eci>
</threeds>
<sent_to_acquirer>true</sent_to_acquirer>
<card_brand>visa</card_brand>
<card_number>479687...8062</card_number>
<card_type>DEBIT</card_type>
<card_subtype>BUSINESS</card_subtype>
<card_issuing_bank>DSK BANK PLC</card_issuing_bank>
<card_issuing_country>bulgaria</card_issuing_country>
<card_holder>John Doe</card_holder>
<expiration_year>2033</expiration_year>
<expiration_month>8</expiration_month>
<scheme_transaction_identifier>119643250547501c79d8295</scheme_transaction_identifier>
</payment_response>
Preauthorization
Name | Type | Description |
---|---|---|
preauthorization | "true" | Preauthorization flag |
preauthorization_expires_at | string | Preauthorization expiration date time in ISO 8601 Combined date and time, e.g. 2007-08-30T17:46:11Z |
preauthorization_total_amount | integer | Total preauthorization amount (initial + topup amount) |
capturable_amount | integer | The total amount that can be captured |
captured_amount | integer | The total captured amount |
reversed_amount | integer | The total reversed amount |
reversible_amount | integer | The total reversible amount |
reason_for_not_honoring_exemption | string | Reason for not honoring exemption. Check SCA Reason For Not Honoring Exemption Values. |
sca_exemption_result | string | SCA exemption result. Check SCA Exemption Result Values. |
Successful Preauthorization Reconciliation Response
stdClass Object
(
[transaction_type] => authorize
[status] => approved
[authorization_code] => 005645
[retrieval_reference_number] => 016813015184
[payment_account_reference] => 50019P9LBXOLHN9G7QMU5VN520YSY
[response_code] => 00
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[transaction_id] => 119643250547501c79d8295
[mode] => live
[timestamp] => 2025-01-16T10:24:01Z
[descriptor] => Descriptor one
[amount] => 5000
[currency] => USD
[card_brand] => master
[card_number] => 555555...4444
[card_type] => CREDIT
[card_subtype] => CARD SUBTYPE
[card_issuing_bank] => Issuing Bank
[card_issuing_country] => Exact Issuing country
[bank_account_number] => Bank Account Number
[bank_identifier_code] => Bank Identifier Code
[sent_to_acquirer] => true
[arn] => 74537605259536043849425
[scheme_response_code] => 00
[scheme_transaction_link_id] => TLINKIDENTIFIER4521412
[scheme_max_settlement_date] => 2024-07-31
[scheme_authentication_data_quality] => true
[threeds] =>
[preauthorization] => true
[preauthorization_expires_at] => 2025-02-16T10:24:01+00:00
[preauthorization_total_amount] => 10000
[captured] => false
[capturable_amount] => 8000
[captured_amount] => 0
[reversed_amount] => 2000
[reversible_amount] => 8000
[reason_for_not_honoring_exemption] => 8A01
[sca_exemption_result] => 13
[payment_account_reference] => 50019P9LBXOLHN9G7QMU5VN520YSY
)
<payment_response content=[
<transaction_type content=[authorize]>
<status content=[approved]>
<authorization_code content=[005645]>
<retrieval_reference_number content=[016813015184]>
<payment_account_reference content=[50019P9LBXOLHN9G7QMU5VN520YSY]>
<response_code content=[00]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<transaction_id content=[119643250547501c79d8295]>
<mode content=[live]>
<timestamp content=[2025-01-16T10:24:01Z]>
<descriptor content=[Descriptor one]>
<amount content=[5000]>
<currency content=[USD]>
<card_brand content=[master]>
<card_number content=[555555...4444]>
<card_type content=[CREDIT]>
<card_subtype content=[CARD SUBTYPE]>
<card_issuing_bank content=[Issuing Bank]>
<card_issuing_country content=[Exact Issuing country]>
<bank_account_number content=[Bank Account Number]>
<bank_identifier_code content=[Bank Identifier Code]>
<sent_to_acquirer content=[true]>
<arn content=[74537605259536043849425]>
<scheme_response_code content=[00]>
<scheme_transaction_link_id content=[TLINKIDENTIFIER4521412]>
<scheme_max_settlement_date content=[2024-07-31]>
<scheme_authentication_data_quality content=[true]>
<threeds content=[]>
<preauthorization content=[true]>
<preauthorization_expires_at content=[2025-02-16T10:24:01+00:00]>
<preauthorization_total_amount content=[10000]>
<captured content=[false]>
<capturable_amount content=[8000]>
<captured_amount content=[0]>
<reversed_amount content=[2000]>
<reversible_amount content=[8000]>
<reason_for_not_honoring_exemption content=[8A01]>
<sca_exemption_result content=[13]>
<payment_account_reference content=[50019P9LBXOLHN9G7QMU5VN520YSY]>
]>
{
transaction_type: "authorize",
status: "approved",
authorization_code: "005645",
retrieval_reference_number: "016813015184",
payment_account_reference: "50019P9LBXOLHN9G7QMU5VN520YSY",
response_code: "00",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
transaction_id: "119643250547501c79d8295",
mode: "live",
timestamp: "2025-01-16T10:24:01Z",
descriptor: "Descriptor one",
amount: "5000",
currency: "USD",
card_brand: "master",
card_number: "555555...4444",
card_type: "CREDIT",
card_subtype: "CARD SUBTYPE",
card_issuing_bank: "Issuing Bank",
card_issuing_country: "Exact Issuing country",
bank_account_number: "Bank Account Number",
bank_identifier_code: "Bank Identifier Code",
sent_to_acquirer: "true",
arn: "74537605259536043849425",
scheme_response_code: "00",
scheme_transaction_link_id: "TLINKIDENTIFIER4521412",
scheme_max_settlement_date: "2024-07-31",
scheme_authentication_data_quality: "true",
threeds: "",
preauthorization: "true",
preauthorization_expires_at: "2025-02-16T10:24:01+00:00",
preauthorization_total_amount: "10000",
captured: "false",
capturable_amount: "8000",
captured_amount: "0",
reversed_amount: "2000",
reversible_amount: "8000",
reason_for_not_honoring_exemption: "8A01",
sca_exemption_result: "13",
payment_account_reference: "50019P9LBXOLHN9G7QMU5VN520YSY",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>authorize</transaction_type>
<status>approved</status>
<authorization_code>005645</authorization_code>
<retrieval_reference_number>016813015184</retrieval_reference_number>
<payment_account_reference>50019P9LBXOLHN9G7QMU5VN520YSY</payment_account_reference>
<response_code>00</response_code>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<transaction_id>119643250547501c79d8295</transaction_id>
<mode>live</mode>
<timestamp>2025-01-16T10:24:01Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>5000</amount>
<currency>USD</currency>
<card_brand>master</card_brand>
<card_number>555555...4444</card_number>
<card_type>CREDIT</card_type>
<card_subtype>CARD SUBTYPE</card_subtype>
<card_issuing_bank>Issuing Bank</card_issuing_bank>
<card_issuing_country>Exact Issuing country</card_issuing_country>
<bank_account_number>Bank Account Number</bank_account_number>
<bank_identifier_code>Bank Identifier Code</bank_identifier_code>
<sent_to_acquirer>true</sent_to_acquirer>
<arn>74537605259536043849425</arn>
<scheme_response_code>00</scheme_response_code>
<scheme_transaction_link_id>TLINKIDENTIFIER4521412</scheme_transaction_link_id>
<scheme_max_settlement_date>2024-07-31</scheme_max_settlement_date>
<scheme_authentication_data_quality>true</scheme_authentication_data_quality>
<payment_response>threeds</payment_response>
<preauthorization>true</preauthorization>
<preauthorization_expires_at>2025-02-16T10:24:01+00:00</preauthorization_expires_at>
<preauthorization_total_amount>10000</preauthorization_total_amount>
<captured>false</captured>
<capturable_amount>8000</capturable_amount>
<captured_amount>0</captured_amount>
<reversed_amount>2000</reversed_amount>
<reversible_amount>8000</reversible_amount>
<reason_for_not_honoring_exemption>8A01</reason_for_not_honoring_exemption>
<sca_exemption_result>13</sca_exemption_result>
</payment_response>
By date range
Date range based reconciliation allows you to fetch information for all payment transactions from a terminal within a given date range. The response is paginated, each request will return 100 entries max.
The URL for date range reconciling is:
https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/reconcile/by_date/TERMINAL-TOKEN
Reconcile By Date Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('NonFinancial\Reconcile\DateRange');
$request = $genesis->request();
$request
->setStartDate('2014-01-01 09:20:00')
->setEndDate('2014-01-31 21:30:00')
->setPage('2');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.nonfinancial.reconcile.ReconcileByDate;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
ReconcileByDate request = new ReconcileByDate();
request.setStartDate("2014-01-01 09:20:00");
request.setEndDate("2014-01-31 21:30:00");
request.setPage("2");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.reconcile_by_date(
{
"start_date": "2014-01-01 09:20:00",
"end_date": "2014-01-31 21:30:00",
"page": 2
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/reconcile/by_date/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<reconcile>
<start_date>2014-01-01 09:20:00</start_date>
<end_date>2014-01-31 21:30:00</end_date>
<page>2</page>
</reconcile>'
Parameter | Required | Format | Description |
---|---|---|---|
start_date | required | yyyy-mm-dd hh:mm:ss | start of the requested date range (time is optional) |
end_date | optional | yyyy-mm-dd hh:mm:ss | end of the requested date range (time is optional) |
page | optional | integer the page within the paginated result, defaults to 1 |
Response:
The attributes in the root node payment responses include information about the pagination of the response.
<?xml version="1.0" encoding="UTF-8"?>
<payment_responses per_page="100" page="2" total_count="19" pages_count="7">
<payment_response>
<transaction_type>sale</transaction_type>
<status>approved</status>
<authorization_code>005645</authorization_code>
<scheme_response_code>00</scheme_response_code>
<response_code>00</response_code>
<unique_id>130319cfb3bf65ff3c4a4045487b174f</unique_id>
<transaction_id>EFBFBC7D-82CD-4375-9A69-15F19C88A134</transaction_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<mode>live</mode>
<timestamp>2014-01-03T15:04:00Z</timestamp>
<descriptor>descriptor one</descriptor>
<amount>500</amount>
<currency>USD</currency>
<card_brand>visa</card_brand>
<card_number>420000...0000</card_number>
<card_holder>John Doe</card_holder>
<expiration_year>2020</expiration_year>
<expiration_month>2</expiration_month>
<sent_to_acquirer>true</sent_to_acquirer>
<reason_for_not_honoring_exemption>8A01</reason_for_not_honoring_exemption>
<sca_exemption_result>13</sca_exemption_result>
</payment_response>
<payment_response>
<transaction_type>sale</transaction_type>
<status>approved</status>
<authorization_code>638745</authorization_code>
<scheme_response_code>00</scheme_response_code>
<response_code>00</response_code>
<unique_id>130319cfb3bf65ff3c4a4045487b173f</unique_id>
<transaction_id>BBD7945B-BE57-4A14-A7FB-47F7AE928D95</transaction_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<mode>live</mode>
<timestamp>2014-01-05T15:04:00Z</timestamp>
<descriptor>descriptor one</descriptor>
<amount>500</amount>
<currency>USD</currency>
<card_brand>visa</card_brand>
<card_number>420000...0000</card_number>
<card_holder>John Doe</card_holder>
<expiration_year>2020</expiration_year>
<expiration_month>2</expiration_month>
<sent_to_acquirer>true</sent_to_acquirer>
<reason_for_not_honoring_exemption>8A01</reason_for_not_honoring_exemption>
<sca_exemption_result>13</sca_exemption_result>
</payment_response>
<payment_response>
<transaction_type>sale</transaction_type>
<status>approved</status>
<authorization_code>226534</authorization_code>
<scheme_response_code>00</scheme_response_code>
<response_code>00</response_code>
<unique_id>1e8a6f09253eb8b4f8c84c0d8803713e</unique_id>
<transaction_id>_5041_2013041012_22_10_545</transaction_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<mode>live</mode>
<timestamp>2013-01-09T10:22:13Z</timestamp>
<descriptor>test_descriptor</descriptor>
<amount>50422</amount>
<currency>EUR</currency>
<card_brand>visa</card_brand>
<card_number>420000...0000</card_number>
<card_holder>John Doe</card_holder>
<expiration_year>2020</expiration_year>
<expiration_month>2</expiration_month>
<sent_to_acquirer>true</sent_to_acquirer>
<reason_for_not_honoring_exemption>8A01</reason_for_not_honoring_exemption>
<sca_exemption_result>13</sca_exemption_result>
</payment_response>
<payment_response>
<transaction_type>sale3d</transaction_type>
<status>pending_async</status>
<unique_id>5dbdb4c677ee16b8fb1e43483164be2c</unique_id>
<transaction_id>_6547_2013041012_23_08_470</transaction_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<redirect_url>https://staging.gate.emerchantpay.net/redirect/to_acquirer/5dbdb4c677</redirect_url>
<mode>live</mode>
<timestamp>2014-01-10T10:23:10Z</timestamp>
<descriptor>test_descriptor</descriptor>
<amount>100</amount>
<currency>EUR</currency>
<card_brand>visa</card_brand>
<card_number>471110...0000</card_number>
<card_holder>John Doe</card_holder>
<expiration_year>2020</expiration_year>
<expiration_month>2</expiration_month>
<sent_to_acquirer>true</sent_to_acquirer>
<reason_for_not_honoring_exemption>8A01</reason_for_not_honoring_exemption>
<sca_exemption_result>13</sca_exemption_result>
</payment_response>
<payment_response>
<transaction_type>refund</transaction_type>
<status>approved</status>
<authorization_code>005645</authorization_code>
<scheme_response_code>00</scheme_response_code>
<response_code>00</response_code>
<unique_id>44177a21403427eb96664a6d7e5d5d49</unique_id>
<transaction_id>119643250547501c79d8296</transaction_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<mode>test</mode>
<timestamp>2014-01-30T14:21:48Z</timestamp>
<descriptor>descriptor one</descriptor>
<amount>9000</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
<reference_transaction_unique_id>44177a21403427eb96664a6d7e5d5d48</reference_transaction_unique_id>
<reason_for_not_honoring_exemption>8A01</reason_for_not_honoring_exemption>
<sca_exemption_result>13</sca_exemption_result>
</payment_response>
...
</payment_responses>
Name | Type | Description |
---|---|---|
@per_page | integer | number of entries per page |
@page | integer | the current page |
@total_count | integer | total number of all entries |
@pages_count | integer | total number of pages |
Payment Authorizations
Payment Authorizations API
The Payment Authorizations API can be used to retrieve data about payment authorizations.
Payment Authorizations can be retrieved by date
By date range
Date range based retrieval allows you to fetch information for all payment authorizations for a given merchant within a given date range. Date range searches for payment authorizations by their creation date. The response is paginated, each request will return 100 entries max.
The URLs for date range payment authorizations retrieval are:
Production:
https://gate.emerchantpay.net/payment_authorizations/by_date
Staging (for integration):
https://staging.gate.emerchantpay.net/payment_authorizations/by_date
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.gate.emerchantpay.net/payment_authorizations/by_date \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_authorization_request>
<start_date>2014-01-01</start_date>
<end_date>2014-01-31</end_date>
<auth_start_date>2014-01-01</auth_start_date>
<auth_end_date>2014-01-31</auth_end_date>
<externally_processed>external</externally_processed>
<processing_type>all</processing_type>
<page>1</page>
</payment_authorization_request>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
start_date | required* | yyyy-mm-dd | start of the requested date range |
end_date | optional | yyyy-mm-dd | end of the requested date range |
auth_start_date | required* | yyyy-mm-dd | start of the requested auth date range |
auth_end_date | optional | yyyy-mm-dd | end of the requested auth date range |
page | optional | integer | the page within the paginated result, defaults to 1 |
per_page | optional | integer | Number of entities on page, defaults to 100 |
externally_processed | optional | string(255) | Filters transactions by being externally processed: or being native to Genesis. Possible values include 'genesis', 'external', and 'all'. If flag not supplied, it defaults to 'genesis' |
processing_type | optional | string(255) | Filters transactions by being card present or card not present. Possible values include 'card_present', 'card_not_present', and 'all'. If flag not supplied, it defaults to 'all'. |
required* = conditionally required
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
merchant_number | string(20) | Merchant number |
record_number | string | Unique identifier for the authorizations |
card_number | string(19) | Masked card number |
exp_date | string(4) | Expiry MMYY |
currency | string(3) | Currency |
amount | integer | Amount in minor currency unit, see Currency and Amount Handling for details |
auth_code | string(6) | Authorization code |
auth_date | string | Authorization date in date and time format |
resp_code | string | Description of the response code |
reversed | string(1) | Contains the character Y if the authorisation has been reversed else N |
pos_entry_mode | string(3) | POS Entry Mode |
voice | string(1) | Y if this is a voice authorisation, N otherwise |
avs_result | string(1) | AVS Result |
cvv2_result | string(1) | CVV2 Result |
card_type | string(1) | Card Type code |
ecom_type | string(5) | Indicator for electronic commerce transactions |
eci_sli | string(2) | Visa card scheme ECI / MasterCard SLI |
rrn | string(12) | Retrieval Reference Number |
card_acceptor | string(40) | Card Acceptor Name and Location |
mcc | string(4) | Merchant category code |
trace | integer | Trace number. All messages belonging the same transaction have to have the same trace value |
type | string(1) | Transaction Type |
card_sub_type | string(8) | Card Subtype |
terminal_id | string(15) | Terminal ID |
unique_tran_id | string(36) | Unique Transaction Identifier |
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_authorizations_responses per_page="100" page="1" total_count="2" pages_count="1">
<payment_authorizations_response>
<xml_root>payment_authorization_response</xml_root>
<merchant_number>605000000002029</merchant_number>
<record_number>33202414090</record_number>
<card_number>465944******7359</card_number>
<exp_date/>
<currency>EUR</currency>
<amount>1234</amount>
<auth_code>15056</auth_code>
<auth_date>2019-06-10 16:17:18 UTC</auth_date>
<resp_code>Transaction approved</resp_code>
<reversed>N</reversed>
<pos_entry_mode>102</pos_entry_mode>
<voice>N</voice>
<avs_result/>
<cvv2_result>M</cvv2_result>
<card_type>M</card_type>
<ecom_type/>
<eci_sli>21</eci_sli>
<rrn>916116130233</rrn>
<card_acceptor>test.bg 12629314 BG</card_acceptor>
<mcc>7995</mcc>
<trace>1130233</trace>
<type/>
<card_sub_type/>
<terminal_id>53b1f5eacc9edd</terminal_id>
<unique_tran_id/>
</payment_authorizations_response>
<payment_authorizations_response>
<merchant_number>605000000002029</merchant_number>
<record_number>33202414090</record_number>
<card_number>465944******7359</card_number>
<exp_date/>
<currency>EUR</currency>
<amount>1234</amount>
<auth_code>15056</auth_code>
<auth_date>2019-06-10 16:17:18 UTC</auth_date>
<resp_code>Transaction approved</resp_code>
<reversed>N</reversed>
<pos_entry_mode>102</pos_entry_mode>
<voice>N</voice>
<avs_result/>
<cvv2_result>M</cvv2_result>
<card_type>M</card_type>
<ecom_type/>
<eci_sli>21</eci_sli>
<rrn>916116130233</rrn>
<card_acceptor>test.bg 12629314 BG</card_acceptor>
<mcc>7995</mcc>
<trace>1130233</trace>
<type/>
<card_sub_type/>
<terminal_id>53b1f5eacc9edd</terminal_id>
<unique_tran_id/>
</payment_authorizations_response>
</payment_authorizations_responses>
The attributes in the root node payment authorization responses includes information about the pagination of the response.
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
@per_page | integer | number of entries per page |
@page | integer | the current page |
@total_count | integer | total number of all entries |
@pages_count | integer | total number of pages |
Processed Transactions
Processed Transaction API
The Processed Transaction API can be used to retrieve data about transactions, processed through external platforms (both card present and card not present). To retrieve data about transactions processed through the Genesis platform, use Reconcile API.
Single Processed Transaction
Single processed transaction retrieval allows to get a certain processed transaction by its ARN or by passing its unique ID.
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.gate.emerchantpay.net/processed_transactions \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<processed_transaction_request>
<arn>74537604221431003881865</arn>
</processed_transaction_request>'
OR
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.gate.emerchantpay.net/processed_transactions \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<processed_transaction_request>
<unique_id>53b1f5eacc9e4d3a3afebb4e993fe962</unique_id>
</processed_transaction_request>'
The URLs for the single processed transaction API are:
Production:
https://gate.emerchantpay.net/processed_transactions
Staging (for integration):
https://staging.gate.emerchantpay.net/processed_transactions
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<processed_transaction_response>
<merchant_number>124000000006698</merchant_number>
<batch_number>eMP</batch_number>
<transaction_id>a1qf12e81eb23d0e00ffb85b1db7d152</transaction_id>
<transaction_date>2019-09-01 16:43:02 UTC</transaction_date>
<post_date>2019-09-01</post_date>
<terminal_id>53b1f5eacc9eddda3afebb4e993fe962</terminal_id>
<auth_code>09117B</auth_code>
<currency>USD</currency>
<amount>3690</amount>
<merchant_transaction_reference>b76e9a54bdc99b3</merchant_transaction_reference>
<arn>85301169244934771128812</arn>
<card_brand>MC World Signia</card_brand>
<card_number>420000...0000</card_number>
<bin_country>124</bin_country>
<service_type_desc>Credit Card</service_type_desc>
<merchant_country>826</merchant_country>
<area_of_event>Foreign - MASTER</area_of_event>
<cross_rate>1</cross_rate>
<card_scheme>Mastercard</card_scheme>
<capture_method>ICC, contactless, no cvm</capture_method>
<unique_id>b76e9a54bdc99b338068681727ed5e240000</unique_id>
<type>purchase</type>
<card_present>false</card_present>
<deposit_slip_number>60506291293</deposit_slip_number>
<batch_slip_number>60506282664</batch_slip_number>
</processed_transaction_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
merchant_number | string(20) | Merchant number |
batch_number | string(23) | Batch number |
transaction_id | string(255) | Merchant transaction ID. Returned only when the processed transaction is Card Not Present. |
transaction_date | string(255) | Transaction date in date and time format |
post_date | string(255) | Posting date |
terminal_id | string(10) | Terminal ID |
arn | string(23) | Acquirer reference number |
merchant_transaction_reference | string(23) | Merchant's transaction reference number |
card_scheme | string(16) | Descriptive text for the card scheme |
capture_method | string(255) | Capture method identifying the type of the transaction |
service_type_desc | string(25) | Indicates if transaction is a Debit or Credit transaction |
card_brand | string(3) | Scheme card brand |
card_number | string(13) | Masked card number |
bin_country | string(3) | Issuing BIN ISO Country Code from Scheme BIN tables |
merchant_country | string(3) | 3 digit ISO country code of the merchant country |
area_of_event | string(19) | Area of event |
currency | string(3) | Currency of transaction |
cross_rate | float(11) | FX rate to convert from transaction account to merchant funding currency |
auth_code | string(6) | Authorization code |
unique_id | string(36) | Unique Transaction Identifier is generated at PoS before sent for authorisation or offline approval |
card_present | boolean | Transaction is card present or card not present |
deposit_slip_number | string(11) | Deposit Slip Number |
batch_slip_number | string(11) | Batch Slip Number |
type | string(65) | Transaction type for the related charge posted to account |
Error Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<processed_transaction_response>
<status>error</status>
<code>465</code>
<message>Processed transaction not found!</message>
<technical_message>Processed transaction by the given criteria cannot be found!</technical_message>
</processed_transaction_response>
In case no processed transaction is found for the given ARN or unique ID, a corresponding XML response is as follows:
By date or post date range
Date range based processed transaction retrieval allows you to fetch information for all processed transactions for a given merchant within a given date range. Date range searches for processed transactions either by their creation or posting date. The response is paginated, each request will return 100 entries max.
The URLs for date range processed transaction retrieval are:
Production:
https://gate.emerchantpay.net/processed_transactions/by_date
https://gate.emerchantpay.net/processed_transactions/by_post_date
Staging (for integration):
https://staging.gate.emerchantpay.net/processed_transactions/by_date
https://staging.gate.emerchantpay.net/processed_transactions/by_post_date
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.gate.emerchantpay.net/processed_transactions/by_post_date \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<processed_transaction_request>
<start_date>2014-01-01</start_date>
<end_date>2014-01-31</end_date>
<batch_number>2065063</batch_number>
<batch_slip_number>366236636</batch_slip_number>
<deposit_slip_number>224234433</deposit_slip_number>
<externally_processed>external</externally_processed>
<processing_type>all</processing_type>
<page>1</page>
</processed_transaction_request>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
start_date | required | yyyy-mm-dd | start of the requested date range |
end_date | optional | yyyy-mm-dd | end of the requested date range |
page | optional | integer | the page within the paginated result, defaults to 1 |
per_page | optional | integer | Number of entities on page, defaults to 100 |
batch_number | optional | string(255) | Batch number of processed transactions (only for by_post_date API call) |
batch_slip_number | optional | string(255) | Batch slip number of processed transactions (only for by_post_date API call) |
deposit_slip_number | optional | string(255) | Deposit slip number of processed transactions (only for by_post_date API call) |
externally_processed | optional | string(255) | Filters transactions by being externally processed or being native to Genesis. Possible values include 'genesis', 'external', and 'all'. If flag not supplied, it defaults to 'genesis' |
processing_type | optional | string(255) | Filters transactions by being card present or card not present. Possible values include 'card_present', 'card_not_present', and 'all'. If flag not supplied, it defaults to 'all'. |
required* = conditionally required
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<processed_transaction_responses per_page="100" page="1" total_count="2" pages_count="1">
<processed_transaction_response>
<merchant_number>124000000006698</merchant_number>
<batch_number>eMP</batch_number>
<transaction_id>a1qf12e81eb23d0e00ffb85b1db7d152</transaction_id>
<transaction_date>2019-09-01 16:43:02 UTC</transaction_date>
<post_date>2019-09-01</post_date>
<terminal_id>53b1f5eacc9eddda3afebb4e993fe962</terminal_id>
<auth_code>09117B</auth_code>
<currency>USD</currency>
<amount>3690</amount>
<merchant_transaction_reference>b76e9a54bdc99b3</merchant_transaction_reference>
<card_brand>MC World Signia</card_brand>
<card_number>420000...0000</card_number>
<bin_country>124</bin_country>
<service_type_desc>Credit Card</service_type_desc>
<merchant_country>826</merchant_country>
<area_of_event>Foreign - MASTER</area_of_event>
<cross_rate>1</cross_rate>
<card_scheme>Mastercard</card_scheme>
<capture_method>ICC, contactless, no cvm</capture_method>
<unique_id>b76e9a54bdc99b338068681727ed5e240000</unique_id>
<type>purchase</type>
<card_present>false</card_present>
<deposit_slip_number>60506291293</deposit_slip_number>
<batch_slip_number>60506282664</batch_slip_number>
<arn>85301169244934771128812</arn>
</processed_transaction_response>
<processed_transaction_response>
<merchant_number>124000000006698</merchant_number>
<batch_number>eMP</batch_number>
<transaction_id>a1qf12e81eb23d0e00ffb85b1db7d152</transaction_id>
<transaction_date>2019-09-01 16:43:02 UTC</transaction_date>
<post_date>2019-09-01</post_date>
<terminal_id>53b1f5eacc9eddda3afebb4e993fe962</terminal_id>
<auth_code>09117B</auth_code>
<currency>USD</currency>
<amount>3690</amount>
<merchant_transaction_reference>b76e9a54bdc99b3</merchant_transaction_reference>
<card_brand>MC World Signia</card_brand>
<card_number>420000...0000</card_number>
<bin_country>124</bin_country>
<service_type_desc>Credit Card</service_type_desc>
<merchant_country>826</merchant_country>
<area_of_event>Foreign - MASTER</area_of_event>
<cross_rate>1</cross_rate>
<card_scheme>Mastercard</card_scheme>
<capture_method>ICC, contactless, no cvm</capture_method>
<unique_id>b76e9a54bdc99b338068681727ed5e240000</unique_id>
<type>purchase</type>
<card_present>false</card_present>
<deposit_slip_number>60506291293</deposit_slip_number>
<batch_slip_number>60506282664</batch_slip_number>
<arn>85301169244934771128812</arn>
</processed_transaction_response>
</processed_transaction_responses>
The attributes in the root node processed transaction responses includes information about the pagination of the response.
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
@per_page | integer | number of entries per page |
@page | integer | the current page |
@total_count | integer | total number of all entries |
@pages_count | integer | total number of pages |
Chargebacks
Chargebacks are a special type of transactions as they cannot be triggered by the merchant. Charge- backs occur if a customer disputes to an item of his credit card bill at his issuing bank and the bank requests a chargeback. In this case, the amount is automatically refunded to the customers cc account and deducted from your merchant account.
Customers who initiate chargebacks will automatically be blocked for future transactions. For details, please contact our Risk team.
You can also see a chargeback overview in the merchant console under the Risk Management menu.
Chargeback reversals
The reversals could be split into two types. These are the chargeback reversals, which appear when the a chargeback dispute is cancelled (withdrawn) by the consumer/issuer and the representments, which appear when the merchant or the acquirer disputes an already received chargeback. Both of these chargeback event types are handled properly and integrated into the whole process of chargeback dispute procedure.
Chargeback notifications
You now have the option to receive API and/or email notifications for each chargeback event that occurs - e.g. for first chargebacks, second chargebacks, and representments. Enable this feature by emailing the IT Support team at tech-support@emerchantpay.com with the chargeback notification URL if needed.
The email notifications are sent to the merchant user with role ’admin’ which is configured for managing the merchant entity on the gateway platform. The API notifications are equal to Notification for asynchronous payments, please refer to the section Notification for asynchronous payments to understand how notifications work.
Chargeback Notification Example
?transaction_id=343d9040a671c45832ee5381860e2996
&terminal_token=f4266042a6131b666060beb75691341d78ee5b4f
&unique_id=57ff74d1ca8727f59f243de6d01ff027
&transaction_type=sale
&status=chargebacked
&signature=ab4348afa9830834df90069646e4ce66c39a5358
&amount=100
&event=chargeback
Chargeback API
The Chargeback API can be used to retrieve data about chargebacks.
Single Chargeback
Single chargeback retrieval allows to get a certain chargeback by its ARN or by passing the unique ID of the original transaction.
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.gate.emerchantpay.net/chargebacks \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<chargeback_request>
<arn>74537604221431003881865</arn>
</chargeback_request>'
OR
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.gate.emerchantpay.net/chargebacks \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<chargeback_request>
<original_transaction_unique_id>53b1f5eacc9e4d3a3afebb4e993fe962</original_transaction_unique_id>
</chargeback_request>'
List of Chargebacks
Retrieve a list of chargebacks by ARN or by passing the unique ID of the original transaction.
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.gate.emerchantpay.net/chargebacks \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<chargeback_request>
<arn>74537604221431003881865</arn>
<mode>list</mode>
</chargeback_request>'
OR
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.gate.emerchantpay.net/chargebacks \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<chargeback_request>
<original_transaction_unique_id>53b1f5eacc9e4d3a3afebb4e993fe962</original_transaction_unique_id>
<mode>list</mode>
</chargeback_request>'
The URLs for single and list of chargebacks API are:
Production:
https://gate.emerchantpay.net/chargebacks
Staging (for integration):
https://staging.gate.emerchantpay.net/chargebacks
Successful Response
stdClass Object
(
[type] => 1st Chargeback
[post_date] => 2014-01-24
[reason_code] => 4855
[merchant_number] => 443344323459841
[reason_description] => Non-receipt of merchandise
[authorization_code] => 811714
[batch_number] => 2093064
[cnn] => 9002578764
[merchant_transaction_reference] => b76e9a54bdc99b3
[capture_method] => SET/3D-SET authenticated
[amount] => -14625
[currency] => USD
[chargeback_amount] => 300.0
[chargeback_currency] => EUR
[chargeback_account_amount] => 185.99
[chargeback_account_currency] => EUR
[merchant_funding_amount] => 1003.72
[merchant_funding_currency] => EUR
[original_transaction_amount] => 148.0
[original_transaction_currency] => EUR
[merchant_settlement_amount] => 148.0
[merchant_settlement_currency] => EUR
[network_settlement_amount] => 148.0
[network_settlement_currency] => EUR
[merchant_dba_name] => hyperstech.com
[original_type] => Purchase
[original_post_date] => 2019-06-28
[original_transaction_date] => 2019-06-28
[original_slip] => 92572791484
[item_slip_number] => 93778283100
[card_number] => 554960******5069
[card_brand] => master
[customer_email] => jonh_doe@example.com
[customer_phone] => 3598851248512
[transaction_type] => sale3d
[original_transaction_unique_id] => f9634ec5e7dbe6ca3871974accb875cd
[arn] => 74537604221431003881865
)
<payment_response content=[
<type content=[1st Chargeback]>
<post_date content=[2014-01-24]>
<reason_code content=[4855]>
<merchant_number content=[443344323459841]>
<reason_description content=[Non-receipt of merchandise]>
<authorization_code content=[811714]>
<batch_number content=[2093064]>
<cnn content=[9002578764]>
<merchant_transaction_reference content=[b76e9a54bdc99b3]>
<capture_method content=[SET/3D-SET authenticated]>
<amount content=[-14625]>
<currency content=[USD]>
<chargeback_amount content=[300.0]>
<chargeback_currency content=[EUR]>
<chargeback_account_amount content=[185.99]>
<chargeback_account_currency content=[EUR]>
<merchant_funding_amount content=[1003.72]>
<merchant_funding_currency content=[EUR]>
<original_transaction_amount content=[148.0]>
<original_transaction_currency content=[EUR]>
<merchant_settlement_amount content=[148.0]>
<merchant_settlement_currency content=[EUR]>
<network_settlement_amount content=[148.0]>
<network_settlement_currency content=[EUR]>
<merchant_dba_name content=[hyperstech.com]>
<original_type content=[Purchase]>
<original_post_date content=[2019-06-28]>
<original_transaction_date content=[2019-06-28]>
<original_slip content=[92572791484]>
<item_slip_number content=[93778283100]>
<card_number content=[554960******5069]>
<card_brand content=[master]>
<customer_email content=[jonh_doe@example.com]>
<customer_phone content=[3598851248512]>
<transaction_type content=[sale3d]>
<original_transaction_unique_id content=[f9634ec5e7dbe6ca3871974accb875cd]>
<arn content=[74537604221431003881865]>
]>
{
type: "1st Chargeback",
post_date: "2014-01-24",
reason_code: "4855",
merchant_number: "443344323459841",
reason_description: "Non-receipt of merchandise",
authorization_code: "811714",
batch_number: "2093064",
cnn: "9002578764",
merchant_transaction_reference: "b76e9a54bdc99b3",
capture_method: "SET/3D-SET authenticated",
amount: "-14625",
currency: "USD",
chargeback_amount: "300.0",
chargeback_currency: "EUR",
chargeback_account_amount: "185.99",
chargeback_account_currency: "EUR",
merchant_funding_amount: "1003.72",
merchant_funding_currency: "EUR",
original_transaction_amount: "148.0",
original_transaction_currency: "EUR",
merchant_settlement_amount: "148.0",
merchant_settlement_currency: "EUR",
network_settlement_amount: "148.0",
network_settlement_currency: "EUR",
merchant_dba_name: "hyperstech.com",
original_type: "Purchase",
original_post_date: "2019-06-28",
original_transaction_date: "2019-06-28",
original_slip: "92572791484",
item_slip_number: "93778283100",
card_number: "554960******5069",
card_brand: "master",
customer_email: "jonh_doe@example.com",
customer_phone: "3598851248512",
transaction_type: "sale3d",
original_transaction_unique_id: "f9634ec5e7dbe6ca3871974accb875cd",
arn: "74537604221431003881865",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<chargeback_response>
<type>1st Chargeback</type>
<post_date>2014-01-24</post_date>
<reason_code>4855</reason_code>
<merchant_number>443344323459841</merchant_number>
<reason_description>Non-receipt of merchandise</reason_description>
<authorization_code>811714</authorization_code>
<batch_number>2093064</batch_number>
<cnn>9002578764</cnn>
<merchant_transaction_reference>b76e9a54bdc99b3</merchant_transaction_reference>
<capture_method>SET/3D-SET authenticated</capture_method>
<amount>-14625</amount>
<currency>USD</currency>
<chargeback_amount>300.0</chargeback_amount>
<chargeback_currency>EUR</chargeback_currency>
<chargeback_account_amount>185.99</chargeback_account_amount>
<chargeback_account_currency>EUR</chargeback_account_currency>
<merchant_funding_amount>1003.72</merchant_funding_amount>
<merchant_funding_currency>EUR</merchant_funding_currency>
<original_transaction_amount>148.0</original_transaction_amount>
<original_transaction_currency>EUR</original_transaction_currency>
<merchant_settlement_amount>148.0</merchant_settlement_amount>
<merchant_settlement_currency>EUR</merchant_settlement_currency>
<network_settlement_amount>148.0</network_settlement_amount>
<network_settlement_currency>EUR</network_settlement_currency>
<merchant_dba_name>hyperstech.com</merchant_dba_name>
<original_type>Purchase</original_type>
<original_post_date>2019-06-28</original_post_date>
<original_transaction_date>2019-06-28</original_transaction_date>
<original_slip>92572791484</original_slip>
<item_slip_number>93778283100</item_slip_number>
<card_number>554960******5069</card_number>
<card_brand>master</card_brand>
<customer_email>jonh_doe@example.com</customer_email>
<customer_phone>3598851248512</customer_phone>
<transaction_type>sale3d</transaction_type>
<original_transaction_unique_id>f9634ec5e7dbe6ca3871974accb875cd</original_transaction_unique_id>
<arn>74537604221431003881865</arn>
</chargeback_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
type | string(255) | The chargeback type. See chargeback types for details |
post_date | string(255) | The date of the chargeback |
reason_code | string(255) | Reason code of the chargeback |
merchant_number | string(255) | Merchant number |
reason_description | string(255) | Reason description of the chargeback |
authorization_code | string(255) | Authorization code of the chargeback’s transaction |
batch_number | string(23) | The batch number is provided by the submitter of the original presentment |
cnn | string(14) | Chargeback Control Number filled for chargebacks and representments; empty for transfer transactions. |
merchant_transaction_reference | string(255) | Merchant's transaction reference number |
capture_method | string(255) | Capture method |
amount | integer | Amount reported in the currency of the acquirer’s dispute account i.e. as per the accountancy of the acquirer. The amount can be negative for types 1st chargeback, 2nd chargeback, transfer reversal, and positive for all other types, see Currency and Amount Handling for details. |
currency | string(3) | Currency as accounted by the acquirer. See ISO 4217 |
chargeback_amount | float | The amount in the chargeback’s transaction currency i.e. the way it has been reported by the issuer. See Currency and Amount Handling for details. |
chargeback_currency | string(3) | The currency of the chargeback as reported by the issuer. See ISO 4217 |
chargeback_account_amount | float | Scheme settlement amount of the transaction |
chargeback_account_currency | string(3) | Scheme settlement currency of the transaction |
merchant_funding_amount | float | Amount corresponding to the financial impact for the merchant as reported by the acquirer |
merchant_funding_currency | string(3) | Currency corresponding to the financial impact for the merchant as reported by the acquirer |
original_transaction_amount | float(18) | Amount of the original presentment in transaction currency, see Currency and Amount Handling for details. |
original_transaction_currency | string(3) | Transaction currency of the original presentment |
merchant_settlement_amount | float(18) | Amount settled with the merchant for the original presentment (that is, the amount posted to the merchant account), before the deduction of any charges, see Currency and Amount Handling for details. |
merchant_settlement_currency | string(3) | Currency settled with the payment network for the presentment before the deduction of any charges. |
network_settlement_amount | float(18) | Amount settled with the merchant for the original presentment (that is, the amount posted to the merchant account), before the deduction of any charges, see Currency and Amount Handling for details. |
network_settlement_currency | string(3) | Currency settled with the payment network for the presentment before the deduction of any charges. |
merchant_dba_name | string(25) | Merchant name in the transaction as cleared to the schemes (charge descriptor). |
original_type | string(28) | Transaction type of the original presentment |
original_post_date | date(8) | Original presentment posting date |
original_transaction_date | date(8) | Transaction date of the original presentment |
original_slip | string(11) | OmniPay internal slip number of the original presentment |
item_slip_number | string(11) | OmniPay internal slip number of the original presentment |
card_number | string(255) | Card number used for the chargeback’s transaction |
card_brand | string(255) | Card brand of the card number |
customer_email | string(255) | The email of the cardholder |
customer_phone | integer | The phone of the cardholder |
transaction_type | string(255) | The type of the chargeback’s transaction |
original_transaction_unique_id | string(255) | The unique id of the chargeback’s transaction |
arn | string(255) | ARN of the chargeback’s transaction |
Error Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<chargeback_response>
<status>error</status>
<code>470</code>
<message>Chargeback not found!</message>
<technical_message>Chargeback by the given criteria cannot be found!</technical_message>
</chargeback_response>
In case no chargeback is found for the given ARN or unique ID, a corresponding XML response is as follows:
By date range
Date range based chargeback retrieval allows you to fetch information for all chargebacks for a given merchant within a given date range. Date range searches for chargebacks by their posting date. Search option is chargeback retrieval by their import (creation) date. The response is paginated, each request will return 100 entries max.
The URLs for date range chargeback retrieval are:
Production:
https://gate.emerchantpay.net/chargebacks/by_date
Staging (for integration):
https://staging.gate.emerchantpay.net/chargebacks/by_date
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.gate.emerchantpay.net/chargebacks/by_date \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<chargeback_request>
<start_date>2014-01-01</start_date>
<end_date>2014-01-31</end_date>
<externally_processed>external</externally_processed>
<processing_type>all</processing_type>
<page>1</page>
</chargeback_request>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
start_date | required | yyyy-mm-dd | start of the requested date range |
end_date | optional | yyyy-mm-dd | end of the requested date range |
import_date | optional | yyyy-mm-dd | date of import in our system. Spans from beggining until end of day. |
page | optional | integer | the page within the paginated result, defaults to 1 |
per_page | optional | integer | Number of entities on page, defaults to 100 |
externally_processed | optional | string(255) | Filters chargebacks by being externally processed or being native to Genesis. Possible values include 'genesis', 'external', and 'all'. If flag not supplied, it defaults to 'genesis' |
processing_type | optional | string(255) | Filters chargebacks by being card present or card not present. Possible values include 'card_present', 'card_not_present', and 'all'. If flag not supplied, it defaults to 'all'. |
required* = conditionally required
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<chargeback_responses per_page="100" page="1" total_count="2" pages_count="1">
<chargeback_response>
<type>1st Chargeback</type>
<merchant_number>443344323459841</merchant_number>
<post_date>2014-01-24</post_date>
<reason_code>4855</reason_code>
<reason_description>Non-receipt of merchandise</reason_description>
<authorization_code>811714</authorization_code>
<batch_number>2093064</batch_number>
<cnn>9002578764</cnn>
<merchant_transaction_reference>b76e9a54bdc99b3</merchant_transaction_reference>
<capture_method>SET/3D-SET authenticated</capture_method>
<amount>-14625</amount>
<currency>USD</currency>
<chargeback_amount>300.0</chargeback_amount>
<chargeback_currency>EUR</chargeback_currency>
<chargeback_account_amount>185.99</chargeback_account_amount>
<chargeback_account_currency>EUR</chargeback_account_currency>
<merchant_funding_amount>1003.72</merchant_funding_amount>
<merchant_funding_currency>EUR</merchant_funding_currency>
<original_transaction_amount>148.0</original_transaction_amount>
<original_transaction_currency>EUR</original_transaction_currency>
<merchant_settlement_amount>148.0</merchant_settlement_amount>
<merchant_settlement_currency>EUR</merchant_settlement_currency>
<network_settlement_amount>148.0</network_settlement_amount>
<network_settlement_currency>EUR</network_settlement_currency>
<merchant_dba_name>hyperstech.com</merchant_dba_name>
<original_type>Purchase</original_type>
<original_post_date>2019-06-28</original_post_date>
<original_transaction_date>2019-06-28</original_transaction_date>
<original_slip>92572791484</original_slip>
<item_slip_number>93778283100</item_slip_number>
<card_number>554960******5069</card_number>
<card_brand>master</card_brand>
<customer_email>jonh_doe@example.com</customer_email>
<customer_phone>3598851248512</customer_phone>
<transaction_type>sale3d</transaction_type>
<original_transaction_unique_id>f9634ec5e7dbe6ca3871974accb875cd</original_transaction_unique_id>
<arn>74537604221431003881865</arn>
</chargeback_response>
<chargeback_response>
<type>2nd Chargeback</type>
<merchant_number>443344323459841</merchant_number>
<post_date>2014-01-27</post_date>
<reason_code>4855</reason_code>
<reason_description>Non-receipt of merchandise</reason_description>
<authorization_code>811714</authorization_code>
<batch_number>2093064</batch_number>
<cnn>9002578764</cnn>
<merchant_transaction_reference>b76e9a54bdc99b3</merchant_transaction_reference>
<capture_method>SET/3D-SET authenticated</capture_method>
<amount>3456</amount>
<currency>USD</currency>
<chargeback_amount>300.0</chargeback_amount>
<chargeback_currency>EUR</chargeback_currency>
<chargeback_account_amount>185.99</chargeback_account_amount>
<chargeback_account_currency>EUR</chargeback_account_currency>
<merchant_funding_amount>1003.72</merchant_funding_amount>
<merchant_funding_currency>EUR</merchant_funding_currency>
<original_transaction_amount>148.0</original_transaction_amount>
<original_transaction_currency>EUR</original_transaction_currency>
<merchant_settlement_amount>148.0</merchant_settlement_amount>
<merchant_settlement_currency>EUR</merchant_settlement_currency>
<network_settlement_amount>148.0</network_settlement_amount>
<network_settlement_currency>EUR</network_settlement_currency>
<merchant_dba_name>hyperstech.com</merchant_dba_name>
<original_type>Purchase</original_type>
<original_post_date>2019-06-28</original_post_date>
<original_transaction_date>2019-06-28</original_transaction_date>
<original_slip>92572791484</original_slip>
<item_slip_number>93778283100</item_slip_number>
<card_number>454360******5008</card_number>
<card_brand>visa</card_brand>
<customer_email>ivan@example.com</customer_email>
<customer_phone>3598851248512</customer_phone>
<transaction_type>sale</transaction_type>
<original_transaction_unique_id>67fbebc172b743a164a3f3af3d010457</original_transaction_unique_id>
<arn>74537604221431003881865</arn>
</chargeback_response>
</chargeback_responses>
The attributes in the root node chargeback responses includes information about the pagination of the response.
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
@per_page | integer | number of entries per page |
@page | integer | the current page |
@total_count | integer | total number of all entries |
@pages_count | integer | total number of pages |
Chargeback types
Chargebacks will have one of the following type:
Type | Description |
---|---|
1st Chargeback | The first stage of the dispute procedure raised by the issuer |
2nd Chargeback | Second stage of the dispute procedure raised by the issuer (MasterCard only) |
1st Chargeback Reversal | When the first chargeback is cancelled (withdrawn) by the issuer |
2nd Chargeback Reversal | When the second chargeback is cancelled (withdrawn) by the issuer (MasterCard only) |
Transfer Reversal | An operation that sends the amount of the dispute to the merchant when the acquirer represents a chargeback |
Re-presentment | Acquirer’s defend of the issuer’s (first) chargeback |
Representment Reversal | The Representment initiated by the merchant is cancelled or rejected by the acquirer (the merchant's bank) due to an error or invalid reason for representment. The funds that were initially refunded to the merchant as a result of the re-presentment are reversed back to the issuer account (the cardholder's bank). |
Chargeback Transfer to Merchant Hold Acc | The money is taken from merchant’s hold account in Omnipay and is sent to the issuer |
Chargeback Transfer to Writeoff Account Acq | The acquirer is taking the loss for this chargeback |
Chargeback Transfer to Paymnt Acct Retail | The money is taken from merchant’s account in Omnipay and are sent to the issuer (as per the chargeback rules). |
Chargeback Transfer to Writeoff SP | The Service Provider is taking the loss for the chargeback. |
Rapid Dispute Resolution
Rapid Dispute Resolution(RDR) is a kind of a pre-dispute program of VISA via VISA's recent acquisition of VERIFI. Its goal is to reduce chargebacks.
RDR is now part of VROL and all the issuers have to use it now prior to initiating a dispute. A merchant can enrol via Visa's VERIFI service (or another authorized reseller) and define rules for auto-liability acceptance with the platform.
When an RDR event occurs and the merchant accepts the liability then the cardholder will be automatically refunded. VISA will withdraw the amount from the acquirer account.
Rapid Dispute Resolution API
The Rapid Dispute Resolution API can be used to retrieve data about Rapid Dispute Resolutions.
Single Rapid Dispute Resolution
Single RDR retrieval allows to get a certain RDR by its ARN or by passing the unique ID of the original transaction.
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.gate.emerchantpay.net/rapid_dispute_resolutions \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<rapid_dispute_resolution_request>
<arn>74537604221431003881865</arn>
</rapid_dispute_resolution_request>'
OR
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.gate.emerchantpay.net/rapid_dispute_resolutions \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<rapid_dispute_resolution_request>
<original_transaction_unique_id>53b1f5eacc9e4d3a3afebb4e993fe962</original_transaction_unique_id>
</rapid_dispute_resolution_request>'
List of Rapid Dispute Resolutions
Retrieve a list of rdrs by ARN or by passing the unique ID of the original transaction.
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.gate.emerchantpay.net/rapid_dispute_resolutions \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<rapid_dispute_resolution_request>
<arn>74537604221431003881865</arn>
<mode>list</mode>
</rapid_dispute_resolution_request>'
OR
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.gate.emerchantpay.net/rapid_dispute_resolutions \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<rapid_dispute_resolution_request>
<original_transaction_unique_id>53b1f5eacc9e4d3a3afebb4e993fe962</original_transaction_unique_id>
<mode>list</mode>
</rapid_dispute_resolution_request>'
The URLs for single and list of Rapid Dispute Resolutions API are:
Production:
https://gate.emerchantpay.net/rapid_dispute_resolutions
Staging (for integration):
https://staging.gate.emerchantpay.net/rapid_dispute_resolutions
Successful Response
stdClass Object
(
[type] => RDR Pre-dispute
[post_date] => 2014-01-24
[reason_code] => 4855
[reason_description] => Non-receipt of merchandise
[rdr_amount] => 300.0
[rdr_currency] => EUR
[card_number] => 554960******5069
[arn] => 74537604221431003881865
[card_brand] => master
[customer_email] => jonh_doe@example.com
[customer_phone] => 3598851248512
[transaction_type] => sale3d
[original_transaction_unique_id] => f9634ec5e7dbe6ca3871974accb875cd
[original_transaction_amount] => 200.0
[original_transaction_currency] => EUR
[original_transaction_merchant_transaction_id] => 12345
)
<payment_response content=[
<type content=[RDR Pre-dispute]>
<post_date content=[2014-01-24]>
<reason_code content=[4855]>
<reason_description content=[Non-receipt of merchandise]>
<rdr_amount content=[300.0]>
<rdr_currency content=[EUR]>
<card_number content=[554960******5069]>
<arn content=[74537604221431003881865]>
<card_brand content=[master]>
<customer_email content=[jonh_doe@example.com]>
<customer_phone content=[3598851248512]>
<transaction_type content=[sale3d]>
<original_transaction_unique_id content=[f9634ec5e7dbe6ca3871974accb875cd]>
<original_transaction_amount content=[200.0]>
<original_transaction_currency content=[EUR]>
<original_transaction_merchant_transaction_id content=[12345]>
]>
{
type: "RDR Pre-dispute",
post_date: "2014-01-24",
reason_code: "4855",
reason_description: "Non-receipt of merchandise",
rdr_amount: "300.0",
rdr_currency: "EUR",
card_number: "554960******5069",
arn: "74537604221431003881865",
card_brand: "master",
customer_email: "jonh_doe@example.com",
customer_phone: "3598851248512",
transaction_type: "sale3d",
original_transaction_unique_id: "f9634ec5e7dbe6ca3871974accb875cd",
original_transaction_amount: "200.0",
original_transaction_currency: "EUR",
original_transaction_merchant_transaction_id: "12345",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<rapid_dispute_resolution_response>
<type>RDR Pre-dispute</type>
<post_date>2014-01-24</post_date>
<reason_code>4855</reason_code>
<reason_description>Non-receipt of merchandise</reason_description>
<rdr_amount>300.0</rdr_amount>
<rdr_currency>EUR</rdr_currency>
<card_number>554960******5069</card_number>
<arn>74537604221431003881865</arn>
<card_brand>master</card_brand>
<customer_email>jonh_doe@example.com</customer_email>
<customer_phone>3598851248512</customer_phone>
<transaction_type>sale3d</transaction_type>
<original_transaction_unique_id>f9634ec5e7dbe6ca3871974accb875cd</original_transaction_unique_id>
<original_transaction_amount>200.0</original_transaction_amount>
<original_transaction_currency>EUR</original_transaction_currency>
<original_transaction_merchant_transaction_id>12345</original_transaction_merchant_transaction_id>
</rapid_dispute_resolution_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
type | string(255) | The rapid dispute resolution type. |
post_date | string(255) | The date of the rapid dispute resolution |
reason_code | string(255) | Reason code of the rapid dispute resolution |
reason_description | string(255) | Reason description of the rapid dispute resolution |
rdr_amount | float | The amount in the rapid dispute resolution’s transaction currency i.e. the way it has been reported by the issuer. See Currency and Amount Handling for details. |
rdr_currency | string(3) | The currency of the rapid dispute resolution as reported by the issuer. See ISO 4217 |
card_number | string(255) | Card number used for the rapid dispute resolution’s transaction |
arn | string(255) | ARN of the rapid dispute resolution’s transaction |
card_brand | string(255) | Card brand of the card number |
customer_email | string(255) | The email of the cardholder |
customer_phone | integer | The phone of the cardholder |
transaction_type | string(255) | The type of the rapid dispute resolution’s transaction |
original_transaction_unique_id | string(255) | The unique id of the rapid dispute resolution’s transaction |
original_transaction_amount | string(255) | Original transaction amount |
original_transaction_currency | string(255) | Original transaction currency |
original_transaction_merchant_transaction_id | string(255) | Merchant reference id |
In case no rapid dispute resolution is found for the given ARN or unique ID, the corresponding XML response is as follows:
Error Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<rapid_dispute_resolution_response>
<status>error</status>
<code>471</code>
<message>Rapid Dispute Resolution not found!</message>
<technical_message>Rapid Dispute Resolution by the given criteria cannot be found!</technical_message>
</rapid_dispute_resolution_response>
By date range
Date range based rapid dispute resolution retrieval allows you to fetch information for all rapid dispute resolutions for a given date range. Date range searches for rapid dispute resolutions by their posting date if start_date and an optional end_date is provided. Date range can also search by creation date if import_date parameter is specified in the request. The response is paginated, each request will return maximum 100 entries.
The URLs for date range rapid dispute resolution retrieval are:
Production:
https://gate.emerchantpay.net/rapid_dispute_resolutions/by_date
Staging (for integration):
https://staging.gate.emerchantpay.net/rapid_dispute_resolutions/by_date
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.gate.emerchantpay.net/rapid_dispute_resolutions/by_date \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<rapid_dispute_resolution_request>
<start_date>2014-01-01</start_date>
<end_date>2014-01-31</end_date>
<externally_processed>external</externally_processed>
<processing_type>all</processing_type>
<page>1</page>
</rapid_dispute_resolution_request>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
start_date | required | yyyy-mm-dd | start of the requested date range |
end_date | optional | yyyy-mm-dd | end of the requested date range |
import_date | optional | yyyy-mm-dd | date of import in our system. Spans from beginning until end of day. |
page | optional | integer | the page within the paginated result, defaults to 1 |
per_page | optional | integer | Number of entities on page, defaults to 100 |
externally_processed | optional | string(255) | Filters rapid dispute resolutions by being externally processed or being native to Genesis. Possible values include 'genesis', 'external', and 'all'. If flag not supplied, it defaults to 'genesis' |
processing_type | optional | string(255) | Filters rapid dispute resolutions by being card present or card not present. Possible values include 'card_present', 'card_not_present', and 'all'. If flag not supplied, it defaults to 'all'. |
required* = conditionally required
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<rapid_dispute_resolution_responses per_page="100" page="1" total_count="2" pages_count="1">
<rapid_dispute_resolution_response>
<type>RDR Pre-dispute</type>
<post_date>2014-01-24</post_date>
<reason_code>4855</reason_code>
<reason_description>Non-receipt of merchandise</reason_description>
<rdr_amount>300.0</rdr_amount>
<rdr_currency>EUR</rdr_currency>
<card_number>554960******5069</card_number>
<arn>74537604221431003881865</arn>
<card_brand>master</card_brand>
<customer_email>jonh_doe@example.com</customer_email>
<customer_phone>3598851248512</customer_phone>
<transaction_type>sale3d</transaction_type>
<original_transaction_unique_id>f9634ec5e7dbe6ca3871974accb875cd</original_transaction_unique_id>
<original_transaction_amount>200.0</original_transaction_amount>
<original_transaction_currency>EUR</original_transaction_currency>
<original_transaction_merchant_transaction_id>12345</original_transaction_merchant_transaction_id>
</rapid_dispute_resolution_response>
<rapid_dispute_resolution_response>
<type>RDR Pre-dispute</type>
<post_date>2014-01-27</post_date>
<reason_code>4855</reason_code>
<reason_description>Non-receipt of merchandise</reason_description>
<rdr_amount>300.0</rdr_amount>
<rdr_currency>EUR</rdr_currency>
<card_number>454360******5008</card_number>
<arn>74537604221431003881865</arn>
<card_brand>visa</card_brand>
<customer_email>ivan@example.com</customer_email>
<customer_phone>3598851248512</customer_phone>
<transaction_type>sale</transaction_type>
<original_transaction_unique_id>67fbebc172b743a164a3f3af3d010457</original_transaction_unique_id>
<original_transaction_amount>200.0</original_transaction_amount>
<original_transaction_currency>EUR</original_transaction_currency>
<original_transaction_merchant_transaction_id>12345</original_transaction_merchant_transaction_id>
<amount>3456</amount>
</rapid_dispute_resolution_response>
</rapid_dispute_resolution_responses>
The attributes in the root node rapid dispute resolution responses includes information about the pagination of the response.
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
@per_page | integer | number of entries per page |
@page | integer | the current page |
@total_count | integer | total number of all entries |
@pages_count | integer | total number of pages |
Rapid Dispute Resolution types
RDRs will have one of the following type:
Status | Description |
---|---|
RDR Pre-dispute | RDR for pre-dispute |
RDR Pre-dispute Reversal | RDR Reversal means that the funds already taken from the acquirer with a previously received RDR are reversed to the acquirer's account with Visa and the acquirer could respectively credit the merchant. |
RDR Transfer to Payment Account Retail / RDR Transfer to Paymnt Acct Retail | The money is taken from merchant’s account in Omnipay and are sent to the issuer (as per the RDR rules). |
RDR Transfer to Merchant Hold Account | The money is taken from merchant’s hold account in Omnipay and is sent to the issuer |
RDR Transfer to Write-off Acq | The acquirer is taking the loss for the RDR |
RDR Transfer to Write-off SP | The Service Provider is taking the loss for the RDR |
Retrieval Requests
Retrieval requests are a special type of transactions as they cannot be triggered by the merchant. Retrieval requests occur if the issuer requests additional documentation for a transaction. Retrieval requests do not have financial implication, but they indicate the issuer doubts a given transaction and can initiate a chargeback.
For details, please contact our Risk team.
You can see also see a retrieval request overview in the merchant console under the Risk Management menu.
Retrieval Request notifications
You now have the option to receive API and/or email notifications for each retrieval request event. Enable this feature by emailing the IT Support team at tech-support@emerchantpay.com with the desired notification URL.
The email notifications are sent to the merchant user with role ’admin’ which is configured for managing the merchant entity on the gateway platform. The API notifications are equal to Notification for asynchronous payments, please refer to the section Notification for asynchronous payments to understand how notifications work.
Retrieval Notification Example
?transaction_id=30450
&terminal_token=cd577214de104fa0dd9c28486b3c817fd08c89a6
&unique_id=5de39380bf7ac7e1fc31cbd7805dc0ec
&transaction_type=sale
&status=chargebacked
&signature=98676c91391094b823d1f521d06cc129195952f9
&amount=400
¤cy=USD
&avs_response_code=5I
&avs_response_text=Response+provided+by+issuer+processor%3B+Address+information+not+verified
&cvv_result_code=M
&reason_code=10
&reason_description=Dispute+Transaction
&post_date=2014-07-16
&arn=17b4646c093b025
&event=retrieval_request
Retrieval Request API
The retrieval request API can be used to get info for retrieval requests.
Single Retrieval Request
Single retrieval request retrieval allows to get a certain retrieval request by its ARN or by passing the unique ID of the original transaction.
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.gate.emerchantpay.net/retrieval_equests \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<retrieval_request_request>
<arn>74537604221431003881865</arn>
</retrieval_request_request>'
OR
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.gate.emerchantpay.net/retrieval_equests \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<retrieval_request_request>
<original_transaction_unique_id>53b1f5eacc9e4d3a3afebb4e993fe962</original_transaction_unique_id>
</retrieval_request_request>'
List of Retrieval Request
Retrieve a list of retrieval requests by ARN or by passing the unique ID of the original transaction.
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.gate.emerchantpay.net/retrieval_equests \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<retrieval_request_request>
<arn>74537604221431003881865</arn>
<retrieval_request_request>all</retrieval_request_request>
</retrieval_request_request>'
OR
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.gate.emerchantpay.net/retrieval_equests \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<retrieval_request_request>
<original_transaction_unique_id>53b1f5eacc9e4d3a3afebb4e993fe962</original_transaction_unique_id>
<mode>list</mode>
</retrieval_request_request>'
The URLs for the single and list of retrieval requests API are:
Production:
https://gate.emerchantpay.net/retrieval_equests
Staging (for integration):
https://staging.gate.emerchantpay.net/retrieval_requests
Successful Response
stdClass Object
(
[type] => Retrieval request
[arn] => 74537604221431003881865
[post_date] => 2014-01-24
[reason_code] => 42
[reason_description] => Cardholder request
[authorization_code] => 811714
[merchant_number] => 124000000006698
[issuer_number] => 0000002884
[item_slip_number] => 93778283100
[original_type] => Purchase
[original_slip] => 92572791484
[original_batch_number] => 2093064
[description] => Action Control ID=20140224019152
[fulfillment_date] => 2019-06-28
[original_post_date] => 2019-06-28
[original_transaction_date] => 2019-06-28
[original_transaction_amount] => 148.0
[original_transaction_currency] => EUR
[merchant_settlement_amount] => 148.0
[merchant_settlement_currency] => EUR
[network_settlement_amount] => 148.0
[network_settlement_currency] => EUR
[card_number] => 554960******5069
[card_brand] => master
[customer_email] => jonh_doe@example.com
[customer_phone] => 3598851248512
[transaction_type] => sale3d
[original_transaction_unique_id] => f9634ec5e7dbe6ca3871974accb875cd
[arn] => 74537604221431003881865
)
<payment_response content=[
<type content=[Retrieval request]>
<arn content=[74537604221431003881865]>
<post_date content=[2014-01-24]>
<reason_code content=[42]>
<reason_description content=[Cardholder request]>
<authorization_code content=[811714]>
<merchant_number content=[124000000006698]>
<issuer_number content=[0000002884]>
<item_slip_number content=[93778283100]>
<original_type content=[Purchase]>
<original_slip content=[92572791484]>
<original_batch_number content=[2093064]>
<description content=[Action Control ID=20140224019152]>
<fulfillment_date content=[2019-06-28]>
<original_post_date content=[2019-06-28]>
<original_transaction_date content=[2019-06-28]>
<original_transaction_amount content=[148.0]>
<original_transaction_currency content=[EUR]>
<merchant_settlement_amount content=[148.0]>
<merchant_settlement_currency content=[EUR]>
<network_settlement_amount content=[148.0]>
<network_settlement_currency content=[EUR]>
<card_number content=[554960******5069]>
<card_brand content=[master]>
<customer_email content=[jonh_doe@example.com]>
<customer_phone content=[3598851248512]>
<transaction_type content=[sale3d]>
<original_transaction_unique_id content=[f9634ec5e7dbe6ca3871974accb875cd]>
<arn content=[74537604221431003881865]>
]>
{
type: "Retrieval request",
arn: "74537604221431003881865",
post_date: "2014-01-24",
reason_code: "42",
reason_description: "Cardholder request",
authorization_code: "811714",
merchant_number: "124000000006698",
issuer_number: "0000002884",
item_slip_number: "93778283100",
original_type: "Purchase",
original_slip: "92572791484",
original_batch_number: "2093064",
description: "Action Control ID=20140224019152",
fulfillment_date: "2019-06-28",
original_post_date: "2019-06-28",
original_transaction_date: "2019-06-28",
original_transaction_amount: "148.0",
original_transaction_currency: "EUR",
merchant_settlement_amount: "148.0",
merchant_settlement_currency: "EUR",
network_settlement_amount: "148.0",
network_settlement_currency: "EUR",
card_number: "554960******5069",
card_brand: "master",
customer_email: "jonh_doe@example.com",
customer_phone: "3598851248512",
transaction_type: "sale3d",
original_transaction_unique_id: "f9634ec5e7dbe6ca3871974accb875cd",
arn: "74537604221431003881865",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<retrieval_request_response>
<type>Retrieval request</type>
<arn>74537604221431003881865</arn>
<post_date>2014-01-24</post_date>
<reason_code>42</reason_code>
<reason_description>Cardholder request</reason_description>
<authorization_code>811714</authorization_code>
<merchant_number>124000000006698</merchant_number>
<issuer_number>0000002884</issuer_number>
<item_slip_number>93778283100</item_slip_number>
<original_type>Purchase</original_type>
<original_slip>92572791484</original_slip>
<original_batch_number>2093064</original_batch_number>
<description>Action Control ID=20140224019152</description>
<fulfillment_date>2019-06-28</fulfillment_date>
<original_post_date>2019-06-28</original_post_date>
<original_transaction_date>2019-06-28</original_transaction_date>
<original_transaction_amount>148.0</original_transaction_amount>
<original_transaction_currency>EUR</original_transaction_currency>
<merchant_settlement_amount>148.0</merchant_settlement_amount>
<merchant_settlement_currency>EUR</merchant_settlement_currency>
<network_settlement_amount>148.0</network_settlement_amount>
<network_settlement_currency>EUR</network_settlement_currency>
<card_number>554960******5069</card_number>
<card_brand>master</card_brand>
<customer_email>jonh_doe@example.com</customer_email>
<customer_phone>3598851248512</customer_phone>
<transaction_type>sale3d</transaction_type>
<original_transaction_unique_id>f9634ec5e7dbe6ca3871974accb875cd</original_transaction_unique_id>
</retrieval_request_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
type | string(255) | The retrieval request type. See retrieval request types for details |
arn | string(255) | ARN of the retrieval request’s transaction |
post_date | string(255) | The date of the retrieval request |
reason_code | string(255) | Reason code of the retrieval request |
reason_description | string(255) | Reason description of the retrieval request |
authorization_code | string(255) | Authorization code of the retrieval request’s transaction |
merchant_number | string(20) | Merchant number |
issuer_number | string(14) | Issuer reference number for the retrieval request |
item_slip_number | string(11) | OmniPay internal slip number of the original presentment |
original_type | string(28) | Transaction type of the original presentment |
original_slip | string(11) | OmniPay internal slip number of the original presentment |
original_batch_number | string(23) | The batch number is provided by the submitter of the original presentment |
description | string(255) | Free-text note entered by the institution and associated with the fulfilment |
fulfillment_date | date(8) | Date on which the retrieval request was fulfilled. Empty if not yet fulfilled |
original_post_date | date(8) | Original presentment posting date |
original_transaction_date | date(8) | Transaction date of the original presentment |
original_transaction_amount | float | Amount of the original presentment in major currency unit, see Currency and Amount Handling for details. |
original_transaction_currency | string(3) | Transaction currency of the original presentment |
merchant_settlement_amount | float | Amount settled with the merchant for the original presentment (that is, the amount posted to the merchant account) in major currency unit, before the deduction of any charges, see Currency and Amount Handling for details. |
merchant_settlement_currency | string(3) | Currency settled with the payment network for the presentment before the deduction of any charges. |
network_settlement_amount | float | Amount settled with the merchant for the original presentment (that is, the amount posted to the merchant account) in major currency unit, before the deduction of any charges, see Currency and Amount Handling for details. |
network_settlement_currency | string(3) | Currency settled with the payment network for the presentment before the deduction of any charges. |
card_number | string(255) | Card number used for the retrieval request’s transaction |
card_brand | string(255) | Card brand of the card number |
customer_email | string(255) | The email of the cardholder |
customer_phone | integer | The phone of the cardholder |
transaction_type | string(255) | The type of the retrieval request’s transaction |
original_transaction_unique_id | string(255) | The unique id of the retrieval request’s transaction |
arn | string(255) | ARN of the retrieval request’s transaction |
Error Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<retrieval_request_response>
<status>error</status>
<code>480</code>
<message>Retrieval request not found!</message>
<technical_message>Retrieval request by the given criteria cannot be found!</technical_message>
</retrieval_request_response>
In case no retrieval request is found with the given ARN or unique ID, a corresponding XML error response is received.
By date range
Date range based retrieval request retrieval allows you to fetch information for all retrieval requests for a given merchant within a given date range. Date range searches for retrieval requests by their posting date. The response is paginated, each request will return 100 entries max.
The URLs for date range retrieval request retrieval are:
Production:
https://gate.emerchantpay.net/retrieval_requests/by_date
Staging (for integration):
https://staging.gate.emerchantpay.net/retrieval_requests/by_date
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.gate.emerchantpay.net/retrieval_requests/by_date \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<retrieval_request_request>
<start_date>2014-01-01</start_date>
<end_date>2014-01-31</end_date>
<page>1</page>
</retrieval_request_request>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
start_date | required | yyyy-mm-dd | start of the requested date range |
end_date | optional | yyyy-mm-dd | end of the requested date range |
import_date | optional | yyyy-mm-dd | date of import in our system. Spans from beggining until end of day. |
page | optional | integer | the page within the paginated result, defaults to 1 |
per_page | optional | integer | Number of entities on page, defaults to 100 |
externally_processed | optional | string(255) | Filters retrieval requests by being externally processed or being native to Genesis. Possible values include 'genesis', 'external', and 'all'. If flag not supplied, it defaults to 'genesis' |
processing_type | optional | string(255) | Filters retrieval requests by being card present or card not present. Possible values include 'card_present', 'card_not_present', and 'all'. If flag not supplied, it defaults to 'all'. |
required* = conditionally required
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<retrieval_request_responses per_page="100" page="1" total_count="2" pages_count="1">
<retrieval_request_response>
<type>Retrieval request</type>
<post_date>2014-01-24</post_date>
<reason_code>42</reason_code>
<reason_description>Cardholder request</reason_description>
<authorization_code>811714</authorization_code>
<merchant_number>124000000006698</merchant_number>
<issuer_number>0000002884</issuer_number>
<item_slip_number>93778283100</item_slip_number>
<original_type>Purchase</original_type>
<original_slip>92572791484</original_slip>
<original_batch_number>2093064</original_batch_number>
<description>Action Control ID=20140224019152</description>
<fulfillment_date>2019-06-28</fulfillment_date>
<original_post_date>2019-06-28</original_post_date>
<original_transaction_date>2019-06-28</original_transaction_date>
<original_transaction_amount>148.0</original_transaction_amount>
<original_transaction_currency>EUR</original_transaction_currency>
<merchant_settlement_amount>148.0</merchant_settlement_amount>
<merchant_settlement_currency>EUR</merchant_settlement_currency>
<network_settlement_amount>148.0</network_settlement_amount>
<network_settlement_currency>EUR</network_settlement_currency>
<card_number>554960******5069</card_number>
<card_brand>master</card_brand>
<customer_email>jonh_doe@example.com</customer_email>
<customer_phone>3598851248512</customer_phone>
<transaction_type>sale3d</transaction_type>
<original_transaction_unique_id>f9634ec5e7dbe6ca3871974accb875cd</original_transaction_unique_id>
<arn>74537604221431003881865</arn>
</retrieval_request_response>
<retrieval_request_response>
<type>Retrieval request</type>
<post_date>2014-01-27</post_date>
<reason_code>42</reason_code>
<reason_description>Cardholder request</reason_description>
<authorization_code>811714</authorization_code>
<merchant_number>124000000006698</merchant_number>
<issuer_number>0000002884</issuer_number>
<item_slip_number>93778283100</item_slip_number>
<original_type>Purchase</original_type>
<original_slip>92572791484</original_slip>
<original_batch_number>2093064</original_batch_number>
<description>Action Control ID=20140224019152</description>
<fulfillment_date>2019-06-28</fulfillment_date>
<original_post_date>2019-06-28</original_post_date>
<original_transaction_date>2019-06-28</original_transaction_date>
<original_transaction_amount>148.0</original_transaction_amount>
<original_transaction_currency>EUR</original_transaction_currency>
<merchant_settlement_amount>148.0</merchant_settlement_amount>
<merchant_settlement_currency>EUR</merchant_settlement_currency>
<network_settlement_amount>148.0</network_settlement_amount>
<network_settlement_currency>EUR</network_settlement_currency>
<card_number>454360******5008</card_number>
<card_brand>visa</card_brand>
<customer_email>ivan@example.net</customer_email>
<customer_phone>3598851248512</customer_phone>
<transaction_type>sale</transaction_type>
<original_transaction_unique_id>67fbebc172b743a164a3f3af3d010457</original_transaction_unique_id>
<arn>74537604221431003881865</arn>
</retrieval_request_response>
</retrieval_request_responses>
The attributes in the root node retrieval_request_responses includes information about the pagination of the response.
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
@per_page | integer | number of entries per page |
@page | integer | the current page |
@total_count | integer | total number of all entries |
@pages_count | integer | total number of pages |
Fraud reports
SAFE/TC40 reports contain information for transactions reported as fraud to MasterCard or VISA.
You can see a SAFE/TC40 reports overview in the merchant console under the Risk management menu.
SAFE/TC40 API
The SAFE/TC40 API can be used to retrieve data about SAFE/TC40 reports.
Fraud report codes
Code | Type | Description |
---|---|---|
0 | string(1) | Lost |
1 | string(1) | Stolen |
2 | string(1) | Card not received as issued (NRI) |
3 | string(1) | Fraudulent application |
4 | string(1) | Issuer-reported counterfeit |
5 | string(1) | Miscellaneous/Account takeover |
6 | string(1) | Fraudulent use of account number |
7 | string(1) | (U.S. only) used by ICS |
8 | string(1) | (U.S. only) used by ICS |
9 | string(1) | Acquirer-reported counterfeit' |
Single SAFE/TC40 report
Single SAFE/TC40 retrieval allows to get a certain SAFE/TC40 by its ARN or by passing the unique ID of the original transaction.
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.gate.emerchantpay.net/fraud_reports \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<fraud_report_request>
<arn>74537604221431003881865</arn>
</fraud_report_request>'
OR
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.gate.emerchantpay.net/fraud_reports \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<fraud_report_request>
<original_transaction_unique_id>53b1f5eacc9e4d3a3afebb4e993fe962</original_transaction_unique_id>
</fraud_report_request>'
List of SAFE/TC40 report
Retrieve a list of SAFE/TC40 by ARN or by passing the unique ID of the original transaction.
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.gate.emerchantpay.net/fraud_reports \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<fraud_report_request>
<fraud_report_request>arn,</fraud_report_request>
<mode>list</mode>
</fraud_report_request>'
OR
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.gate.emerchantpay.net/fraud_reports \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<fraud_report_request>
<original_transaction_unique_id>53b1f5eacc9e4d3a3afebb4e993fe962</original_transaction_unique_id>
<mode>list</mode>
</fraud_report_request>'
The URLs for the single and list of SAFE/TC40 API are:
Production:
https://gate.emerchantpay.net/fraud_reports
Staging (for integration):
https://staging.gate.emerchantpay.net/fraud_reports
Successful Response
stdClass Object
(
[arn] => 74537604221431003881865
[post_date] => 2014-01-24
[reason_code] => 6
[reason_description] => Card not present
[original_transaction_amount] => 450
[original_transaction_currency] => GBP
[card_number] => 554960******5069
[card_brand] => master
[customer_email] => name@example.net
[customer_phone] => +359885934567
[transaction_type] => recurring_sale
[original_transaction_unique_id] => f9634ec5e7dbe6ca3871974accb875cd
[chargeback_amount] => 450
[chargeback_currency] => USD
[report_date] => 2014-05-07
)
<payment_response content=[
<arn content=[74537604221431003881865]>
<post_date content=[2014-01-24]>
<reason_code content=[6]>
<reason_description content=[Card not present]>
<original_transaction_amount content=[450]>
<original_transaction_currency content=[GBP]>
<card_number content=[554960******5069]>
<card_brand content=[master]>
<customer_email content=[name@example.net]>
<customer_phone content=[+359885934567]>
<transaction_type content=[recurring_sale]>
<original_transaction_unique_id content=[f9634ec5e7dbe6ca3871974accb875cd]>
<chargeback_amount content=[450]>
<chargeback_currency content=[USD]>
<report_date content=[2014-05-07]>
]>
{
arn: "74537604221431003881865",
post_date: "2014-01-24",
reason_code: "6",
reason_description: "Card not present",
original_transaction_amount: "450",
original_transaction_currency: "GBP",
card_number: "554960******5069",
card_brand: "master",
customer_email: "name@example.net",
customer_phone: "+359885934567",
transaction_type: "recurring_sale",
original_transaction_unique_id: "f9634ec5e7dbe6ca3871974accb875cd",
chargeback_amount: "450",
chargeback_currency: "USD",
report_date: "2014-05-07",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<fraud_report_response>
<arn>74537604221431003881865</arn>
<post_date>2014-01-24</post_date>
<reason_code>6</reason_code>
<reason_description>Card not present</reason_description>
<original_transaction_amount>450</original_transaction_amount>
<original_transaction_currency>GBP</original_transaction_currency>
<card_number>554960******5069</card_number>
<card_brand>master</card_brand>
<customer_email>name@example.net</customer_email>
<customer_phone>+359885934567</customer_phone>
<transaction_type>recurring_sale</transaction_type>
<original_transaction_unique_id>f9634ec5e7dbe6ca3871974accb875cd</original_transaction_unique_id>
<chargeback_amount>450</chargeback_amount>
<chargeback_currency>USD</chargeback_currency>
<report_date>2014-05-07</report_date>
</fraud_report_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
arn | string(255) | ARN of the chargeback’s transaction |
post_date | yyyy-mm-dd | When the transaction was posted |
reason_code | string(1) | Fraud report codes. See the codes here |
reason_description | string(255) | Text description of reason code |
original_transaction_amount | integer | The amount of the initial transaction in minor units |
original_transaction_currency | integer | The initial transaction currency |
card_number | string(255) | Card number used for the chargeback’s transaction |
card_brand | string(255) | Card brand of the card number |
customer_email | string(255) | The email of the cardholder |
customer_phone | integer | The phone of the cardholder |
transaction_type | string(255) | The type of the chargeback’s transaction |
original_transaction_unique_id | string(255) | The unique id of the initial transaction |
chargeback_amount | integer | The amount of the the chargeback’s transaction in minor units |
chargeback_currency | string(3) | The currency of the the chargeback’s transaction |
report_date | yyyy-mm-dd | The report entered date in the note payload |
Error Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<fraud_report_response>
<status>error</status>
<code>490</code>
<message>Mastercard Fraud Report not found!</message>
<technical_message>Mastercard fraud report by the given criteria cannot be found!</technical_message>
</fraud_report_response>
In case no SAFE/TC40 is found for the given ARN or unique ID, a corresponding XML response is as follows:
By date range
Date range based SAFE/TC40 retrieval allows you to fetch information for all SAFE/TC40 reports for a given merchant within a given date range.
Date range searches include:
- for SAFE/TC40 reports by their posting date.
- for SAFE/TC40 retrieval by their import (creation) date.
- for SAFE/TC40 retrieval by their fraud report date.
The response is paginated, each request will return 100 entries max.
The URLs for date range SAFE/TC40 retrieval are:
Production:
https://gate.emerchantpay.net/fraud_reports/by_date
Staging (for integration):
https://staging.gate.emerchantpay.net/fraud_reports/by_date
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.gate.emerchantpay.net/fraud_reports/by_date \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<fraud_report_request>
<start_date>2014-01-01</start_date>
<end_date>2014-01-31</end_date>
<page>1</page>
</fraud_report_request>'
OR
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.gate.emerchantpay.net/fraud_reports/by_date \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<fraud_report_request>
<import_date>2014-01-01</import_date>
<page>1</page>
</fraud_report_request>'
OR
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.gate.emerchantpay.net/fraud_reports/by_date \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<fraud_report_request>
<report_start_date>2014-01-01</report_start_date>
<report_end_date>2014-01-31</report_end_date>
<page>1</page>
</fraud_report_request>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
start_date | required* | yyyy-mm-dd | Start of the requested date range |
end_date | optional | yyyy-mm-dd | End of the requested date range |
import_date | required* | yyyy-mm-dd | Date of import in our system. Spans from beginning until end of day. |
report_start_date | required* | yyyy-mm-dd | Start of the requested date range for the date when the fraud was reported |
report_end_date | optional | yyyy-mm-dd | End of the requested date range for the date when the fraud was reported |
page | optional | integer | The page within the paginated result, defaults to 1 |
per_page | optional | integer | Number of entities on page, defaults to 100 |
required* = conditionally required
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<fraud_report_responses per_page="100" page="1" total_count="2" pages_count="1">
<fraud_report_response>
<arn>74537604221431003881865</arn>
<post_date>2014-01-24</post_date>
<reason_code>6</reason_code>
<reason_description>Card not present</reason_description>
<original_transaction_amount>450</original_transaction_amount>
<original_transaction_currency>GBP</original_transaction_currency>
<card_number>554960******5069</card_number>
<card_brand>master</card_brand>
<customer_email>name@example.net</customer_email>
<customer_phone>+359885934567</customer_phone>
<transaction_type>recurring_sale</transaction_type>
<original_transaction_unique_id>f9634ec5e7dbe6ca3871974accb875cd</original_transaction_unique_id>
<chargeback_amount>450</chargeback_amount>
<chargeback_currency>USD</chargeback_currency>
<report_date>2014-05-07</report_date>
</fraud_report_response>
<fraud_report_response>
<arn>67fbebc172b743a164a3f3af3d010457</arn>
<post_date>2014-05-27</post_date>
<reason_code>6</reason_code>
<reason_description>Card not present</reason_description>
<original_transaction_amount>450</original_transaction_amount>
<original_transaction_currency>USD</original_transaction_currency>
<card_number>554960******5069</card_number>
<card_brand>master</card_brand>
<customer_email>name@example.net</customer_email>
<customer_phone>+359886213231</customer_phone>
<transaction_type>recurring_sale</transaction_type>
<original_transaction_unique_id>67fbebc172b743a164a3f3af3d010457</original_transaction_unique_id>
<chargeback_amount>450</chargeback_amount>
<chargeback_currency>USD</chargeback_currency>
<report_date>2014-05-07</report_date>
</fraud_report_response>
</fraud_report_responses>
Conditionally required attributes mean that, you need to either send start/end_date, import_date or report_start/end_date.
The attributes in the root node fraud report responses includes information about the pagination of the response.
Blacklists
With the Blacklist API you can check if a certain credit card is blacklisted within the gateway. If a terminal token is not passed, the merchant and global PAN blacklists will be checked for the given card number. If a terminal token is passed, the terminal, its merchant, and the global PAN blacklists will be checked for blacklist matches.
The URLs for the Blacklist API are:
Production:
https://gate.emerchantpay.net/blacklists
Staging (for integration):
https://staging.gate.emerchantpay.net/blacklists
Invoking a Request
A transaction is invoked via HTTPS POST, parameters are passed as XML with UTF-8 encoding.
<?xml version="1.0" encoding="UTF-8"?>
<blacklist_request>
<card_number>4200000000000000</card_number>
<terminal_token>abd30ed00f88f838c5d233cbb62b6da0b69267b4</terminal_token>
</blacklist_request>
Parameter | Required | Format | Description |
---|---|---|---|
card_number | required | int(13..16) | the credit card number to be checked |
terminal_token | optional | string(40) | the terminal token |
Response
Successful response:
<?xml version="1.0" encoding="UTF-8"?>
<blacklist_response>
<blacklisted>true</blacklisted>
</blacklist_response>
Name | Type | Description |
---|---|---|
blacklisted | boolean | credit card number is blacklisted or not |
Error response:
<?xml version="1.0" encoding="UTF-8"?>
<blacklist_response>
<code>350</code>
<message>Invalid XML: No close tag for /blacklist_request</message>
</blacklist_response>
Name | Type | Description |
---|---|---|
code | integer | error code of the error that occurred |
message | string | info about the error |
Asynchronous Transactions and Notifications
Asynchronous Transactions
3D-Secure transactions can be either processed asynchronously or synchronously depending on the 3DSv2 authentication flow that will be reached (For more information, go to the 3DSv2-Authentication flows). Other types of transactions that are processed asynchronously, are payments that require the end-user to complete the payment using the redirect_url that is returned from the API within the synchronous response. Such transaction types are Sofort, iDeal Online Banking ePayments and others (For more information, check the documentation per transaction type and the available API responses - either synchronous or asynchronous response).
This means that the final result of the transaction will not be available immediately and the status is pending async. Once the transaction has reached a final status, a Notification is sent to the merchant.
Overview
Transaction type | async? |
---|---|
Authorize | never |
Authorize3d | always |
Sale | never |
Sale3d | always |
Capture | never |
Refund | never |
Async Refund | always |
Void | never |
InitRecurringSale | never |
InitRecurringSale3D | always |
RecurringSale | never |
Credit | never |
BitPay Sale | always |
BitPay Refund | always |
iDeal | always |
Sofort | always |
Notifications
For asynchronous payments, a notification is always sent, either to the notification_url provided within the payment transaction or to the one configured in the merchant account.
The payment gateway can be configured to also send a notification after each synchronous payment transaction. The notification is sent to the notification_url which is configured per merchant.
Also see 3-D Secure Transactions and Notification for asynchronous payments.
The format of the notification in both cases is the same.
Notification Example
?transaction_id=82803B4C-70CC-43BD-8B21-FD0395285B40
&unique_id=44177a21403427eb96664a6d7e5d5d48
&transaction_type=sale3d
&terminal_token=394f2ebc3646d3c017fa1e1cbc4a1e20
&status=approved
&amount=500
&signature=088e16a1019277b15d58faf0541e11910eb756f6
&payment_account_reference=50019P9LBXOLHN9G7QMU5VN520YSY
&consumer_id=123456
&token=ee946db8-d7db-4bb7-b608-b65b153e127d
&eci=05
&avs_response_code=5I
&avs_response_text=Response+provided+by+issuer+processor%3B+Address+information+not+verified
&cvv_result_code=M
&scheme_response_code=00
&scheme_transaction_identifier=MCS267BG0
&scheme_transaction_link_id=TLINKIDENTIFIER4521412
&scheme_pan_indicator=V
&scheme_pan_tail=0013
&scheme_settlement_date=1103
&reason_for_not_honoring_exemption=8A01
&sca_exemption_result=13
&scheme_max_settlement_date=2024-07-31
&scheme_authentication_data_quality=true
Sofort Notification Example
?transaction_id=82803B4C-70CC-43BD-8B21-FD0395285B40
&unique_id=44177a21403427eb96664a6d7e5d5d48
&transaction_type=sofort
&terminal_token=394f2ebc3646d3c017fa1e1cbc4a1e20
&status=approved
&amount=500
&signature=088e16a1019277b15d58faf0541e11910eb756f6
&funds_status=sent
&account_holder=name+surname
&bank_account_number=DE89370400440532013000
&bank_identifier_code=GENODETT488
Parameters
Name | Type | Description |
---|---|---|
transaction_id | string | merchant generated transaction id |
unique_id | string | unique id generated by Genesis |
transaction_type | string | transaction type for the transaction eg: sale3d |
terminal_token | string | the terminal token as used in the processing url |
status | string | status of the payment transaction |
amount | string | amount of the payment transaction. If the transaction is partially approved, this is the partially approved amount. Check Partial Approvals for details |
partial_approval | string | If the transaction is partially approved, this is set to 'true'. Check Partial Approvals for details |
signature | string | the signature of the notification, should be used to verify the notification was sent by Genesis |
funds_status | string | funds status of transaction *present only when the transaction has funds status |
account_holder | string | account Holder of transaction's bank account. *present only when the transaction has account holder |
consumer_id | string(10) | Consumer unique reference. See Consumers |
token | string(36) | Plain-text token value. See Tokenize |
eci | string | See Electronic Commerce Indicator as returned from the MPI for details |
event | string | The event that caused the notification |
rc_code | string | The reason code for the event |
rc_description | string | The reason description for the event |
avs_response_code | string | Generated by the card network on trying to match the billing ad- dress when performing the address verification. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
avs_response_text | string | Gives the human response text for the AVS response code above. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
cvv_result_code | string | Card Verification Value response code. Optional, returned only if acquirer supports it. |
reference_transaction_unique_id | string | The unique id generated by Genesis, identifies the reference transaction if present. |
authorization code | string | A code returned by some acquirers to indicate that a card payment has been authorized. |
retrieval_reference_number | string | A reference number used for tracking all messages related to a given cardholder transaction returned by some acquirers. |
scheme_response_code | string | The response code returned from the schemes. |
recurring_advice_code | string | An additional response code returned from the schemes. Specifies if the transaction can be retried in case of failure. |
recurring_advice_text | string | The text representation of the recurring advice code. |
threeds_authentication_flow | string | Identifies the concrete 3DS authentication flow that the transaction has gone through. It will be available in the notification only if the consumer has finished the 3DS authentication with the issuer. The available values for 3DSv2 are frictionless and challenge. |
threeds_method_status | string | Identifies the status of the 3DS-Method in the scope of 3DSv2 authentication protocol. The possible values are required, in_progress and completed. For more details about the 3DS-Method submission, go to the 3DSv2 authentication flows. |
threeds_target_protocol_version | string(1) | Identifies the 3DS protocol that has been enforced. The possible values are 2. |
threeds_concrete_protocol_version | string(1) | Identifies the concrete 3DS protocol version that the transaction has gone through. The possible values are 2. |
threeds_protocol_sub_version | string(1) | Identifies the 3DS protocol sub-version that the transaction has gone through. The possible values are 1, 2, 3, 4, 5, 6, 7, 8, 9. |
threeds_authentication_status_reason_code | string(2) | See 3DS Authentication Status Reason Codes for details. |
scheme_transaction_identifier | string | The text representation of the scheme transaction identifier. |
scheme_settlement_date | string | The text representation of the scheme settlement date. |
card_brand | string* | The brand of the card used for the transaction. |
card_number | string* | The card number of the card used for the transaction. |
card_type | string* | The type of the card used for the transaction. |
card_subtype | string* | The subtype of the card used for the transaction. |
card_issuing_bank | string* | The card issuer. |
card_holder | string* | The card holder. |
expiration_year | string* | The expiration year of the card. |
expiration_month | string* | The expiration month of the card. |
status | string* | The transaction status. |
customer_email | string* | The email of the customer. |
customer_phone | string* | The phone of the customer. |
first_name | string* | The first name of the customer. |
last_name | string* | The last name of the customer. |
address1 | string* | The address of the customer. |
address2 | string* | The second line of address of the customer. |
zip_code | string* | The zip code of the customer. |
city | string* | The city of the customer. |
state | string* | The state of the customer. |
country | string* | The country of the customer. |
arn acquirer_reference_number | string* | The unique number assigned to the card transaction as it moves through the payment flow. |
bank_account_number | string* | The IBAN number of the customer. |
bank_identifier_code | string* | The BIC of the customer bank. |
currency | string* | The currency of the transaction. |
reason_for_not_honoring_exemption | string | Reason for not honoring exemption. Check SCA Reason For Not Honoring Exemption Values. |
sca_exemption_result | string | SCA exemption result. Check SCA Exemption Result Values. |
scheme_transaction_link_id | string | The transaction unique identifier returned from the schemes. |
scheme_pan_indicator | string | The account number indicator in scheme-tokenized transactions. See Account number indicator codes for details. |
scheme_pan_tail | string | The tail of the PAN number associated with the token in scheme-tokenized transactions. Returned in conjunction with scheme_pan_indicator . |
payment_account_reference | string | The payment account reference value returned from the schemes. |
scheme_max_settlement_date | string | The final date an authorization could be captured which is returned from the card scheme. See Scheme Maximum Settlement Date for more details. |
scheme_authentication_data_quality | boolean | The Authentication Data Quality Indicator returned by the card scheme is used to indicate whether a transaction meets the authentication data quality requirements. The value can be either true or false . |
string* = This is an optional parameter.
Contact tech-support@emerchantpay.com for more details
Status will be either "declined", "approved" or "error", like shown in the states table.
The event parameter is added only for fraud transactions eg: chargeback, chargeback_reversal, representment, representment_reversal, second_chargeback or retrieval_request.
The signature is a mean of security to ensure that the gate is really the sender of the notification. It is generated by concatenating the unique id of the transaction with your API password and generating a Hash of the string using SHA algorithm:
SHA Hash Hex of <unique_id><Your API password>
Possible encryption algorithms:
- SHA-1 (by default)
- SHA-256
- SHA-512
To change the encryption algorithm please contact Tech Support.
Notification signature examples
unique_id | API password | algorithm | signature |
---|---|---|---|
fc6c3c8c0219730c7a099eaa540f70dc | bogus | SHA-1 | 08d01ae1ebdc22b6a1a764257819bb26e9e94e8d |
130319cfb3bf65ff3c4a4045487b173e | test123 | SHA-256 | e4c5e70de4a5b00663122f0b902ff4bb73f4542354e3a1edecf24a038576596d |
a459f8781f2fe14a6e787648c146be02 | secret | SHA-512 | 162528f9760c188076ca1694701f7827e4904f2f7c72179a9c493989e8ba2c73318f818d61a4685485296f95a4c0aba0d826890eeef618a78df6ba50f170da69 |
You can use the signature to verify the integrity of the notification, ensuring that it was really sent by the gate.
<?xml version="1.0" encoding="UTF-8"?>
<notification_echo>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
</notification_echo>
When receiving the notification, you are required to render an xml page containing the transaction’s unique id so that the gateway knows that you have accepted the notification. If the XML is not delivered, the notification is sent periodically until the XML is received.
WPF
The WPF (Web Payment Form) is a customizable component of the Genesis payment gateway. It provides merchants with an intuitive user interface to easily process their customers’ payments. Through a single point of integration, the merchant can offer his customers multiple payment methods instantly and since the WPF is hosted on the secure Genesis infrastructure, it is already PCI-DSS compliant.
Workflow
In the example above the customer visits the merchant’s website and does a checkout.
(1), the merchant initiates the payment on the Genesis payment gateway through a request to the WPF API, which carries the mandatory, initial payload (e.g. amount, currency, etc.). The response to this request (if successful) is a redirect URL, which the merchants hands over to the customer. Following this redirect URL
(2), the customer is then directed to the actual payment form (WPF), which gets served from the Genesis servers. Because the merchant has previously transmitted most of the relevant payment information, the form is prefilled with these values and the customer only needs to add personal data. The customer then selects one of the payment methods offered by the merchant and fills in his payment information
(3) (e.g. credit card data). Upon completion the customer is redirected back to the merchant
(4)1. After the payment has been processed and reached a final state the merchant is sent a notification
(5) to the notification url supplied in the initial create request (1). The merchant must either use the notification’s signature to verify the payment’s integrity or make a reconcile
(6) to check the final payment status. However, we urge all merchants to always do a reconcile.
1 - Particularly to the return success url defined by the merchant in his initial request. If the customer has selected an asynchronous payment method, he is redirected to the MPI provider before this step
Express Checkout
Apple Pay
When Apple Pay
transaction type is sent in the initial WPF create request, the consumer
will have an option to pay using enabled debit or credit card in the Apple Wallet instead of
adding its payment details to the form, step (2) from the main workflow.
Apple Pay is available on all iOS devices with a Secure Element — an industry-standard, certified chip designed to store payment information safely. In macOS, users must have an Apple Pay-capable iPhone or Apple Watch to authorize the payment, or a MacBook Pro with Touch ID.
In order to do so, while the consumer is on the WPF form page, there should be a Apple Pay
button:
After this, the consumer should select the Apple Pay
button.
Then a pop-up window with its predefined card details will appear and the consumer will be able to select any of the predefined cards to complete the payment. In macOS, consumers will be asked to turn on the Bluetooth on the mobile phone and pair the devices in order to be able to fetch and display the registered cards in Apple Wallet.
Lastly, the consumer should complete the payment either using biometric authentication such as fingerprint, Face ID on his/her mobile phone or to follow additional instructions on the popup window and the payment will be automatically processed with the next step (3) from the main workflow.
All other steps are the same as in the main workflow.
Google Pay
When Google Pay
transaction type is sent in the initial WPF create request, the consumer
will have an option to pay using saved to its Google
account debit or credit card instead of
adding its payment details to the form, step (2) from the main workflow.
In order to do so while the consumer is on the WPF form page, there should be a Google Pay
button:
After this, the consumer should select the Pay with Google Pay
button.
Then a pop-up window with its predefined card details will appear and the consumer will be able to select any of the
predefined cards or add a new payment option which will be saved to its Google
account for next payments.
Lastly, the consumer should confirm the selected payment option and the payment will be automatically processed with the next step (3) from the main workflow.
All other steps are the same as in the main workflow.
WPF API
URLs
Create:
The URL for the WPF API create method is:
https://wpf.emerchantpay.net/<locale>/wpf
For the test system the URL is:
https://staging.wpf.emerchantpay.net/<locale>/wpf
Note that if you do not submit one of the available locales, defaults to 'en' (English).
Check the WPF Internationalization (i18n) for details.
Reconcile:
The URL for the WPF API reconcile method is:
https://wpf.emerchantpay.net/wpf/reconcile
For the test system the URL is:
https://staging.wpf.emerchantpay.net/wpf/reconcile
Create
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('WPF\Create');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setDescription('You are about to buy 3 shoes at www.shoes.com!')
->setNotificationUrl('https://www.example.com/notification')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setReturnCancelUrl('http://www.example.com/cancel.html')
->setReturnPendingUrl('http://www.example.com/payment-pending.html')
->setAmount('100')
->setCurrency('USD')
->setConsumerId('123456')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
->setRememberCard('true')
->setLifetime('60')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
// Risk Params
->setRiskUserId('123456')
// Transaction Types
->addTransactionType('authorize')
->addTransactionType('sale')
->setPayLater('true')
// Reminders
->addReminder('email', '40')
->addReminder('sms', '10')
// Sca Params
->setScaExemption('low_value')
// Account Owner
->setAccountFirstName('Travis')
->setAccountMiddleName('Joe')
->setAccountLastName('Pastrana')
->setWebPaymentFormId('1');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.wpf.WPFCreateRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
WPFCreateRequest request = new WPFCreateRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setDescription("You are about to buy 3 shoes at www.shoes.com!");
request.setNotificationUrl(new URL("https://www.example.com/notification"));
request.setReturnSuccessUrl(new URL("http://www.example.com/success"));
request.setReturnFailureUrl(new URL("http://www.example.com/failure"));
request.setReturnCancelUrl(new URL("http://www.example.com/cancel.html"));
request.setReturnPendingUrl(new URL("http://www.example.com/payment-pending.html"));
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setConsumerId("123456");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
request.setRememberCard("true");
request.setLifetime(60);
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
// Risk Params
request.setRiskUserId("123456");
// Transaction Types
request.addTransactionType("authorize").done();
request.addTransactionType("sale").done();
request.setPayLater("true");
// Sca Params
request.setScaExemption("low_value");
// Account Owner
request.setAccountFirstname("Travis");
request.setAccountMiddlename("Joe");
request.setAccountLastname("Pastrana");
request.setWebPaymentFormId("1");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.wpf_create(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"description": "You are about to buy 3 shoes at www.shoes.com!",
"notification_url": "https://www.example.com/notification",
"return_success_url": "http://www.example.com/success",
"return_failure_url": "http://www.example.com/failure",
"return_cancel_url": "http://www.example.com/cancel.html",
"return_pending_url": "http://www.example.com/payment-pending.html",
"amount": "100",
"currency": "USD",
"consumer_id": "123456",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"remember_card": "true",
"lifetime": 60,
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"risk_params": {
"user_id": "123456"
},
"transaction_types": [
"authorize",
"sale"
],
"business_attributes": {
"name_of_the_supplier": "Best Furniture"
},
"pay_later": true,
"reminder_language": "en",
"reminders": [
{
"channel": "email",
"after": 40
},
{
"channel": "sms",
"after": 10
}
],
"sca_params": {
"exemption": "low_value"
},
"account_owner": {
"first_name": "Travis",
"middle_name": "Joe",
"last_name": "Pastrana"
},
"web_payment_form_id": "1"
}
).send()
.then(success)
.catch(failure);
Request
curl https://staging.wpf.emerchantpay.net/wpf \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<wpf_payment>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<description>You are about to buy 3 shoes at www.shoes.com!</description>
<notification_url>https://www.example.com/notification</notification_url>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<return_cancel_url>http://www.example.com/cancel.html</return_cancel_url>
<return_pending_url>http://www.example.com/payment-pending.html</return_pending_url>
<amount>100</amount>
<currency>USD</currency>
<consumer_id>123456</consumer_id>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<remember_card>true</remember_card>
<lifetime>60</lifetime>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<risk_params>
<user_id>123456</user_id>
</risk_params>
<transaction_types>
<transaction_type moto="true" name="authorize" fx_rate_id="123" recurring_type="initial"/>
<transaction_type crypto="true" name="sale" fx_rate_id="123" recurring_type="initial"/>
</transaction_types>
<business_attributes>
<name_of_the_supplier>Best Furniture</name_of_the_supplier>
</business_attributes>
<pay_later>true</pay_later>
<reminder_language>en</reminder_language>
<reminders>
<reminder>
<channel>email</channel>
<after>40</after>
</reminder>
<reminder>
<channel>sms</channel>
<after>10</after>
</reminder>
</reminders>
<sca_params>
<exemption>low_value</exemption>
</sca_params>
<account_owner>
<first_name>Travis</first_name>
<middle_name>Joe</middle_name>
<last_name>Pastrana</last_name>
</account_owner>
<web_payment_form_id>1</web_payment_form_id>
</wpf_payment>'
Funding Transaction Example
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('WPF\Create');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setDescription('You are about to buy 3 shoes at www.shoes.com!')
->setNotificationUrl('https://www.example.com/notification')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setReturnCancelUrl('http://www.example.com/cancel.html')
->setReturnPendingUrl('http://www.example.com/payment-pending.html')
->setAmount('100')
->setCurrency('USD')
->setConsumerId('123456')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
->setRememberCard('true')
->setLifetime('60')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
// Risk Params
->setRiskUserId('123456')
// Transaction Types
->addTransactionType('authorize')
->addTransactionType('sale')
->setPayLater('true')
// Reminders
->addReminder('email', '40')
->addReminder('sms', '10')
// Sca Params
->setScaExemption('low_value')
// Account Owner
->setAccountFirstName('Travis')
->setAccountMiddleName('Joe')
->setAccountLastName('Pastrana')
->setWebPaymentFormId('1')
->setFunding('{"identifier_type"=>"business_disbursement", "business_application_identifier"=>"funds_disbursement", "receiver"=>{"first_name"=>"Hamza", "last_name"=>"Arshad", "country"=>"AF", "account_number"=>"090078601", "account_number_type"=>"iban", "address"=>"Gulberg 21 street", "state"=>"CN", "city"=>"Lahore"}, "sender"=>{"name"=>"John Wick", "country"=>"BG", "reference_number"=>"90078602", "address"=>"Meow street 5", "state"=>"CN", "city"=>"Columbia"}}');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.wpf.WPFCreateRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
WPFCreateRequest request = new WPFCreateRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setDescription("You are about to buy 3 shoes at www.shoes.com!");
request.setNotificationUrl(new URL("https://www.example.com/notification"));
request.setReturnSuccessUrl(new URL("http://www.example.com/success"));
request.setReturnFailureUrl(new URL("http://www.example.com/failure"));
request.setReturnCancelUrl(new URL("http://www.example.com/cancel.html"));
request.setReturnPendingUrl(new URL("http://www.example.com/payment-pending.html"));
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setConsumerId("123456");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
request.setRememberCard("true");
request.setLifetime(60);
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
// Risk Params
request.setRiskUserId("123456");
// Transaction Types
request.addTransactionType("authorize").done();
request.addTransactionType("sale").done();
request.setPayLater("true");
// Sca Params
request.setScaExemption("low_value");
// Account Owner
request.setAccountFirstname("Travis");
request.setAccountMiddlename("Joe");
request.setAccountLastname("Pastrana");
request.setWebPaymentFormId("1");
request.setFunding("{"identifier_type"=>"business_disbursement", "business_application_identifier"=>"funds_disbursement", "receiver"=>{"first_name"=>"Hamza", "last_name"=>"Arshad", "country"=>"AF", "account_number"=>"090078601", "account_number_type"=>"iban", "address"=>"Gulberg 21 street", "state"=>"CN", "city"=>"Lahore"}, "sender"=>{"name"=>"John Wick", "country"=>"BG", "reference_number"=>"90078602", "address"=>"Meow street 5", "state"=>"CN", "city"=>"Columbia"}}");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.wpf_create(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"description": "You are about to buy 3 shoes at www.shoes.com!",
"notification_url": "https://www.example.com/notification",
"return_success_url": "http://www.example.com/success",
"return_failure_url": "http://www.example.com/failure",
"return_cancel_url": "http://www.example.com/cancel.html",
"return_pending_url": "http://www.example.com/payment-pending.html",
"amount": "100",
"currency": "USD",
"consumer_id": "123456",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"remember_card": "true",
"lifetime": 60,
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"risk_params": {
"user_id": "123456"
},
"transaction_types": [
"authorize",
"sale"
],
"business_attributes": {
"name_of_the_supplier": "Best Furniture"
},
"pay_later": true,
"reminder_language": "en",
"reminders": [
{
"channel": "email",
"after": 40
},
{
"channel": "sms",
"after": 10
}
],
"sca_params": {
"exemption": "low_value"
},
"account_owner": {
"first_name": "Travis",
"middle_name": "Joe",
"last_name": "Pastrana"
},
"web_payment_form_id": "1",
"funding": {
"identifier_type": "business_disbursement",
"business_application_identifier": "funds_disbursement",
"receiver": {
"first_name": "Hamza",
"last_name": "Arshad",
"country": "AF",
"account_number": "090078601",
"account_number_type": "iban",
"address": "Gulberg 21 street",
"state": "CN",
"city": "Lahore"
},
"sender": {
"name": "John Wick",
"country": "BG",
"reference_number": "90078602",
"address": "Meow street 5",
"state": "CN",
"city": "Columbia"
}
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://staging.wpf.emerchantpay.net/wpf \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<wpf_payment>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<description>You are about to buy 3 shoes at www.shoes.com!</description>
<notification_url>https://www.example.com/notification</notification_url>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<return_cancel_url>http://www.example.com/cancel.html</return_cancel_url>
<return_pending_url>http://www.example.com/payment-pending.html</return_pending_url>
<amount>100</amount>
<currency>USD</currency>
<consumer_id>123456</consumer_id>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<remember_card>true</remember_card>
<lifetime>60</lifetime>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<risk_params>
<user_id>123456</user_id>
</risk_params>
<transaction_types>
<transaction_type moto="true" name="authorize" fx_rate_id="123" recurring_type="initial"/>
<transaction_type crypto="true" name="sale" fx_rate_id="123" recurring_type="initial"/>
</transaction_types>
<business_attributes>
<name_of_the_supplier>Best Furniture</name_of_the_supplier>
</business_attributes>
<pay_later>true</pay_later>
<reminder_language>en</reminder_language>
<reminders>
<reminder>
<channel>email</channel>
<after>40</after>
</reminder>
<reminder>
<channel>sms</channel>
<after>10</after>
</reminder>
</reminders>
<sca_params>
<exemption>low_value</exemption>
</sca_params>
<account_owner>
<first_name>Travis</first_name>
<middle_name>Joe</middle_name>
<last_name>Pastrana</last_name>
</account_owner>
<web_payment_form_id>1</web_payment_form_id>
<funding>
<identifier_type>business_disbursement</identifier_type>
<business_application_identifier>funds_disbursement</business_application_identifier>
<receiver>
<first_name>Hamza</first_name>
<last_name>Arshad</last_name>
<country>AF</country>
<account_number>090078601</account_number>
<account_number_type>iban</account_number_type>
<address>Gulberg 21 street</address>
<state>CN</state>
<city>Lahore</city>
</receiver>
<sender>
<name>John Wick</name>
<country>BG</country>
<reference_number>90078602</reference_number>
<address>Meow street 5</address>
<state>CN</state>
<city>Columbia</city>
</sender>
</funding>
</wpf_payment>'
Web Payment Form With 3 D Sv2 Authentication Protocol Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('WPF\Create');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setDescription('You are about to buy 3 shoes at www.shoes.com!')
->setNotificationUrl('https://www.example.com/notification')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setReturnCancelUrl('http://www.example.com/cancel.html')
->setReturnPendingUrl('http://www.example.com/payment-pending.html')
->setAmount('100')
->setCurrency('USD')
->setConsumerId('123456')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
->setRememberCard('true')
->setLifetime('60')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
// Risk Params
->setRiskUserId('123456')
// Transaction Types
->addTransactionType('authorize3d')
->addTransactionType('wechat')
->setPayLater('true')
// Reminders
->addReminder('email', '40')
->addReminder('sms', '10')
// Sca Params
->setScaExemption('low_value')
// Account Owner
->setAccountFirstName('Travis')
->setAccountMiddleName('Joe')
->setAccountLastName('Pastrana')
->setWebPaymentFormId('1');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.wpf.WPFCreateRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
WPFCreateRequest request = new WPFCreateRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setDescription("You are about to buy 3 shoes at www.shoes.com!");
request.setNotificationUrl(new URL("https://www.example.com/notification"));
request.setReturnSuccessUrl(new URL("http://www.example.com/success"));
request.setReturnFailureUrl(new URL("http://www.example.com/failure"));
request.setReturnCancelUrl(new URL("http://www.example.com/cancel.html"));
request.setReturnPendingUrl(new URL("http://www.example.com/payment-pending.html"));
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setConsumerId("123456");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
request.setRememberCard("true");
request.setLifetime(60);
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
// Risk Params
request.setRiskUserId("123456");
// Transaction Types
request.addTransactionType("authorize3d").done();
request.addTransactionType("wechat").done();
request.setPayLater("true");
// Sca Params
request.setScaExemption("low_value");
// Account Owner
request.setAccountFirstname("Travis");
request.setAccountMiddlename("Joe");
request.setAccountLastname("Pastrana");
request.setWebPaymentFormId("1");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.wpf_create(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"description": "You are about to buy 3 shoes at www.shoes.com!",
"notification_url": "https://www.example.com/notification",
"return_success_url": "http://www.example.com/success",
"return_failure_url": "http://www.example.com/failure",
"return_cancel_url": "http://www.example.com/cancel.html",
"return_pending_url": "http://www.example.com/payment-pending.html",
"amount": "100",
"currency": "USD",
"consumer_id": "123456",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"remember_card": "true",
"lifetime": 60,
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"risk_params": {
"user_id": "123456"
},
"transaction_types": [
"authorize3d",
"wechat"
],
"business_attributes": {
"name_of_the_supplier": "Best Furniture"
},
"pay_later": true,
"reminder_language": "en",
"reminders": [
{
"channel": "email",
"after": 40
},
{
"channel": "sms",
"after": 10
}
],
"sca_params": {
"exemption": "low_value"
},
"account_owner": {
"first_name": "Travis",
"middle_name": "Joe",
"last_name": "Pastrana"
},
"web_payment_form_id": "1"
}
).send()
.then(success)
.catch(failure);
Request
curl https://staging.wpf.emerchantpay.net/wpf \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<wpf_payment>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<description>You are about to buy 3 shoes at www.shoes.com!</description>
<notification_url>https://www.example.com/notification</notification_url>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<return_cancel_url>http://www.example.com/cancel.html</return_cancel_url>
<return_pending_url>http://www.example.com/payment-pending.html</return_pending_url>
<amount>100</amount>
<currency>USD</currency>
<consumer_id>123456</consumer_id>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<remember_card>true</remember_card>
<lifetime>60</lifetime>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<risk_params>
<user_id>123456</user_id>
</risk_params>
<transaction_types>
<transaction_type name="authorize3d"/>
<transaction_type name="wechat"/>
</transaction_types>
<business_attributes>
<name_of_the_supplier>Best Furniture</name_of_the_supplier>
</business_attributes>
<pay_later>true</pay_later>
<reminder_language>en</reminder_language>
<reminders>
<reminder>
<channel>email</channel>
<after>40</after>
</reminder>
<reminder>
<channel>sms</channel>
<after>10</after>
</reminder>
</reminders>
<sca_params>
<exemption>low_value</exemption>
</sca_params>
<account_owner>
<first_name>Travis</first_name>
<middle_name>Joe</middle_name>
<last_name>Pastrana</last_name>
</account_owner>
<web_payment_form_id>1</web_payment_form_id>
</wpf_payment>'
Web Payment Form With 3 D Sv2 Authentication Protocol Including Additional Optional 3 D Sv2 Attributes Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('WPF\Create');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setDescription('You are about to buy 3 shoes at www.shoes.com!')
->setNotificationUrl('https://www.example.com/notification')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setReturnCancelUrl('http://www.example.com/cancel.html')
->setReturnPendingUrl('http://www.example.com/payment-pending.html')
->setAmount('100')
->setCurrency('USD')
->setConsumerId('123456')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
->setRememberCard('true')
->setLifetime('60')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
// Risk Params
->setRiskUserId('123456')
// Transaction Types
->addTransactionType('init_recurring_sale3d')
->addTransactionType('sofort')
// Threeds V2 Params
->setThreedsControl('{"challenge_window_size"=>"full_screen", "challenge_indicator"=>"preference"}')
->setThreedsPurchase('{"category"=>"goods"}')
->setThreedsRecurring('{"expiration_date"=>"17-07-2025", "frequency"=>30}')
->setThreedsMerchantRisk('{"shipping_indicator"=>"verified_address", "delivery_timeframe"=>"electronic", "reorder_items_indicator"=>"reordered", "pre_order_purchase_indicator"=>"merchandise_available", "pre_order_date"=>"17-02-2025", "gift_card"=>"true", "gift_card_count"=>"2"}')
->setThreedsCardHolderAccount('{"creation_date"=>"17-01-2024", "update_indicator"=>"more_than_60days", "last_change_date"=>"17-10-2024", "password_change_indicator"=>"no_change", "password_change_date"=>"02-01-2025", "shipping_address_usage_indicator"=>"current_transaction", "shipping_address_date_first_used"=>"12-01-2025", "transactions_activity_last_24_hours"=>"2", "transactions_activity_previous_year"=>"10", "provision_attempts_last_24_hours"=>"1", "purchases_count_last_6_months"=>"5", "suspicious_activity_indicator"=>"no_suspicious_observed", "registration_indicator"=>"30_to_60_days", "registration_date"=>"17-01-2023"}')
->setPayLater('true')
// Reminders
->addReminder('email', '40')
->addReminder('sms', '10')
// Sca Params
->setScaExemption('low_value')
// Account Owner
->setAccountFirstName('Travis')
->setAccountMiddleName('Joe')
->setAccountLastName('Pastrana')
->setWebPaymentFormId('1');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.wpf.WPFCreateRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
WPFCreateRequest request = new WPFCreateRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setDescription("You are about to buy 3 shoes at www.shoes.com!");
request.setNotificationUrl(new URL("https://www.example.com/notification"));
request.setReturnSuccessUrl(new URL("http://www.example.com/success"));
request.setReturnFailureUrl(new URL("http://www.example.com/failure"));
request.setReturnCancelUrl(new URL("http://www.example.com/cancel.html"));
request.setReturnPendingUrl(new URL("http://www.example.com/payment-pending.html"));
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setConsumerId("123456");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
request.setRememberCard("true");
request.setLifetime(60);
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
// Risk Params
request.setRiskUserId("123456");
// Transaction Types
request.addTransactionType("init_recurring_sale3d").done();
request.addTransactionType("sofort").done();
// Threeds V2 Params
request.setThreedsControl("{"challenge_window_size"=>"full_screen", "challenge_indicator"=>"preference"}");
request.setThreedsPurchase("{"category"=>"goods"}");
request.setThreedsRecurring("{"expiration_date"=>"17-07-2025", "frequency"=>30}");
request.setThreedsMerchantRisk("{"shipping_indicator"=>"verified_address", "delivery_timeframe"=>"electronic", "reorder_items_indicator"=>"reordered", "pre_order_purchase_indicator"=>"merchandise_available", "pre_order_date"=>"17-02-2025", "gift_card"=>"true", "gift_card_count"=>"2"}");
request.setThreedsCardHolderAccount("{"creation_date"=>"17-01-2024", "update_indicator"=>"more_than_60days", "last_change_date"=>"17-10-2024", "password_change_indicator"=>"no_change", "password_change_date"=>"02-01-2025", "shipping_address_usage_indicator"=>"current_transaction", "shipping_address_date_first_used"=>"12-01-2025", "transactions_activity_last_24_hours"=>"2", "transactions_activity_previous_year"=>"10", "provision_attempts_last_24_hours"=>"1", "purchases_count_last_6_months"=>"5", "suspicious_activity_indicator"=>"no_suspicious_observed", "registration_indicator"=>"30_to_60_days", "registration_date"=>"17-01-2023"}");
request.setPayLater("true");
// Sca Params
request.setScaExemption("low_value");
// Account Owner
request.setAccountFirstname("Travis");
request.setAccountMiddlename("Joe");
request.setAccountLastname("Pastrana");
request.setWebPaymentFormId("1");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.wpf_create(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"description": "You are about to buy 3 shoes at www.shoes.com!",
"notification_url": "https://www.example.com/notification",
"return_success_url": "http://www.example.com/success",
"return_failure_url": "http://www.example.com/failure",
"return_cancel_url": "http://www.example.com/cancel.html",
"return_pending_url": "http://www.example.com/payment-pending.html",
"amount": "100",
"currency": "USD",
"consumer_id": "123456",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"remember_card": "true",
"lifetime": 60,
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"risk_params": {
"user_id": "123456"
},
"transaction_types": [
"init_recurring_sale3d",
"sofort"
],
"business_attributes": {
"name_of_the_supplier": "Best Furniture"
},
"threeds_v2_params": {
"control": {
"challenge_window_size": "full_screen",
"challenge_indicator": "preference"
},
"purchase": {
"category": "goods"
},
"recurring": {
"expiration_date": "17-07-2025",
"frequency": 30
},
"merchant_risk": {
"shipping_indicator": "verified_address",
"delivery_timeframe": "electronic",
"reorder_items_indicator": "reordered",
"pre_order_purchase_indicator": "merchandise_available",
"pre_order_date": "17-02-2025",
"gift_card": "true",
"gift_card_count": "2"
},
"card_holder_account": {
"creation_date": "17-01-2024",
"update_indicator": "more_than_60days",
"last_change_date": "17-10-2024",
"password_change_indicator": "no_change",
"password_change_date": "02-01-2025",
"shipping_address_usage_indicator": "current_transaction",
"shipping_address_date_first_used": "12-01-2025",
"transactions_activity_last_24_hours": "2",
"transactions_activity_previous_year": "10",
"provision_attempts_last_24_hours": "1",
"purchases_count_last_6_months": "5",
"suspicious_activity_indicator": "no_suspicious_observed",
"registration_indicator": "30_to_60_days",
"registration_date": "17-01-2023"
}
},
"pay_later": true,
"reminder_language": "en",
"reminders": [
{
"channel": "email",
"after": 40
},
{
"channel": "sms",
"after": 10
}
],
"sca_params": {
"exemption": "low_value"
},
"account_owner": {
"first_name": "Travis",
"middle_name": "Joe",
"last_name": "Pastrana"
},
"web_payment_form_id": "1"
}
).send()
.then(success)
.catch(failure);
Request
curl https://staging.wpf.emerchantpay.net/wpf \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<wpf_payment>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<description>You are about to buy 3 shoes at www.shoes.com!</description>
<notification_url>https://www.example.com/notification</notification_url>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<return_cancel_url>http://www.example.com/cancel.html</return_cancel_url>
<return_pending_url>http://www.example.com/payment-pending.html</return_pending_url>
<amount>100</amount>
<currency>USD</currency>
<consumer_id>123456</consumer_id>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<remember_card>true</remember_card>
<lifetime>60</lifetime>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<risk_params>
<user_id>123456</user_id>
</risk_params>
<transaction_types>
<transaction_type name="init_recurring_sale3d"/>
<transaction_type name="sofort"/>
</transaction_types>
<business_attributes>
<name_of_the_supplier>Best Furniture</name_of_the_supplier>
</business_attributes>
<threeds_v2_params>
<control>
<challenge_window_size>full_screen</challenge_window_size>
<challenge_indicator>preference</challenge_indicator>
</control>
<purchase>
<category>goods</category>
</purchase>
<recurring>
<expiration_date>17-07-2025</expiration_date>
<frequency>30</frequency>
</recurring>
<merchant_risk>
<shipping_indicator>verified_address</shipping_indicator>
<delivery_timeframe>electronic</delivery_timeframe>
<reorder_items_indicator>reordered</reorder_items_indicator>
<pre_order_purchase_indicator>merchandise_available</pre_order_purchase_indicator>
<pre_order_date>17-02-2025</pre_order_date>
<gift_card>true</gift_card>
<gift_card_count>2</gift_card_count>
</merchant_risk>
<card_holder_account>
<creation_date>17-01-2024</creation_date>
<update_indicator>more_than_60days</update_indicator>
<last_change_date>17-10-2024</last_change_date>
<password_change_indicator>no_change</password_change_indicator>
<password_change_date>02-01-2025</password_change_date>
<shipping_address_usage_indicator>current_transaction</shipping_address_usage_indicator>
<shipping_address_date_first_used>12-01-2025</shipping_address_date_first_used>
<transactions_activity_last_24_hours>2</transactions_activity_last_24_hours>
<transactions_activity_previous_year>10</transactions_activity_previous_year>
<provision_attempts_last_24_hours>1</provision_attempts_last_24_hours>
<purchases_count_last_6_months>5</purchases_count_last_6_months>
<suspicious_activity_indicator>no_suspicious_observed</suspicious_activity_indicator>
<registration_indicator>30_to_60_days</registration_indicator>
<registration_date>17-01-2023</registration_date>
</card_holder_account>
</threeds_v2_params>
<pay_later>true</pay_later>
<reminder_language>en</reminder_language>
<reminders>
<reminder>
<channel>email</channel>
<after>40</after>
</reminder>
<reminder>
<channel>sms</channel>
<after>10</after>
</reminder>
</reminders>
<sca_params>
<exemption>low_value</exemption>
</sca_params>
<account_owner>
<first_name>Travis</first_name>
<middle_name>Joe</middle_name>
<last_name>Pastrana</last_name>
</account_owner>
<web_payment_form_id>1</web_payment_form_id>
</wpf_payment>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_id | required | string(255) | Unique transaction id defined by merchant |
usage | optional | string(255) | Description of the transaction for later use. |
amount | required* | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required* | string(3) | Currency code in ISO 4217 |
description | optional | string | a text describing the reason of the payment (e.g. "you’re buying concert tickets") |
consumer_id | required* | string(10) | See Consumers and Tokenization. Saved cards will be listed for user to select |
customer_email | required* | e-mail address | Must contain valid e-mail of customer |
customer_phone | required* | string(32) | Must contain valid phone number of customer |
notification_url | required* | url | URL at merchant where gateway sends outcome of transaction. |
return_success_url | required* | url | URL where customer is sent to after successful payment |
return_failure_url | required* | url | URL where customer is sent to after unsuccessful payment |
return_cancel_url | required* | string | URL where customer is sent to when the customer cancels the payment process within the WPF |
return_pending_url | optional | string | URL where customer is sent to when asynchronous payment is pending confirmation |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required* | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
neighborhood | optional | string(255) | Neighborhood |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
transaction_types | required | The transaction types that the merchant is willing to accept payments for | |
transaction_type | required | string | One of the available WPF transaction types. Multiple transaction type elements supported. Attribute ’name’ contains the transaction type name in question |
business_attributes | required* | Check business attributes section. | |
event_start_date | required* | dd-mm-yyyy | The date when event starts in format dd-mm-yyyy |
event_end_date | required* | dd-mm-yyyy | The date when event ends in format dd-mm-yyyy |
event_organizer_id | required* | string | |
event_id | required* | string | |
date_of_order | required* | dd-mm-yyyy | The date when order was placed in format dd-mm-yyyy |
delivery_date | required* | dd-mm-yyyy | Date of the expected delivery in format dd-mm-yyyy |
name_of_the_supplier | required* | string | |
recurring_type | optional | string(255) | Specifies recurring type of the transaction, can be 'initial' or 'managed' when Sale or Sale3d or Authorize or Authorize3d is included in the transaction_types. Apple Pay and Google Pay transaction types supports 'initial' recurring type |
recurring_category | optional | Specifies whether the recurring transaction is a subscription(fixed amount, fixed intervals)or if it is a standing order(varying amount, fixed intervals). The allowed values aresubscription and standing_order . The default value is subscription |
|
threeds_v2_params | optional | 3DSv2 async parameters. They must be submitted in order to use the 3DSv2 authentication protocol in asynchronous workflow | |
control | optional | General params for preferences in authentication flow and providing device interface information. | |
challenge_window_size | optional | string | Identifies the size of the challenge window for the consumer. For more information, go to 3DSv2 control params |
challenge_indicator | optional | string | The value has weight and might impact the decision whether a challenge will be required for the transaction or not. If not provided, it will be interpreted as no_preference. For more information, go to 3DSv2 control params |
purchase | optional | Purchase related params providing with additional information regarding the order. | |
category | optional | string | Optional for transactions to be processed through the 3DSv2 authentication protocol. |
recurring | optional | Additional optional recurring attributes when InitRecurringSale3d is included in the transaction_types. | |
expiration_date | optional | dd-mm-yyyy | A future date indicating the end date for any further subsequent transactions. For more information, go to 3DSv2 recurring params |
frequency | optional | integer | Indicates the minimum number of days between subsequent transactions. An empty value indicates the payment frequency is not set.For more information, go to 3DSv2 recurring params |
merchant_risk | optional | Merchant risk assessment params. They are all optional, but recommended. | |
shipping_indicator | optional | string(16) | Indicator code that most accurately describes the shipping method for the cardholder specific transaction. If one or more items are included in the sale, use the Shipping Indicator code for the physical goods. If all digital goods, use the code that describes the most expensive item. Accepted values are: same_as_billing, stored_address, verified_address, pick_up, digital_goods, travel, event_tickets, other. |
delivery_timeframe | optional | string(11) | Indicates the merchandise delivery timeframe. Accepted values are: electronic, same_day, over_night, another_day. |
reorder_items_indicator | optional | string(10) | Indicates whether the cardholder is reordering previously purchased merchandise. Accepted values are: first_time, reordered. |
pre_order_purchase_indicator | optional | string(21) | Indicates whether cardholder is placing an order for merchandise with a future-availability or release date. Accepted values are: merchandise_available, future_availability. |
pre_order_date | optional | dd-mm-yyyy | For a pre-ordered purchase, the expected date that the merchandise will be available. |
gift_card | optional | 'true' | Prepaid or gift card purchase. |
gift_card_count | optional | integer | For prepaid or gift card purchase, total count of individual prepaid or gift cards/codes purchased. The value is limited to 99. |
card_holder_account | optional | Cardholder account additional information. They are all optional, but recommended, because they have a significant impact on approval rates | |
creation_date | optional | dd-mm-yyyy | Date that the cardholder opened the account with the 3DS Requester. |
update_indicator | optional | string(19) | Length of time since the cardholder’s account information with the 3DS Requestor was last changed. Includes Billing or Shipping address, new payment account, or new user(s) added. Accepted values are: current_transaction, less_than_30days, 30_to_60_days, more_than_60days. |
last_change_date | optional | dd-mm-yyyy | Date that the cardholder’s account with the 3DS Requestor was last changed. Including Billing or Shipping address, new payment accout, or new user(s) added. |
password_change_indicator | optional | string(18) | Length of time since the cardholder account with the 3DS Requestor had a password change or account reset. Accepted values are: no_change, during_transaction, less_than_30days, 30_to_60_days, more_than_60days. |
password_change_date | optional | dd-mm-yyyy | Date that cardholder’s account with the 3DS Requestor had a password change or account reset. |
shipping_address_usage_indicator | optional | string(19) | Indicates when the shipping address used for this transaction was first used with the 3DS Requestor. Accepted values are: current_transaction, less_than_30days, 30_to_60_days, more_than_60days. |
shipping_address_date_first_used | optional | dd-mm-yyyy | Date when the shipping address used for this transaction was first used with the 3DS Requestor. |
transactions_activity_last_24_hours | optional | integer | Number of transactions (successful and abandoned) for this cardholder account with the 3DS Requestor across all payment accounts in the previous 24 hours. |
transactions_activity_previous_year | optional | integer | Number of transactions (successful and abandoned) for this cardholder account with the 3DS Requestor across all payment accounts in the previous year. |
provision_attempts_last_24_hours | optional | integer | Number of Add Card attempts in the last 24 hours. |
purchases_count_last_6_months | optional | integer | Number of purchases with this cardholder account during the previous six months. |
suspicious_activity_indicator | optional | string(22) | Indicates whether the 3DS Requestor has experienced suspicious activity (including previous fraud) on the cardholder account. Accepted values are: no_suspicious_observed, suspicious_observed. |
registration_indicator | optional | string(19) | Indicates the length of time that the payment account was enrolled in the cardholder’s account with the 3DS Requester. Accepted values are: guest_checkout, current_transaction, less_than_30days, 30_to_60_days, more_than_60days. |
registration_date | optional | dd-mm-yyyy | Date that the payment account was enrolled in the cardholder’s account with the 3DS Requestor. |
remember_card | optional | "true" | See Tokenize. Offer the user the option to save cardholder details for future use (tokenize). |
lifetime | optional | integer | number of minutes determining how long the WPF will be valid. Will be set to 30 minutes by default. Valid value ranges between 1 minute and 3 months given in minutes (131487) |
risk_params | optional | list of risk params as described in the Advanced risk management with RiskParams section | |
user_id (example) | optional | string | the customer’s ID within the merchant’s system (example) |
session_id (example) | optional | string | the customer’s session ID within the mer- chant’s system (example) |
pay_later | optional | "true" | Signifies whether the ’Pay Later’ feature would be enabled on the WPF |
reminder_language | optional | string | It must be a valid language abbreviation from the available WPF languages |
reminders | optional | Settings for reminders sending when using the ’Pay Later’ feature. The number of the sent reminders would be exactly as sent or configured and delivery failures could be handled on demand. Also there will be no reminders sent if the WPF is already completed | |
reminder | optional | Settings for a single reminder. Upto three reminders are allowed | |
channel | optional | string | Channel for sending WPF reminder. Valid values are ’email’ and ’sms’ |
after | optional | integer | Number of minutes after WPF creation when the reminder should be sent. Valid value ranges between 1 minute and 31 days given in minutes |
crypto | optional | "true" | Signifies whether a purchase of crypto-currency transaction is performed. Must be populated when purchasing crypto-currency with a VISA card. Must be populated when purchasing crypto-currency with a MASTER or INTL MAESTRO card and MCC is one of 6051, 6211. Contact tech-support@emerchantpay.com for more details |
gaming | optional | "true" | Signifies whether a gaming transaction is performed. Gaming transactions usually use MCC 7995. Contact tech-support@emerchantpay.com for more details |
moto | optional | "true" | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech-support@emerchantpay.com for more details |
fx_rate_id | optional | integer | See Get rates for FX Service. Offers the option to use a specific FX rate to convert the transaction processing amount. Used FX rate should have the same source currency as the processing currency. Contact tech-support@emerchantpay.com for more details |
sca_preference | optional | "true" | Values 'true' or 'false'. Signifies whether to perform SCA on the transaction. At least one 3DS transaction type has to be submitted. Contact tech-support@emerchantpay.com for more details |
sca_params | optional | SCA params | |
exemption | optional | string | Exemption for the Strong Customer Authentication. The allowed options are low_value , low_risk |
account_owner | optional | Account owner parameters related to account owner inquiry requests | |
first_name | optional | string(35) | Account owner's first name |
middle_name | optional | string(35) | Account owner's middle name |
last_name | optional | string(35) | Account owner's last name |
web_payment_form_id | optional | The unique ID of the the web payment form configuration to be displayed for the current payment. | |
funding | optional | Funding Transaction Params | |
identifier_type | required* | string | This is only required in case of Mastercard. Type of Funding Transaction. Please check Identifier Types |
business_application_identifier | required* | string | This is only required in case of VISA. Type of VISA Funding Transaction. Please check BAI |
receiver | optional | Funding Transaction Receiver details | |
first_name | required* | string | First name of the receiver |
last_name | required* | string | Last name of the receiver |
country | required* | string(2) | Country code in ISO 3166 |
account_number | required* | string | Receiver account number. Mandatory for Mastercard. If Sender Reference Number is provided then it becomes optional for VISA |
account_number_type | required* | string | This is only required in case of Mastercard. Receiver account number type. Please check Receiver Account Types |
address | required* | string | Receiver address. Only required in case of VISA and Canadian cards |
state | required* | string | Receiver state. Only required in case of VISA and Canadian cards |
city | required* | string | Receiver city. Only required in case of VISA and Canadian cards |
sender | optional | Funding Transaction Sender details | |
name | required* | string | Sender name. Only required in case of VISA |
reference_number | required* | string | Sender Reference Number. Only required in case of VISA. This is option if Receiver Account Number is provided |
country | required* | string | Sender country. Only required in case of VISA. If not provided billing address is used |
address | required* | string | Sender address. Only required in case of VISA. If not provided billing address is used |
state | required* | string | Sender state. Only required in case of VISA and Canadian card. If not provided billing address is used |
city | required* | string | Sender city. Only required in case of VISA. If not provided billing address is used |
dynamic_descriptor_params | optional | ||
merchant_name | optional | string(25) | Allows to dynamically override the charge descriptor |
merchant_city | optional | string(13) | Allows to dynamically override the merchant phone number |
sub_merchant_id | optional | string(15) | Allows to dynamically override the sub-merchant ID. |
merchant_country | optional | string(3) | Allows to dynamically override the merchant country. |
merchant_state | optional | string(3) | Allows to dynamically override the merchant subdivision code. |
merchant_zip_code | optional | string(10) | Allows to dynamically override the merchant zip/postal code. Required for VISA OCT transactions with Australian and Canadian card bins. |
merchant_address | optional | string(48) | Allows to dynamically override the merchant address. |
merchant_url | optional | string(60) | Allows to dynamically override the merchant URL |
merchant_phone | optional | string(16) | Allows to dynamically override the merchant phone number. |
merchant_service_city | optional | string(13) | Allows to dynamically override the merchant service city. |
merchant_service_country | optional | string(3) | Allows to dynamically override the merchant service country. |
merchant_service_state | optional | string(3) | Allows to dynamically override the merchant service subdivision code. |
merchant_service_zip_code | optional | string(10) | Allows to dynamically override the merchant service zip/postal code. |
merchant_service_phone | optional | string(16) | Allows to dynamically override the merchant service phone number. |
merchant_geo_coordinates | optional | string(20) | Allows to dynamically override the merchant geographic coordinates. |
merchant_service_geo_coordinates | optional | string(20) | Allows to dynamically override the merchant service geographic coordinates. |
required* = conditionally required
Successful Response
stdClass Object
(
[transaction_type] => wpf_create
[status] => new
[mode] => live
[transaction_id] => 119643250547501c79d8295
[consumer_id] => 123456
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[technical_message] => Transaction successful!
[message] => Transaction successful!
[redirect_url] => https://staging.wpf.emerchantpay.net/en/payment/c7e32c1e9d1
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:24:03.000000
[timezone_type] => 2
[timezone] => Z
)
[amount] => 100
[currency] => USD
)
<payment_response content=[
<transaction_type content=[wpf_create]>
<status content=[new]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<consumer_id content=[123456]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<technical_message content=[Transaction successful!]>
<message content=[Transaction successful!]>
<redirect_url content=[https://staging.wpf.emerchantpay.net/en/payment/c7e32c1e9d1]>
<timestamp content=[2025-01-16T10:24:03Z]>
<amount content=[100]>
<currency content=[USD]>
]>
{
transaction_type: "wpf_create",
status: "new",
mode: "live",
transaction_id: "119643250547501c79d8295",
consumer_id: "123456",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
technical_message: "Transaction successful!",
message: "Transaction successful!",
redirect_url: "https://staging.wpf.emerchantpay.net/en/payment/c7e32c1e9d1",
timestamp: "2025-01-16T10:24:03Z",
amount: "100",
currency: "USD",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<wpf_payment>
<transaction_type>wpf_create</transaction_type>
<status>new</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<consumer_id>123456</consumer_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<technical_message>Transaction successful!</technical_message>
<message>Transaction successful!</message>
<redirect_url>https://staging.wpf.emerchantpay.net/en/payment/c7e32c1e9d1</redirect_url>
<timestamp>2025-01-16T10:24:03Z</timestamp>
<amount>100</amount>
<currency>USD</currency>
</wpf_payment>
Successful With Optional Invalid Transactions For Amount Response
stdClass Object
(
[consumer_id] => 123456
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:24:03.000000
[timezone_type] => 2
[timezone] => Z
)
[amount] => 100
[currency] => USD
[redirect_url] => https://staging.wpf.emerchantpay.net/en/payment/c7e32c1e9d1
[invalid_transactions_for_amount] => alipay
)
<payment_response content=[
<consumer_id content=[123456]>
<timestamp content=[2025-01-16T10:24:03Z]>
<amount content=[100]>
<currency content=[USD]>
<redirect_url content=[https://staging.wpf.emerchantpay.net/en/payment/c7e32c1e9d1]>
<invalid_transactions_for_amount content=[alipay]>
]>
{
consumer_id: "123456",
timestamp: "2025-01-16T10:24:03Z",
amount: "100",
currency: "USD",
redirect_url: "https://staging.wpf.emerchantpay.net/en/payment/c7e32c1e9d1",
invalid_transactions_for_amount: "alipay",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<wpf_payment>
<consumer_id>123456</consumer_id>
<timestamp>2025-01-16T10:24:03Z</timestamp>
<amount>100</amount>
<currency>USD</currency>
<redirect_url>https://staging.wpf.emerchantpay.net/en/payment/c7e32c1e9d1</redirect_url>
<invalid_transactions_for_amount>alipay</invalid_transactions_for_amount>
</wpf_payment>
Successful With Funds Status Response
stdClass Object
(
[consumer_id] => 123456
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:24:03.000000
[timezone_type] => 2
[timezone] => Z
)
[amount] => 100
[currency] => USD
[redirect_url] => https://staging.wpf.emerchantpay.net/en/payment/c7e32c1e9d1
[funds_status] => WAITING
)
<payment_response content=[
<consumer_id content=[123456]>
<timestamp content=[2025-01-16T10:24:03Z]>
<amount content=[100]>
<currency content=[USD]>
<redirect_url content=[https://staging.wpf.emerchantpay.net/en/payment/c7e32c1e9d1]>
<funds_status content=[WAITING]>
]>
{
consumer_id: "123456",
timestamp: "2025-01-16T10:24:03Z",
amount: "100",
currency: "USD",
redirect_url: "https://staging.wpf.emerchantpay.net/en/payment/c7e32c1e9d1",
funds_status: "WAITING",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<wpf_payment>
<consumer_id>123456</consumer_id>
<timestamp>2025-01-16T10:24:03Z</timestamp>
<amount>100</amount>
<currency>USD</currency>
<redirect_url>https://staging.wpf.emerchantpay.net/en/payment/c7e32c1e9d1</redirect_url>
<funds_status>WAITING</funds_status>
</wpf_payment>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the WPF transaction, see states |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
transaction_id | string(255) | Unique transaction id defined by merchant |
consumer_id | string(10) | Consumer unique reference. See Consumers |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
redirect_url | url | URL where user has to be redirected to complete payment process. Contains the locale in which the web payment form will be rendered by default. See WPF Internationalization (i18n) |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
invalid_transactions_for_amount | string* | list of comma separated transactions for which amount is not within the allowed limit *present only when at least for one transaction type an amount is invalid, check Currency and Amount Handling for details |
funds_status | string* | funds status of transaction *present only when the transaction has funds status |
Error Response
stdClass Object
(
[transaction_type] => wpf_create
[status] => error
[mode] => live
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[code] => 330
[technical_message] => Unknown system error. Please contact support.
[message] => Transaction failed, please contact support!
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:24:03.000000
[timezone_type] => 2
[timezone] => Z
)
[amount] => 100
[currency] => USD
)
<payment_response content=[
<transaction_type content=[wpf_create]>
<status content=[error]>
<mode content=[live]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<code content=[330]>
<technical_message content=[Unknown system error. Please contact support.]>
<message content=[Transaction failed, please contact support!]>
<timestamp content=[2025-01-16T10:24:03Z]>
<amount content=[100]>
<currency content=[USD]>
]>
{
transaction_type: "wpf_create",
status: "error",
mode: "live",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
code: "330",
technical_message: "Unknown system error. Please contact support.",
message: "Transaction failed, please contact support!",
timestamp: "2025-01-16T10:24:03Z",
amount: "100",
currency: "USD",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<wpf_payment>
<transaction_type>wpf_create</transaction_type>
<status>error</status>
<mode>live</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<code>330</code>
<technical_message>Unknown system error. Please contact support.</technical_message>
<message>Transaction failed, please contact support!</message>
<timestamp>2025-01-16T10:24:03Z</timestamp>
<amount>100</amount>
<currency>USD</currency>
</wpf_payment>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the WPF transaction, see states |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
Notification
WPF Notifications are sent once the WPF payment has reached a final state and are transmitted via HTTP POST (application/x-www-form-urlencoded) with the following parameters:
Example Notification for Successful Frictionless 3dsv2
signature=c5219b3d385e74496b2b48a5497b347e102849f10eacd25b062f823b
&payment_transaction_transaction_type=sale3d
&payment_transaction_terminal_token=e9fd7a957845450fb7ab9dccb498b6e1f6e1e3aa
&payment_transaction_unique_id=bad08183a9ec545daf0f24c48361aa10
&payment_transaction_amount=500
&wpf_transaction_id=mtid201104081447161135536962
&wpf_status=approved
&wpf_unique_id=26aa150ee68b1b2d6758a0e6c44fce4c
&consumer_id=123456
&payment_transaction_token=ee946db8-d7db-4bb7-b608-b65b153e127d
¬ification_type=wpf
&eci=05
&payment_transaction_avs_response_code=5I
&payment_transaction_avs_response_text=Response+provided+by+issuer+processor%3B+Address+information+not+verified
&payment_transaction_cvv_result_code=M
&authorization_code=005645
&retrieval_reference_number=016813015184
&payment_account_reference=50019P9LBXOLHN9G7QMU5VN520YSY
&scheme_response_code=00
&scheme_transaction_identifier=MCS267BG0
&scheme_transaction_link_id=TLINKIDENTIFIER4521412
&scheme_pan_indicator=V
&scheme_pan_tail=0013
&scheme_settlement_date=1103
&scheme_max_settlement_date=2024-07-31
&scheme_authentication_data_quality=true
&reason_for_not_honoring_exemption=8A01
&sca_exemption_result=13
&threeds_authentication_flow=frictionless
&threeds_target_protocol_version=2
&threeds_concrete_protocol_version=2
&threeds_protocol_sub_version=2
Example Notification for Successful Frictionless 3dsv2 With 3ds Method
signature=c5219b3d385e74496b2b48a5497b347e102849f10eacd25b062f823b
&payment_transaction_transaction_type=sale3d
&payment_transaction_terminal_token=e9fd7a957845450fb7ab9dccb498b6e1f6e1e3aa
&payment_transaction_unique_id=bad08183a9ec545daf0f24c48361aa10
&payment_transaction_amount=500
&wpf_transaction_id=mtid201104081447161135536962
&wpf_status=approved
&wpf_unique_id=26aa150ee68b1b2d6758a0e6c44fce4c
&consumer_id=123456
&payment_transaction_token=ee946db8-d7db-4bb7-b608-b65b153e127d
¬ification_type=wpf
&eci=05
&payment_transaction_avs_response_code=5I
&payment_transaction_avs_response_text=Response+provided+by+issuer+processor%3B+Address+information+not+verified
&payment_transaction_cvv_result_code=M
&authorization_code=005645
&retrieval_reference_number=016813015184
&payment_account_reference=50019P9LBXOLHN9G7QMU5VN520YSY
&scheme_response_code=00
&scheme_transaction_identifier=MCS267BG0
&scheme_transaction_link_id=TLINKIDENTIFIER4521412
&scheme_pan_indicator=V
&scheme_pan_tail=0013
&scheme_settlement_date=1103
&scheme_max_settlement_date=2024-07-31
&scheme_authentication_data_quality=true
&reason_for_not_honoring_exemption=8A01
&sca_exemption_result=13
&threeds_authentication_flow=frictionless
&threeds_method_status=completed
&threeds_target_protocol_version=2
&threeds_concrete_protocol_version=2
&threeds_protocol_sub_version=2
Example Notification for Successful Challenge 3dsv2
signature=c5219b3d385e74496b2b48a5497b347e102849f10eacd25b062f823b
&payment_transaction_transaction_type=sale3d
&payment_transaction_terminal_token=e9fd7a957845450fb7ab9dccb498b6e1f6e1e3aa
&payment_transaction_unique_id=bad08183a9ec545daf0f24c48361aa10
&payment_transaction_amount=500
&wpf_transaction_id=mtid201104081447161135536962
&wpf_status=approved
&wpf_unique_id=26aa150ee68b1b2d6758a0e6c44fce4c
&consumer_id=123456
&payment_transaction_token=ee946db8-d7db-4bb7-b608-b65b153e127d
¬ification_type=wpf
&eci=05
&payment_transaction_avs_response_code=5I
&payment_transaction_avs_response_text=Response+provided+by+issuer+processor%3B+Address+information+not+verified
&payment_transaction_cvv_result_code=M
&authorization_code=005645
&retrieval_reference_number=016813015184
&payment_account_reference=50019P9LBXOLHN9G7QMU5VN520YSY
&scheme_response_code=00
&scheme_transaction_identifier=MCS267BG0
&scheme_transaction_link_id=TLINKIDENTIFIER4521412
&scheme_pan_indicator=V
&scheme_pan_tail=0013
&scheme_settlement_date=1103
&scheme_max_settlement_date=2024-07-31
&scheme_authentication_data_quality=true
&reason_for_not_honoring_exemption=8A01
&sca_exemption_result=13
&threeds_authentication_flow=challenge
&threeds_target_protocol_version=2
&threeds_concrete_protocol_version=2
&threeds_protocol_sub_version=2
Example Notification for Successful Challenge 3dsv2 With 3ds Method
signature=c5219b3d385e74496b2b48a5497b347e102849f10eacd25b062f823b
&payment_transaction_transaction_type=sale3d
&payment_transaction_terminal_token=e9fd7a957845450fb7ab9dccb498b6e1f6e1e3aa
&payment_transaction_unique_id=bad08183a9ec545daf0f24c48361aa10
&payment_transaction_amount=500
&wpf_transaction_id=mtid201104081447161135536962
&wpf_status=approved
&wpf_unique_id=26aa150ee68b1b2d6758a0e6c44fce4c
&consumer_id=123456
&payment_transaction_token=ee946db8-d7db-4bb7-b608-b65b153e127d
¬ification_type=wpf
&eci=05
&payment_transaction_avs_response_code=5I
&payment_transaction_avs_response_text=Response+provided+by+issuer+processor%3B+Address+information+not+verified
&payment_transaction_cvv_result_code=M
&authorization_code=005645
&retrieval_reference_number=016813015184
&payment_account_reference=50019P9LBXOLHN9G7QMU5VN520YSY
&scheme_response_code=00
&scheme_transaction_identifier=MCS267BG0
&scheme_transaction_link_id=TLINKIDENTIFIER4521412
&scheme_pan_indicator=V
&scheme_pan_tail=0013
&scheme_settlement_date=1103
&scheme_max_settlement_date=2024-07-31
&scheme_authentication_data_quality=true
&reason_for_not_honoring_exemption=8A01
&sca_exemption_result=13
&threeds_authentication_flow=challenge
&threeds_method_status=completed
&threeds_target_protocol_version=2
&threeds_concrete_protocol_version=2
&threeds_protocol_sub_version=2
Example Notification for Sofort
?transaction_id=82803B4C-70CC-43BD-8B21-FD0395285B40
&unique_id=44177a21403427eb96664a6d7e5d5d48
&transaction_type=sofort
&terminal_token=394f2ebc3646d3c017fa1e1cbc4a1e20
&status=approved
&amount=500
&signature=088e16a1019277b15d58faf0541e11910eb756f6
&funds_status=sent
&account_holder=name+surname
&bank_account_number=DE89370400440532013000
&bank_identifier_code=GENODETT488
Name | Type | Description |
---|---|---|
signature | string | the signature of the notification, should be used to verify the the notification was sent by Genesis |
payment_transaction_transaction_type | string | transaction type for the transaction eg: sale3d |
payment_transaction_terminal_token | string | the terminal token as used in the processing url |
payment_transaction_unique_id | string | unique id generated by Genesis |
payment_transaction_amount | string | Amount of the payment transaction. If the transaction is partially approved, this is the partially approved amount. Check Partial Approvals for details |
payment_transaction_partial_approval | string | If the transaction is partially approved, this is set to ’true’. Check Partial Approvals for details |
wpf_transaction_id | string | merchant generated tranaction id |
wpf_status | string | status of the payment transaction |
wpf_unique_id | string | unique id generated by Genesis, required for WPF payment reconciliation |
consumer_id | string(10) | Consumer unique reference. See Consumers |
payment_transaction_token | string(36) | Plain-text token value. See Tokenize |
notification_type | string | constant value "wpf" |
eci | string | See Electronic Commerce Indicator as returned from the MPI for details |
payment_transaction_avs_response_code | string | Generated by the card network on trying to match the billing address when performing the address verification. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
payment_transaction_avs_response_text | string | Gives the human response text for the AVS response code above. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
payment_transaction_cvv_result_code | string | Card Verification Value response code. Optional, returned only if acquirer supports it. |
authorization code | string | A code returned by some acquirers to indicate that a card payment has been authorized. |
retrieval_reference_number | string | A reference number used for tracking all messages related to a given cardholder transaction returned by some acquirers. |
funds_status | string | Funds status of transaction *present only when the transaction has funds status |
account_holder | string | Account Holder of transaction's bank account. *present only when the transaction has account holder |
scheme_response_code | string | The response code returned from the schemes. |
recurring_advice_code | string | An additional response code returned from the schemes. Specifies if the transaction can be retried in case of failure. |
recurring_advice_text | string | The text representation of the recurring advice code. |
scheme_transaction_identifier | string | The text representation of the scheme transaction identifier. |
scheme_settlement_date | string | The text representation of the scheme settlement date. |
card_brand | string* | The brand of the card used for the transaction. |
card_number | string* | The card number of the card used for the transaction. |
card_type | string* | The type of the card used for the transaction. |
card_subtype | string* | The subtype of the card used for the transaction. |
card_issuing_bank | string* | The card issuer. |
card_holder | string* | The card holder. |
expiration_year | string* | The expiration year of the card. |
expiration_month | string* | The expiration month of the card. |
status | string* | The transaction status. |
customer_email | string* | The email of the customer. |
customer_phone | string* | The phone of the customer. |
first_name | string* | The first name of the customer. |
last_name | string* | The last name of the customer. |
address1 | string* | The address of the customer. |
address2 | string* | The second line of address of the customer. |
zip_code | string* | The zip code of the customer. |
city | string* | The city of the customer. |
reason_for_not_honoring_exemption | string | Reason for not honoring exemption. Check SCA Reason For Not Honoring Exemption Values. |
sca_exemption_result | string | SCA exemption result. Check SCA Exemption Result Values. |
state | string* | The state of the customer. |
country | string* | The country of the customer. |
arn acquirer_reference_number | string* | The unique number assigned to the card transaction as it moves through the payment flow. |
bank_account_number | string* | The IBAN number of the customer. |
currency | string* | The currency of the transaction. |
bank_identifier_code | string* | The BIC of the customer bank. |
scheme_transaction_link_id | string | The transaction unique identifier returned from the schemes. |
scheme_pan_indicator | string | The account number indicator in scheme-tokenized transactions. See Account number indicator codes for details. |
scheme_pan_tail | string | The tail of the PAN number associated with the token in scheme-tokenized transactions. Returned in conjunction with scheme_pan_indicator . |
scheme_max_settlement_date | string | The final date an authorization could be captured which is returned from the card scheme. See Scheme Maximum Settlement Date for more details. |
scheme_authentication_data_quality | boolean | The Authentication Data Quality Indicator returned by the card scheme is used to indicate whether a transaction meets the authentication data quality requirements. The value can be either true or false . |
payment_account_reference | string | The Payment Account Reference value returned from the schemes. |
string* = This is an optional parameter.
Contact tech-support@emerchantpay.com for more details
3DS Attributes
Name | Type | Description |
---|---|---|
threeds_authentication_flow | string | Identifies the concrete 3DS authentication flow that the transaction has gone through. It will be available in the notification only if the consumer has finished the 3DS authentication with the issuer. The available values for 3DSv2 are frictionless and challenge. |
threeds_method_status | string | Identifies the status of the 3DS-Method in the scope of 3DSv2 authentication protocol. The possible values are required, in_progress and completed. |
threeds_target_protocol_version | string(1) | Identifies the 3DS protocol that has been enforced. The possible values are 2. |
threeds_concrete_protocol_version | string(1) | Identifies the concrete 3DS protocol version that the transaction has gone through. The possible values are 2. |
threeds_protocol_sub_version | string(1) | Identifies the 3DS protocol sub-version that the transaction has gone through. The possible values are 1, 2, 3, 4, 5, 6, 7, 8, 9. |
threeds_authentication_status_reason_code | string(2) | See Status Reason Code for details. |
Status will be one of the following: approved, declined, error, timeout, pending, refunded, voided, chargebacked, chargeback reversed, represented, representment reversed and second chargebacked.
The signature is a mean of security to ensure that the gate is really the sender of the notification. It is generated by concatenating the unique id of the payment with your API password and generating a SHA-512 Hash (Hex) of the string:
SHA-512 Hash Hex of <wpf_unique_id><Your Merchant API password>
Notification signature examples
unique id | API password | signature |
---|---|---|
26aa150ee68b1b2d6758a0e6c44fce4c | 50fd87e65eb415f42fb5af4c9cf497662e00b785 | c5219b3d385e74496b2b48a549 |
3f760162ef57a829011e5e2379b3fa17 | 50fd87e65eb415f42fb5af4c9cf497662e00b785 | 14519d0db2f7f8f407efccc9b099 |
<?xml version="1.0" encoding="UTF-8"?>
<notification_echo>
<wpf_unique_id>3f760162ef57a829011e5e2379b3fa17</wpf_unique_id>
</notification_echo>
When receiving the notification, you are required to render an xml page containing the transaction’s unique id so that the gateway knows that you have accepted the notification. If the XML is not delivered, the notification is sent periodically until the XML is received.
Reconcile
Reconcile can be used to retrieve data about a payment. This can be useful if you want to retrieve information about a payment whose status is timeout, which returned an error or has changed eg. has beed chargebacked.
Reconcile requests are handled exactly like transaction requests via XML. To a large degree, the WPF Reconcile follows the notions of the standard processing Reconcile API.
<?xml version="1.0" encoding="UTF-8"?>
<wpf_reconcile>
<unique_id>26aa150ee68b1b2d6758a0e6c44fce4c</unique_id>
</wpf_reconcile>
Parameter | Required | Format | Description |
---|---|---|---|
unique_id | required | string(32) | unique id as returned by the create request |
Example Reconcile Response XML for Successful Frictionless 3dsv2:
<?xml version="1.0" encoding="UTF-8"?>
<wpf_payment>
<status>approved</status>
<unique_id>26aa150ee68b1b2d6758a0e6c44fce4c</unique_id>
<transaction_id>mtid201104081447161135536962</transaction_id>
<consumer_id>123456</consumer_id>
<timestamp>2011-04-08T14:46:27Z</timestamp>
<amount>5000</amount>
<currency>USD</currency>
<usage>Shopify Electronic Transaction</usage>
<description>You are about to buy shoes from Shopify</description>
<card_brand>visa</card_brand>
<card_number>401200...0085</card_number>
<card_type>CREDIT</card_type>
<card_subtype>CARD SUBTYPE</card_subtype>
<card_issuing_bank>Issuing Bank</card_issuing_bank>
<card_issuing_country>Exact Issuing country</card_issuing_country>
<card_holder>John Doe</card_holder>
<expiration_year>2020</expiration_year>
<expiration_month>2</expiration_month>
<payment_transaction>
<status>approved</status>
<authorization_code>345678</authorization_code>
<scheme_response_code>00</scheme_response_code>
<avs_response_code>5I</avs_response_code>
<avs_response_text>Response+provided+by+issuer+processor%3B+Address+information+not+verified</avs_response_text>
<cvv_result_code>S</cvv_result_code>
<response_code>00</response_code>
<transaction_type>sale3d</transaction_type>
<unique_id>bad08183a9ec545daf0f24c48361aa10</unique_id>
<transaction_id>mtid201104081447161135536962</transaction_id>
<arn>74537605259536043849425</arn>
<terminal_token>e9fd7a957845450fb7ab9dccb498b6e1f6e1e3aa</terminal_token>
<mode>test</mode>
<timestamp>2011-04-08T14:46:40Z</timestamp>
<descriptor>emerchantpay.net/bogus +49123456789</descriptor>
<bank_account_number>Bank Account Number</bank_account_number>
<bank_identifier_code>Bank Identifier Code</bank_identifier_code>
<amount>4900</amount>
<partial_approval>true</partial_approval>
<currency>USD</currency>
<customer_email>john.doe@example.com</customer_email>
<customer_phone>+11234567890</customer_phone>
<payment_account_reference>50019P9LBXOLHN9G7QMU5VN520YSY</payment_account_reference>
<scheme_transaction_identifier>019091214161031</scheme_transaction_identifier>
<scheme_transaction_link_id>TLINKIDENTIFIER4521412</scheme_transaction_link_id>
<scheme_pan_indicator>V</scheme_pan_indicator>
<scheme_pan_tail>0013</scheme_pan_tail>
<scheme_settlement_date>0117</scheme_settlement_date>
<scheme_max_settlement_date>2024-07-31</scheme_max_settlement_date>
<scheme_authentication_data_quality>false</scheme_authentication_data_quality>
<reason_for_not_honoring_exemption>8A01</reason_for_not_honoring_exemption>
<sca_exemption_result>13</sca_exemption_result>
<technical_message>TESTMODE: No real money will be transferred!</technical_message>
<message>TESTMODE: No real money will be transferred!</message>
<billing_address>
<first_name>John</first_name>
<last_name>Doe</last_name>
<address1>32, Doestreet</address1>
<address2></address2>
<zip_code>12345</zip_code>
<city>New York</city>
<state>NY</state>
<country>US</country>
</billing_address>
<threeds>
<authentication_flow>frictionless</authentication_flow>
<protocol>
<target_version>2</target_version>
<concrete_version>2</concrete_version>
</protocol>
<eci>05</eci>
</threeds>
</payment_transaction>
</wpf_payment>
Example Reconcile Response XML for Successful Challenge 3dsv2 With 3ds Method:
<?xml version="1.0" encoding="UTF-8"?>
<wpf_payment>
<status>approved</status>
<unique_id>26aa150ee68b1b2d6758a0e6c44fce4c</unique_id>
<transaction_id>mtid201104081447161135536962</transaction_id>
<consumer_id>123456</consumer_id>
<timestamp>2011-04-08T14:46:27Z</timestamp>
<amount>5000</amount>
<currency>USD</currency>
<usage>Shopify Electronic Transaction</usage>
<description>You are about to buy shoes from Shopify</description>
<card_brand>visa</card_brand>
<card_number>493873...0001</card_number>
<card_type>CREDIT</card_type>
<card_subtype>CARD SUBTYPE</card_subtype>
<card_issuing_bank>Issuing Bank</card_issuing_bank>
<card_issuing_country>Exact Issuing country</card_issuing_country>
<card_holder>John Doe</card_holder>
<expiration_year>2020</expiration_year>
<expiration_month>2</expiration_month>
<payment_transaction>
<status>approved</status>
<authorization_code>345678</authorization_code>
<scheme_response_code>00</scheme_response_code>
<avs_response_code>5I</avs_response_code>
<avs_response_text>Response+provided+by+issuer+processor%3B+Address+information+not+verified</avs_response_text>
<cvv_result_code>S</cvv_result_code>
<response_code>00</response_code>
<transaction_type>sale3d</transaction_type>
<unique_id>bad08183a9ec545daf0f24c48361aa10</unique_id>
<transaction_id>mtid201104081447161135536962</transaction_id>
<arn>74537605259536043849425</arn>
<terminal_token>e9fd7a957845450fb7ab9dccb498b6e1f6e1e3aa</terminal_token>
<mode>test</mode>
<timestamp>2011-04-08T14:46:40Z</timestamp>
<descriptor>emerchantpay.net/bogus +49123456789</descriptor>
<bank_account_number>Bank Account Number</bank_account_number>
<bank_identifier_code>Bank Identifier Code</bank_identifier_code>
<amount>4900</amount>
<partial_approval>true</partial_approval>
<currency>USD</currency>
<customer_email>john.doe@example.com</customer_email>
<customer_phone>+11234567890</customer_phone>
<payment_account_reference>50019P9LBXOLHN9G7QMU5VN520YSY</payment_account_reference>
<scheme_transaction_identifier>019091214161031</scheme_transaction_identifier>
<scheme_transaction_link_id>TLINKIDENTIFIER4521412</scheme_transaction_link_id>
<scheme_pan_indicator>V</scheme_pan_indicator>
<scheme_pan_tail>0013</scheme_pan_tail>
<scheme_settlement_date>0117</scheme_settlement_date>
<scheme_max_settlement_date>2024-07-31</scheme_max_settlement_date>
<scheme_authentication_data_quality>false</scheme_authentication_data_quality>
<reason_for_not_honoring_exemption>8A01</reason_for_not_honoring_exemption>
<sca_exemption_result>13</sca_exemption_result>
<technical_message>TESTMODE: No real money will be transferred!</technical_message>
<message>TESTMODE: No real money will be transferred!</message>
<billing_address>
<first_name>John</first_name>
<last_name>Doe</last_name>
<address1>32, Doestreet</address1>
<address2></address2>
<zip_code>12345</zip_code>
<city>New York</city>
<state>NY</state>
<country>US</country>
</billing_address>
<threeds>
<authentication_flow>challenge</authentication_flow>
<threeds_method>
<status>completed</status>
</threeds_method>
<protocol>
<target_version>2</target_version>
<concrete_version>2</concrete_version>
</protocol>
<eci>05</eci>
</threeds>
</payment_transaction>
</wpf_payment>
Example Reconcile Response XML for successful payment with funds status:
<?xml version="1.0" encoding="UTF-8"?>
<wpf_payment>
<status>approved</status>
<unique_id>26aa150ee68b1b2d6758a0e6c44fce4c</unique_id>
<transaction_id>mtid201104081447161135536962</transaction_id>
<consumer_id>123456</consumer_id>
<timestamp>2011-04-08T14:46:27Z</timestamp>
<amount>5000</amount>
<currency>USD</currency>
<payment_transaction>
<status>approved</status>
<transaction_type>ideal</transaction_type>
<unique_id>bad08183a9ec545daf0f24c48361aa10</unique_id>
<transaction_id>mtid201104081447161135536962</transaction_id>
<terminal_token>e9fd7a957845450fb7ab9dccb498b6e1f6e1e3aa</terminal_token>
<mode>test</mode>
<timestamp>2011-04-08T14:46:40Z</timestamp>
<descriptor>emerchantpay.net/bogus +49123456789</descriptor>
<funds_status>WAITING</funds_status>
<account_holder>Name Surname</account_holder>
<amount>4900</amount>
<currency>GBP</currency>
<customer_email>john.doe@example.com</customer_email>
<customer_phone>+11234567890</customer_phone>
<reason_for_not_honoring_exemption>8A01</reason_for_not_honoring_exemption>
<sca_exemption_result>13</sca_exemption_result>
<technical_message>TESTMODE: No real money will be transferred!</technical_message>
<message>TESTMODE: No real money will be transferred!</message>
</payment_transaction>
</wpf_payment>
Example Response XML for voided payment:
<?xml version="1.0" encoding="UTF-8"?>
<wpf_payment>
<status>voided</status>
<unique_id>26aa150ee68b1b2d6758a0e6c44fce4c</unique_id>
<transaction_id>mtid201104081447161135536962</transaction_id>
<consumer_id>123456</consumer_id>
<timestamp>2011-04-08T14:46:27Z</timestamp>
<amount>5000</amount>
<currency>USD</currency>
<usage>Shopify Electronic Transaction</usage>
<description>You are about to buy shoes from Shopify</description>
<card_brand>visa</card_brand>
<card_number>420000...0000</card_number>
<card_type>CREDIT</card_type>
<card_subtype>CARD SUBTYPE</card_subtype>
<card_issuing_bank>Issuing Bank</card_issuing_bank>
<card_holder>John Doe</card_holder>
<expiration_year>2020</expiration_year>
<expiration_month>2</expiration_month>
<payment_transaction>
<status>voided</status>
<authorization_code>345678</authorization_code>
<scheme_response_code>00</scheme_response_code>
<response_code>00</response_code>
<transaction_type>sale</transaction_type>
<unique_id>bad08183a9ec545daf0f24c48361aa10</unique_id>
<transaction_id>mtid201104081447161135536962</transaction_id>
<arn>74537605259536043849425</arn>
<terminal_token>e9fd7a957845450fb7ab9dccb498b6e1f6e1e3aa</terminal_token>
<mode>test</mode>
<timestamp>2011-04-08T14:46:40Z</timestamp>
<descriptor>emerchantpay.net/bogus +49123456789</descriptor>
<bank_account_number>Bank Account Number</bank_account_number>
<bank_identifier_code>Bank Identifier Code</bank_identifier_code>
<amount>5000</amount>
<currency>USD</currency>
<reason_for_not_honoring_exemption>8A01</reason_for_not_honoring_exemption>
<sca_exemption_result>13</sca_exemption_result>
<customer_email>john.doe@example.com</customer_email>
<customer_phone>+11234567890</customer_phone>
<billing_address>
<first_name>John</first_name>
<last_name>Doe</last_name>
<address1>32, Doestreet</address1>
<address2></address2>
<zip_code>12345</zip_code>
<city>New York</city>
<state>NY</state>
<country>US</country>
</billing_address>
</payment_transaction>
<payment_transaction>
<status>approved</status>
<authorization_code>345678</authorization_code>
<scheme_response_code>00</scheme_response_code>
<response_code>00</response_code>
<transaction_type>void</transaction_type>
<unique_id>bad08183a9ec545daf0f24c48361aa10</unique_id>
<transaction_id>mtid201104081447161135536962</transaction_id>
<terminal_token>e9fd7a957845450fb7ab9dccb498b6e1f6e1e3aa</terminal_token>
<mode>test</mode>
<timestamp>2011-04-08T14:46:40Z</timestamp>
<descriptor>emerchantpay.net/bogus +49123456789</descriptor>
<amount>5000</amount>
<currency>USD</currency>
</payment_transaction>
</wpf_payment>
Example Error Response XML:
<?xml version="1.0" encoding="UTF-8"?>
<wpf_payment>
<status>error</status>
<code>100</code>
<technical_message>Unknown system error. Please contact support.</technical_message>
<message>Transaction failed, please contact support!</message>
</wpf_payment>
Reconcile by Date range
Reconcile by Date can be used to retrieve data about payments in date and time range. This can be useful if the merchant wants to retrieve information about payments belonging to the date and time range. For convenience, there are options to define records per page and the exact page of interest.
Reconcile by Date requests are handled exactly like transaction requests in the Processing API. To a large degree, the WPF Reconcile follows the notions of the standard Reconcile in Processing API.
The URL for date range reconcile is:
https://staging.wpf.emerchantpay.net/wpf/reconcile/by_date
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.wpf.emerchantpay.net/wpf/reconcile/by_date \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<wpf_reconcile>
<start_date>2024-10-19 10:24:03</start_date>
<end_date>2025-01-17 10:24:03</end_date>
<page>1</page>
<records_per_page>100</records_per_page>
</wpf_reconcile>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
start_date | required | yyyy-mm-dd hh:mm:ss | Start date and time of the reconcile range (time is optional) |
end_date | optional | yyyy-mm-dd hh:mm:ss | End of date and time of the reconcile range (time is optional) |
page | optional | string(11) | Number of the page |
records_per_page | optional | 1 to 3 digits | Number ot records per page |
required* = conditionally required
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<wpf_payment_responses page="1" per_page="100" total_count="1" pages_count="1">
<wpf_payment>
<status>approved</status>
<unique_id>e27bd9472d40d3734a49e3e5c5ada52d</unique_id>
<transaction_id>246d15a8644ff203fca6ae39fac8e999</transaction_id>
<timestamp>2024-12-28</timestamp>
<amount>500</amount>
<currency>USD</currency>
<authorization_code>345678</authorization_code>
<retrieval_reference_number>016813015184</retrieval_reference_number>
</wpf_payment>
</wpf_payment_responses>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
status | string(255) | Status of the WPF transaction, see states |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
transaction_id | string(255) | Unique transaction id defined by merchant |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
authorization_code | string(6) | Generated by the card network when an authorisation has occurred, used to identify that auth. Consists of 6 alphanumeric chars |
retrieval_reference_number | string(255) | A reference number used for tracking all messages related to a given cardholder transaction returned by some acquirers. |
reason_for_not_honoring_exemption | string | Reason for not honoring exemption. Check SCA Reason For Not Honoring Exemption Values. |
sca_exemption_result | string | SCA exemption result. Check SCA Exemption Result Values. |
Error Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<wpf_payment>
<status>error</status>
<code>340</code>
<technical_message>start_date has an invalid format</technical_message>
<message>Please check input data for errors!</message>
</wpf_payment>
Error Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<wpf_payment>
<status>error</status>
<code>320</code>
<technical_message>start_date is missing</technical_message>
<message>Please check input data for errors!</message>
</wpf_payment>
Error Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<wpf_payment>
<status>error</status>
<code>340</code>
<technical_message>per_page has an invalid format</technical_message>
<message>Please check input data for errors!</message>
</wpf_payment>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
status | string(255) | Status of the WPF transaction, see states |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
WPF States
WPF transactions will have one of the following states:
Status | Description |
---|---|
new | Initial status of the wpf transaction. |
user | Waiting for the user to fill out and submit the WPF form. |
timeout | The transaction has been pending for too long and the timeout period has been reached. |
in_progress | The transaction is currently being processed. |
unsuccessful | Currently not used. |
pending | The outcome of the transaction could not be determined, e.g. due to a timeout. The transaction state will eventually change - perform a reconcile after a certain time frame to obtain the correct status. |
pending_hold | An asynchronous transaction has been finalized by the user but is waiting for a final update from the provider. |
approved | The transaction has been approved by the schemes and it has been successful. |
declined | The transaction has been declined by the schemes or risk management. |
error | An error has occurred while negotiating with the schemes. |
refunded | Once an approved transaction has been refunded the state changes to refunded. |
voided | The transaction has been authorized, but cancelled at a later stage by the merchant. |
chargebacked | Once an approved transaction has been chargebacked - the state changes to chargebacked. A chargeback occurs when the cardholder or the issuer rejects an accepted transaction for which funds have already been transferred. |
chargeback_reversal | Once a chargebacked transaction has been charged, the state changes to chargeback_reversal. The chargeback has been cancelled. |
represented | When the merchant submits evidence to prove that a chargeback is illegitimate, a chargebacked transaction changes its state to represented. The chargeback has been dismissed. |
representment_reversed | When a representment initiated by the merchant is cancelled or rejected by the acquirer (the merchant's bank) due to an error or invalid reason for representment. The funds that were initially refunded to the merchant as a result of the re-presentment are reversed back to the issuer account (the cardholder's bank). |
second_chargebacked | Once a chargeback_reversed/represented transaction is chargebacked the state changes to second chargebacked. |
pending_review | The transaction is on hold, a manual review needs to be performed. |
submitted | The WPF form was submitted by the user. |
Errors
WPF transaction types
The web payment form supports the typical card-related transaction types such as authorizes, sales, and init recurring - with and without 3D (see below). If more than one card-based transaction type is passed, then if the cardholder decides to pay with a credit card, the first card-based transaction type with a valid configuration - terminals, MIDs, currencies, etc - is selected and used when cardholder decides to pay with a (credit) card.
Also Account Verification for cards is supported by the web payment form. This is a transaction type for card verifications without any financial impact on cardholder's account. If ’account_verification’ is the only transaction type provided, the ’amount’ and the ’currency’ parameters are NOT mandatory. If it is combined with other transaction types, they are still mandatory and required.
In addition, the WPF API supports a host of alternative payment methods (APMs), bank transfer payments, wallets, and more. All of the alternative transaction types are offered to the cardholder for payment, so the cardholder can choose between credit cards and alternatives defined by the merchant. Only credit cards or only a single alternative method can also work, there is no need to always offer credit cards for example.
Merchant custom attributes for a number of the transaction types are required. The WPF API supports those merchant custom attributes - they are submitted as child elements to the transaction type they belong to(see WPF API example request above).
The web payment form has the concept of a default payment method. If a given transaction type has the ’default’ attribute set to ’true’, then this transaction type will be pre-selected as default when the cardholder is redirected to the web payment form. If more than one transaction type has the ’default’ attribute, the first one with this attribute will be pre-selected. In the case there is only one transaction type requested (with or without the ’default’=’true’), this transaction type is automatically set as default by design.
Note that for each transaction type requested by a merchant in the WPF API, a valid configuration should exist - valid terminal, currency, MID, web payment form enabled for the merchant, etc. - otherwise a configuration error will be raised. If this happens, contact the IT support team to resolve/configure your desired transaction types correctly.
Example Request XML with custom attributes:
<?xml version="1.0" encoding="UTF-8"?>
<wpf_payment>
<transaction_id>wev238f328nc</transaction_id>
<usage>Order ID 500, Shoes</usage>
<description>You are about to buy 3 shoes at www.shoes.com!</description>
<notification_url>https://example.com/notification</notification_url>
<return_success_url>https://example.com/return_success</return_success_url>
<return_failure_url>https://example.com/return_failure</return_failure_url>
<return_cancel_url>https://example.com/return_cancel</return_cancel_url>
<amount>5000</amount>
<currency>USD</currency>
<customer_email>john.doe@example.com</customer_email>
<customer_phone>+11234567890</customer_phone>
<card_holder>john doe</card_holder>
<billing_address>
<first_name>John</first_name>
<last_name>Doe</last_name>
<address1>23, Doestreet</address1>
<zip_code>11923</zip_code>
<city>New York City</city>
<state>NY</state>
<country>US</country>
</billing_address>
<transaction_types>
<transaction_type>
<name>sale</name>
<recurring_type>initial</recurring_type>
<bin>420000</bin>
<tail>0000</tail>
<expiration_date>2017-03</expiration_date>
<fx_rate_id>123</fx_rate_id>
<crypto>true</crypto>
</transaction_type>
<transaction_type>
<name>sale3d</name>
<recurring_type>initial</recurring_type>
<default>true</default>
<tail>1111</tail>
<expiration_date>2016-03</expiration_date>
<fx_rate_id>123</fx_rate_id>
<crypto>true</crypto>
</transaction_type>
<transaction_type name="cashu"/>
<transaction_type name="ezeewallet">
<source_wallet_id>john.doe@emerchantpay.net</source_wallet_id>
</transaction_type>
<transaction_type name="ppro">
<payment_method>mybank</payment_method>
</transaction_type>
<transaction_type name="insta_debit_payin">
<customer_account_id>123456</customer_account_id>
</transaction_type>
<transaction_type name="invoice">
<payment_type>secure_invoice</payment_type>
<customer_birthdate>1989-09-21</customer_birthdate>
<customer_reference_number>123123</customer_reference_number>
</transaction_type>
</transaction_types>
<recurring_category>subscription</recurring_category>
<risk_params>
<user_id>123456</user_id>
</risk_params>
</wpf_payment>
Transaction Type | Custom Attribute | Required | Description |
---|---|---|---|
authorize | A standard authorization | ||
bin | no | Card’s first 6 digits | |
tail | no | Card’s last 4 digits | |
default | no | Configure as default or not | |
expiration_date | no | Expiration month and year | |
gaming | no | Signifies whether a gaming transaction is performed. Gaming transactions usually use MCC 7995. Contact tech-support@emerchantpay.com for more details | |
crypto | no | Signifies whether a purchase of crypto-currency transaction is performed. Must be populated when purchasing crypto-currency with a VISA card. Must be populated when purchasing crypto-currency with a MASTER or INTL MAESTRO card and MCC is one of 6051, 6211. Contact tech-support@emerchantpay.com for more details | |
moto | no | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech-support@emerchantpay.com for more details | |
fx_rate_id | no | See Get rates for FX Service. Offers the option to use a specific FX rate to convert the transaction processing amount. Used FX rate should have the same source currency as the processing currency. Contact tech-support@emerchantpay.com for more details | |
authorize3d | A 3D-based authorization | ||
bin | no | Card’s first 6 digits | |
tail | no | Card’s last 4 digits | |
default | no | Configure as default or not | |
expiration_date | no | Expiration month and year | |
gaming | no | Signifies whether a gaming transaction is performed. Gaming transactions usually use MCC 7995. Contact tech-support@emerchantpay.com for more details | |
crypto | no | Signifies whether a purchase of crypto-currency transaction is performed. Must be populated when purchasing crypto-currency with a VISA card. Must be populated when purchasing crypto-currency with a MASTER or INTL MAESTRO card and MCC is one of 6051, 6211. Contact tech-support@emerchantpay.com for more details | |
moto | no | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech-support@emerchantpay.com for more details | |
fx_rate_id | no | See Get rates for FX Service. Offers the option to use a specific FX rate to convert the transaction processing amount. Used FX rate should have the same source currency as the processing currency. Contact tech-support@emerchantpay.com for more details | |
sale | A standard sale | ||
bin | no | Card’s first 6 digits | |
tail | no | Card’s last 4 digits | |
default | no | Configure as default or not | |
expiration_date | no | Expiration month and year | |
gaming | no | Signifies whether a gaming transaction is performed. Gaming transactions usually use MCC 7995. Contact tech-support@emerchantpay.com for more details | |
crypto | no | Signifies whether a purchase of crypto-currency transaction is performed. Must be populated when purchasing crypto-currency with a VISA card. Must be populated when purchasing crypto-currency with a MASTER or INTL MAESTRO card and MCC is one of 6051, 6211. Contact tech-support@emerchantpay.com for more details | |
moto | no | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech-support@emerchantpay.com for more details | |
fx_rate_id | no | See Get rates for FX Service. Offers the option to use a specific FX rate to convert the transaction processing amount. Used FX rate should have the same source currency as the processing currency. Contact tech-support@emerchantpay.com for more details | |
sale3d | A 3D-based sale | ||
bin | no | Card’s first 6 digits | |
tail | no | Card’s last 4 digits | |
default | no | Configure as default or not | |
expiration_date | no | Expiration month and year | |
gaming | no | Signifies whether a gaming transaction is performed. Gaming transactions usually use MCC 7995. Contact tech-support@emerchantpay.com for more details | |
crypto | no | Signifies whether a purchase of crypto-currency transaction is performed. Must be populated when purchasing crypto-currency with a VISA card. Must be populated when purchasing crypto-currency with a MASTER or INTL MAESTRO card and MCC is one of 6051, 6211. Contact tech-support@emerchantpay.com for more details | |
moto | no | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech-support@emerchantpay.com for more details | |
fx_rate_id | no | See Get rates for FX Service. Offers the option to use a specific FX rate to convert the transaction processing amount. Used FX rate should have the same source currency as the processing currency. Contact tech-support@emerchantpay.com for more details | |
init_recurring_sale | A standard init recurring | ||
bin | no | Card’s first 6 digits | |
tail | no | Card’s last 4 digits | |
default | no | Configure as default or not | |
expiration_date | no | Expiration month and year | |
moto | no | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech-support@emerchantpay.com for more details | |
fx_rate_id | no | See Get rates for FX Service. Offers the option to use a specific FX rate to convert the transaction processing amount. Used FX rate should have the same source currency as the processing currency. Contact tech-support@emerchantpay.com for more details | |
managed_recurring | no | See Managed Recurring. Offers the option to automatically schedule recurring transactions. Contact tech-support@emerchantpay.com for more details | |
init_recurring_sale3d | A 3D-based init recurring | ||
bin | no | Card’s first 6 digits | |
tail | no | Card’s last 4 digits | |
default | no | Configure as default or not | |
expiration_date | no | Expiration month and year | |
moto | no | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech-support@emerchantpay.com for more details | |
fx_rate_id | no | See Get rates for FX Service. Offers the option to use a specific FX rate to convert the transaction processing amount. Used FX rate should have the same source currency as the processing currency. Contact tech-support@emerchantpay.com for more details | |
managed_recurring | no | See Managed Recurring. Offers the option to automatically schedule recurring transactions. Contact tech-support@emerchantpay.com for more details | |
account_verification | Card verification without any financial impact | ||
bin | no | Card’s first 6 digits | |
tail | no | Card’s last 4 digits | |
default | no | Configure as default or not | |
expiration_date | no | Expiration month and year | |
moto | no | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech-support@emerchantpay.com for more details | |
alipay | Alipay is an oBeP-style alternative payment method. | ||
usage | optional | Description of the transaction for later use. | |
default | no | Configure as default or not | |
argencard | Argencard is a cash payment method in Argentina. | ||
default | no | Configure as default or not | |
aura | Aura is a cash payment method in Brazil. | ||
default | no | Configure as default or not | |
bancomer | BBVA Bancomer is a cash payment method in Mexico. | ||
default | no | Configure as default or not | |
boleto | Boleto Bancario is a cash payment method in Brazil. | ||
default | no | Configure as default or not | |
bcmc | Bancontact is a local Belgian debit card scheme. | ||
default | no | Configure as default or not | |
baloto | Baloto is a cash payment option in Colombia. | ||
default | no | Configure as default or not | |
banco_do_brasil | Banco do Brasil offers online bank transfer payment service. | ||
default | no | Configure as default or not | |
bitpay_sale | Alternative payment methods supporting digital cryptocurrencies. | ||
default | no | Configure as default or not | |
bitpay_payout | BitPay Payout is a crypto currency payout method. | ||
crypto_address | required | string(255) | Valid crypto address where the funds will be received |
crypto_wallet_provider | required | string(255) | If crypto wallet provider is not in the table below, you must send ’other’ |
default | no | Configure as default or not | |
bradesco | Bradesco is a payment service in Brazil. | ||
default | no | Configure as default or not | |
cashu | CashU is a voucher payment method | ||
default | no | Configure as default or not | |
container_store | The container store transactions are made using gift cards. | ||
card_number | required | string(19..21) | Gift card number |
cvv | required | 5 to 8 digits | Verification code of the gift card, requirement is based on terminal configuration |
default | no | Configure as default or not | |
cabal | Cabal is a card payment method in Argentina. | ||
default | no | Configure as default or not | |
cencosud | Cencosud is a cash payment method in Argentina. | ||
default | no | Configure as default or not | |
davivienda | Davivienda is offering the Bill pay service which is a fast, easy and secure | ||
default | no | Configure as default or not | |
ezeewallet | eZeeWallet is a comprehensive digital wallet. | ||
merchant_website | required | url | Website URL of the merchant initiating the wallet transfer |
default | no | Configure as default or not | |
e_wallet | eWallet transaction that handles different e-wallet providers | ||
payment_type | required | string | eWallet provider name: Airtel Money / Amazon pay / Free Charge / Jio Money / Ola Money / Paytm / Payzapp / PhonePe |
default | no | Configure as default or not | |
efecty | Efecty is an offline cash payment voucher option in Colombia. | ||
default | no | Configure as default or not | |
elo | Elo is a cash payment method in Brazil. | ||
default | no | Configure as default or not | |
eps | EPS is a cash payment method in Austria. | ||
default | no | Configure as default or not | |
fashioncheque | Fashioncheque transactions are made using gift card | ||
default | no | Configure as default or not | |
apple_pay | Apple Pay is a mobile payment solution available on iOS devices with Touch ID / Face ID support and allows shoppers to purchase with credit and debit cards linked to their devices. | ||
payment_subtype | yes | Payment subtype: authorize / sale | |
recurring_type | no | Recurring type: initial | |
default | no | Configure as default or not | |
google_pay | Google Pay is an option to use credit or debit cards connected to a consumer's Google account | ||
payment_subtype | yes | Payment subtype: authorize / sale | |
recurring_type | no | Recurring type: initial | |
default | no | Configure as default or not | |
invoice | APMs Invoice Transaction | ||
payment_type | yes | Payment type: klarna / secure_invoice | |
customer_birthdate | yes | Customer birthdate. For example: 1989-09-22 | |
customer_reference_number | yes | Customer number in merchant system | |
default | no | Configure as default or not | |
itau | Itau is a cash payment method in Brazil. | ||
default | no | Configure as default or not | |
ideal | iDeal is the most popular payment method in the Netherlands. | ||
default | no | Configure as default or not | |
idebit_payin | iDebit is alternative payment method | ||
default | no | Configure as default or not | |
insta_debit_payin | Debit is alternative payment method | ||
default | no | Configure as default or not | |
intersolve | Intersolve transactions iDeal is the most popular payment method in the Netherlands. | ||
default | no | Configure as default or not | |
multibanco | Multibanco allows Portugese shoppers to do payments through the Internet by using virtual credit cards. | ||
default | no | Configure as default or not | |
my_bank | MyBank is a payment method for Italy and Spain. | ||
default | no | Configure as default or not | |
naranja | Naranja is a cash payment method in Argentina. | ||
default | no | Configure as default or not | |
nativa | Nativa is a cash payment method in Argentina. | ||
default | no | Configure as default or not | |
neosurf | Neosurf is voucher payment method supported via IPG | ||
default | no | Configure as default or not | |
neteller | Neteller is wallet payment method | ||
default | no | Configure as default or not | |
online_banking | Online Banking is an OBeP payment method. | ||
default | no | Configure as default or not | |
bank_codes | no | List of top level bank codes | |
oxxo | OXXO is the preferred payment method in Mexico. | ||
default | no | Configure as default or not | |
paysafecard | PaySafeCard is a voucher payment method | ||
default | no | Configure as default or not | |
post_finance | Online Banking ePayment method | ||
default | no | Configure as default or not | |
ppro | Supports payments with EPS, TeleIngreso, SafetyPay, Przelewy24, iDEAL, Mr. Cash and MyBank | ||
default | no | Configure as default or not | |
poli | Payment by bfvank account for customers with an Australian or New Zealand bank account. | ||
default | no | Configure as default or not | |
p24 | Payment by bank account for customers with a Polish bank account. | ||
default | no | Configure as default or not | |
pay_pal | PayPal gives an option to use consumer's PayPal account payment methods. | ||
payment_type | yes | Payment type: authorize / sale / express | |
default | no | Configure as default or not | |
payu | PayU is a Czech payment method. | ||
default | no | Configure as default or not | |
post_finance | Post Finance is an online Switzerland banking method | ||
default | no | Configure as default or not | |
pago_facil | Pago Facil is a payment service in Argentina | ||
default | no | Configure as default or not | |
pse | Pagos Seguros en Linea (PSE) is a payment service in Colombia | ||
default | no | Configure as default or not | |
upi | UPI (Unified Payment Interface) transaction is an alternative payment method. | ||
default | no | Configure as default or not | |
rapi_pago | Rapipago is an Argentinian payment method used for online purchases. | ||
default | no | Configure as default or not | |
redpagos | Redpagos is a cash payment method in Uruguay. | ||
default | no | Configure as default or not | |
santander | Santander is an online bank transfer for ecommerce purchases. | ||
safetypay | Safetypay is a real-time bank transfer system that operates in more than 10 different countries. | ||
default | no | Configure as default or not | |
sofort | Bank transfer payment, popular in Germany | ||
default | no | Configure as default or not | |
webmoney | Bank transfer payment, popular in Russian Federation. | ||
sdd_sale | SEPA Direct Debit sale | ||
sdd_init_recurring_sale | SEPA Direct Debit init recurring | ||
tarjeta_shopping | Tarjeta Shopping is a cash payment method in Argentina. | ||
default | no | Configure as default or not | |
trustly_sale | Solution for Online Banking ePayments. | ||
return_success_url_target | required | URLTarget for successful payment in Trustly iFrame. Possible values: top, self, parent | |
webpay | Webpay is a payment solution in Chile that allows shoppers to pay online with their credit card. | ||
default | no | Configure as default or not | |
Online Banking ePayment method | |||
product_code | no | Product code | |
product_num | no | Product number | |
product_desc | no | Product description | |
invoice | APMs Invoice Transaction | ||
payment_type | yes | Payment type: klarna / secure_invoice | |
customer_birthdate | yes | Customer birthdate. For example: 1989-09-22 | |
customer_reference_number | yes | Customer number in merchant system | |
russian_mobile_sale | Mobile network operator payments in Russian Federation. | ||
target | required | Payment target | |
operator | required | Mobile network operator name (mtc, megafon, tele2 or beeline). |
WPF Internationalization (i18n)
The web payment form is internationalized (i18n) and supports the following locales and corresponding languages:
Locale | Language | Description |
---|---|---|
en | English | English locale and language settings (this is the default) |
it | Italian | Italian locale and language settings |
es | Spanish | Spanish locale and language settings |
fr | French | French locale and language settings |
de | German | German locale and language |
pl | Polish | Polish locale and language |
ja | Japanese | Japanese locale and language |
zh | Mandarin Chinese | Mandarin Chinese locale and language |
ar | Arabic | Arabic locale and language |
pt | Portuguese | Portuguese locale and language |
tr | Turkish | Turkish locale and language |
ru | Russian | Russian locale and language |
hi | Hindu | Hindu locale and language |
bg | Bulgarian | Bulgarian locale and language |
nl | Dutch | Dutch locale and language |
is | Icelandic | Icelandic locale and language |
id | Indonesian | Indonesian locale and language |
ms | Malay | Malay locale and language |
th | Thai | Thai locale and language |
cs | Czech | Czech locale and language |
hr | Croatian | Croatian locale and language |
sl | Slovenian | Slovenian locale and language |
fi | Finnish | Finnish locale and language |
no | Norwegian | Norwegian locale and language |
da | Danish | Danish locale and language |
sv | Swedish | Swedish locale and language |
Note that the English locale is the default, and if you don’t specify another locale in the WPF API, this is the locale and language that the web payment form will be translated into.
The customer has the option to change the language once he has been redirected to the WPF via the received redirect_url
.
It is a good practice to submit the desired locale in the WPF API create call, so that a proper redirect_url
is returned instead of manually parsing and generating a locale-specific redirect_url
.
If a locale/language different than the current ones is needed or any translation errors/inconsistencies are spotted, feel free to contact the IT Support team at tech-support@emerchantpay.com and contribute to the translation effort.
3DSecure
3DSecure (3-domain structure), also known as a payer authentication, is a security protocol that helps to prevent fraud in online credit and debit card transactions. This additional security was initiated and created by Visa and MasterCard and it’s branded as Verified by Visa and MasterCard SecureCode respectively.
3DSecure (3DS): A set of protocols and procedures through which a customer's ownership of the credit card they are using can be assessed. 3DSv2 offers a number of enhancements, including frictionless flows.
V2
Introduction
How does 3DS 2.0 work? Better, stronger fraud-detection intelligence, to put it simply.
3DSecure has been around for years and creates an authentication data connection between digital merchants, payment networks and financial institutions to be able to analyze and share more intelligence about transactions. The new 2.0 version of the technology enables a real-time, secure, information-sharing pipeline that merchants can use to send an unprecedented number of transaction attributes that the issuer can use to authenticate customers more accurately without asking for a static password or slowing down commerce.
All in all, the second iteration of the 3DSecure protocol is a great improvement for all parties involved.
It allows merchants to provide protection across multiple platforms with easy integration into their systems, including mobile applications, while still being able to exploit the benefits that the protocol provides. It is also estimated that cart abandonment rates will dramatically fall.
Issuers can share and receive more data with merchants, giving them a greater insight into transactional patterns which will allow them to determine the risk with higher accuracy and therefore improve the authentication process. 3DS 2.0 will also offer banks the opportunity to effortlessly comply with the requirements of PSD2.
For customers, the updates are perhaps most beneficial. They can now enjoy protection from fraudulent transactions across most platforms.
Not only will transactions be more secure through the implementation of increased protection methods such as two-factor authentication (2FA), but the consumer experience will also be greatly improved by frictionless flows through risk-based authentication.
3DS 2.0 is an updated protocol created to recognise the need of current and future requirements including adding the support of mobile-based authentication and digital wallets integration. One of the main benefits is the introduction of a frictionless flow that allows issuers to approve a transaction without requiring any manual input from the cardholder.
3DSecure Challenge: The 3DS 2.0 step during which the customer interacts with the card issuer to provide additional authentication for the transaction.
3DSecure Method: Refers to the 3DS 2.0 step during which the card issuer gathers information about the customer via their browser. A card issuer may use this data to help make a risk-based decision , for example if the issuer can identify that the cardholder has used this web browser to make purchases in the past, they may decide the transaction is low risk and consider the customer authenticated without requiring a 3DSecure Challenge.
3DSecure Method Handling: The 3DSecure Method allows for additional browser information to be gathered by an ACS prior to receipt of the AReq message to help facilitate the transaction risk assessment. The use of the 3DSecure Method by an ACS is optional. The inclusion of 3DSecure Method URL and account ranges in a Directory Server is optional for an ACS.
Access Control Server: The ACS contains the authentication rules and is controlled by the Issuer. ACS functions include:
- Verifying whether a card number is eligible for 3DSecure authentication
- Verifying whether a Consumer Device type is eligible for 3DSecure authentication
- Authenticating the Cardholder for a specific transaction
Consumer Device: The Consumer Device has the capability to run a 3DSecure Requestor App or present a website on a browser that can be used for 3DSecure authentication. The Consumer Device-based components of the 3DSecure Requestor Environment depend on the model:
- App-based - the 3DSecure SDK integrated with the 3DSecure Requestor App
- Browser-based - a browser utilising the 3DSecure Method
Frictionless: The authentication completes without requiring a interaction between consumer and issuer.
Request Params
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
threeds_v2_params | required* | 3DSv2 async parameters. They must be submitted in order to use the 3DSv2 authentication protocol in asynchronous workflow | |
threeds_method | optional | 3DS-Method related parameters for any callbacks and notifications. | |
callback_url | optional | url | Specific 3DS-Method callback URL after the 3DS-Method completes. The actual status will be provided via HTTP POST to that URL. For more information, go to 3DSv2 method params |
control | required* | General params for preferences in authentication flow and providing device interface information. | |
device_type | required* | string | Identifies the device channel of the consumer, required in the 3DSv2 authentication protocol. For more information, go to 3DSv2 control params |
challenge_window_size | required* | string | Identifies the size of the challenge window for the consumer. For more information, go to 3DSv2 control params |
challenge_indicator | optional | string | The value has weight and might impact the decision whether a challenge will be required for the transaction or not. If not provided, it will be interpreted as no_preference. For more information, go to 3DSv2 control params |
purchase | optional | Purchase related params providing with additional information regarding the order. | |
category | optional | string | Identifies the type of transaction being authenticated. This field is required in some markets.Accepted values are: goods, service, check_acceptance, account_funding, quasi_cash, prepaid_activation, loan. |
merchant_risk | recommended | Merchant risk assessment params. They are all optional, but recommended. | |
shipping_indicator | optional | string(16) | Indicator code that most accurately describes the shipping method for the cardholder specific transaction. If one or more items are included in the sale, use the Shipping Indicator code for the physical goods. If all digital goods, use the code that describes the most expensive item. Accepted values are: same_as_billing, stored_address, verified_address, pick_up, digital_goods, travel, event_tickets, other. |
delivery_timeframe | optional | string(11) | Indicates the merchandise delivery timeframe. Accepted values are: electronic, same_day, over_night, another_day. |
reorder_items_indicator | optional | string(10) | Indicates whether the cardholder is reordering previously purchased merchandise. Accepted values are: first_time, reordered. |
pre_order_purchase_indicator | optional | string(21) | Indicates whether cardholder is placing an order for merchandise with a future-availability or release date. Accepted values are: merchandise_available, future_availability. |
pre_order_date | optional | dd-mm-yyyy | For a pre-ordered purchase, the expected date that the merchandise will be available. |
gift_card | optional | 'true' | Prepaid or gift card purchase. |
gift_card_count | optional | integer | For prepaid or gift card purchase, total count of individual prepaid or gift cards/codes purchased. The value is limited to 99. |
card_holder_account | recommended | Cardholder account additional information. They are all optional, but recommended, because they have a significant impact on approval rates | |
creation_date | optional | dd-mm-yyyy | Date that the cardholder opened the account with the 3DS Requester. |
update_indicator | optional | string(19) | Length of time since the cardholder’s account information with the 3DS Requestor was last changed. Includes Billing or Shipping address, new payment account, or new user(s) added. Accepted values are: current_transaction, less_than_30days, 30_to_60_days, more_than_60days. |
last_change_date | optional | dd-mm-yyyy | Date that the cardholder’s account with the 3DS Requestor was last changed. Including Billing or Shipping address, new payment accout, or new user(s) added. |
password_change_indicator | optional | string(18) | Length of time since the cardholder account with the 3DS Requestor had a password change or account reset. Accepted values are: no_change, during_transaction, less_than_30days, 30_to_60_days, more_than_60days. |
password_change_date | optional | dd-mm-yyyy | Date that cardholder’s account with the 3DS Requestor had a password change or account reset. |
shipping_address_usage_indicator | optional | string(19) | Indicates when the shipping address used for this transaction was first used with the 3DS Requestor. Accepted values are: current_transaction, less_than_30days, 30_to_60_days, more_than_60days. |
shipping_address_date_first_used | optional | dd-mm-yyyy | Date when the shipping address used for this transaction was first used with the 3DS Requestor. |
transactions_activity_last_24_hours | optional | integer | Number of transactions (successful and abandoned) for this cardholder account with the 3DS Requestor across all payment accounts in the previous 24 hours. |
transactions_activity_previous_year | optional | integer | Number of transactions (successful and abandoned) for this cardholder account with the 3DS Requestor across all payment accounts in the previous year. |
provision_attempts_last_24_hours | optional | integer | Number of Add Card attempts in the last 24 hours. |
purchases_count_last_6_months | optional | integer | Number of purchases with this cardholder account during the previous six months. |
suspicious_activity_indicator | optional | string(22) | Indicates whether the 3DS Requestor has experienced suspicious activity (including previous fraud) on the cardholder account. Accepted values are: no_suspicious_observed, suspicious_observed. |
registration_indicator | optional | string(19) | Indicates the length of time that the payment account was enrolled in the cardholder’s account with the 3DS Requester. Accepted values are: guest_checkout, current_transaction, less_than_30days, 30_to_60_days, more_than_60days. |
registration_date | optional | dd-mm-yyyy | Date that the payment account was enrolled in the cardholder’s account with the 3DS Requestor. |
browser | required* | For browser-based transactions. They are all required in case the device_type is set to browser | |
accept_header | required* | string(2048) | The exact content of the HTTP ACCEPT header as sent to the 3DS Requester from the Cardholder browser. Any other header different than the ACCEPT header will be rejected. Example: application/json,text/plain,text/html,*/* . |
java_enabled | required* | boolean | Boolean that represents the ability of the cardholder browser to execute Java. The value can be retrieved by accessing a property of the navigator with JavaScript, navigator.javaEnabled . |
language | required* | string(8) | Value representing the browser language as defined in IETF BCP47. Note that only one browser language tag is about to be submitted as per the above IETF BCP47. Numeric chars are also allowed in the subtag and will represent the region.Example: en-GB , zh-guoyu , fil-PH , gsw , es-419 , de-1996 , etc. The value can be retrieved by accessing a property of the navigator with JavaScript, navigator.language . |
color_depth | required* | integer | Value representing the bit depth of the colour palette for displaying images, in bits per pixel. Obtained from Cardholder browser using the screen.colorDepth property. The value as per EMVCo specs can be one of 1, 4, 8, 15, 16, 24, 32, 48. In case, an unsupported color_depth is determined, the nearest supported value that is less than the actual one needs to be submitted. For example, if the obtained value is 30, which is not supported as per EMVCo specs, 24 has to be submitted. |
screen_height | required* | integer | Total height of the Cardholder's screen in pixels. Value is returned from the screen.height property. |
screen_width | required* | integer | Total width of the Cardholder's screen in pixels. Value is returned from the screen.width property. |
time_zone_offset | required* | string(5) | Time difference between UTC time and the Cardholder browser local time, in minutes. Note that the offset is positive if the local time zone is behind UTC and negative if it is ahead. If UTC -5 hours then submit 300 or +300 , If UTC +2 hours then -120 . The value can be retrieved using Javascript getTimezoneOffset() method over Date object. |
user_agent | required* | string(2048) | Exact content of the HTTP user-agent header. |
sdk | required* | For application-based transactions. They are all required in case the device_type is set to application | |
interface | required* | string(6) | SDK Interface types that the device of the consumer supports for displaying specific challenge interfaces within the SDK. Accepted values are: native, html, both. |
ui_types | required* | Lists all UI types that the device of the consumer supports for displaying specific challenge interfaces within the SDK. | |
ui_type | required* | string(13) | UI type that the device of the consumer supports for displaying specific challenge interface. Accepted values are: text, single_select, multi_select, out_of_bag, other_html. |
application_id | required* | string(36) | Universally unique ID created upon all installations and updates of the 3DS Requestor APp on a Customer Device. This will be newly generated and stored by the 3DS SDK for each installation or update. The field is limited to 36 characters and it shall have a canonical format as defined in IETF RFC 4122. |
encrypted_data | required* | string(64000) | JWE Object as defined Section 6.2.2.1 containing data encrypted by the SDK for the DS to decrypt. The data will be present when sending to DS, but not present from DS to ACS. |
ephemeral_public_key_pair | required* | string(256) | Public key component of the ephemeral key pair generated by the 3DS SDK and used to establish session keys between the 3DS SDK and ACS. In AReq, this data element is contained within the ACS Signed Content JWS Object. The field is limited to maximum 256 characters. |
max_timeout | required* | integer | Indicates the maximum amount of time (in minutes) for all exchanges. The field shall have value greater or equals than 05. |
reference_number | required* | string(32) | Identifies the vendor and version of the 3DS SDK that is integrated in a 3DS Requestor App, assigned by EMVCo when the 3DS SDK is approved. The field is limited to 32 characters. |
recurring | optional | Additional recurring details. | |
expiration_date | optional | dd-mm-yyyy | A future date indicating the end date for any further subsequent transactions. For more information, go to 3DSv2 recurring params |
frequency | optional | integer | Indicates the minimum number of days between subsequent transactions. An empty value indicates the payment frequency is not set.For more information, go to 3DSv2 recurring params |
required* = conditionally required
3DS-Method Params
callback_url
- optional
Notes: The callback_url
is used in 3DSv2 scope is case a 3DS-Method is required to be submitted in asynchronous workflow.
The 3DS-Method is about to be submitted in an iframe and the final HTTP POST request to the callback_url
will be initiated
inside the iframe target of the HTML form used for submitting the 3DS-Method.
Once the 3DS-Method reaches a final state, a callback will be sent via HTTP POST (application/x-www-form-urlencoded) with the following parameters:
unique_id=44177a21403427eb96664a6d7e5d5d48
&threeds_method_status=completed
&signature=86bb547ba3daf8b7970d2e185404426a4c9790282a4612e21ef59dfc591a5fa227f88225571049e2242099effc19f53529433a2bd240a712d7e9ff4c8c4c65e8
The signature is a SHA512 of the concatenated string:
unique_id
, threeds_method_status
and the password
(a54a1e349b9784bb01126fdefc244b3ede19e84d) used for the HTTP Basic authentication to the API.
For more detailed information about the 3DS-Method submission and the usage of the 3DS-Method callback_url
,
please take a look at the 3DSv2 authentication flow diagrams related to the asynchronous 3DS-Method submission.
Control Params
challenge_indicator
- optional
Value | Description |
---|---|
no_preference (default) | Don't have any preferences related to the Challenge flow |
no_challenge_requested | I prefer that a Challenge flow does not take place |
preference | A request for the Challenge flow to take place |
mandate | A Challenge flow must take place to fulfill a mandate |
device_type
- required
Value | Description |
---|---|
browser | Browser-based consumer interface. All the browser parameters are required. |
application | Application-based consumer interface, mobile etc. All the sdk parameters are required. |
challenge_window_size
- required*
Notes: Dimensions of the challenge window that has been displayed to the Cardholder. The ACS shall reply with content that is formatted to appropriately render in this window to provide the best possible consumer experience. Preconfigured sizes are width X height in pixels of the window displayed in the Cardholder browser window.
Value | Description |
---|---|
250x400 | Challenge window: width of 250px and height of 400px |
390x400 | Challenge window: width of 390px and height of 400px |
500x600 | Challenge window: width of 500px and height of 600px |
600x400 | Challenge window: width of 600px and height of 400px |
full_screen | Challenge in a full screen |
Recurring Params
expiration_date
- optional
Value | Description |
---|---|
17-07-2025 | No further subsequent transactions are expected after that date. |
frequency
- optional
Value | Description |
---|---|
14 | Indicates a minimum number of 14 days between subsequent recurring transactions. |
30 | Indicates a minimum number of 30 days (monthly subscription) between subsequent recurring transactions. |
Authentication Flows
There are two general workflows for 3DS 2.0, Frictionless Flow and Challenge Flow.
Frictionless
A Frictionless Flow occurs when the Issuer authenticates the cardholder without cardholder involvement by evaluating the transaction's risk level.
The customer has more frictionless experience through the merchant’s platform by not being challenged. That means the drop-off rate due to the 3DSecure protocol will be drastically reduced and the customer will happily come back to the merchant’s platform.
The Frictionless Flow does not require further Cardholder interaction to achieve a successful authentication and complete the 3DSecure authentication process. The payment will be completely synchronous, the consumer won't be redirected to the Access Control Server to complete the authentication.
1.) The merchant submit a 3D transaction to the API including the 3DSecure v2 params
2.) No 3DSecure Method or 3DSecure Challenge is required by the card issuer, the transaction will be completed without further action.
3.) A synchronous payment response is returned to the merchant indicating the status of the payment.
Asynchronous 3 D Sv2 Frictionless Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Sale3D');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('4012000000060085')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
->setNotificationUrl('https://www.example.com/notification')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
// Threeds V2 Params
->setThreedsThreedsMethod('{"callback_url"=>"https://www.example.com/threeds/threeds_method/callback"}')
->setThreedsControl('{"device_type"=>"browser", "challenge_window_size"=>"full_screen", "challenge_indicator"=>"preference"}')
->setThreedsPurchase('{"category"=>"service"}')
->setThreedsRecurring('{"expiration_date"=>"17-07-2025", "frequency"=>30}')
->setThreedsMerchantRisk('{"shipping_indicator"=>"verified_address", "delivery_timeframe"=>"electronic", "reorder_items_indicator"=>"reordered", "pre_order_purchase_indicator"=>"merchandise_available", "pre_order_date"=>"17-02-2025", "gift_card"=>"true", "gift_card_count"=>"2"}')
->setThreedsCardHolderAccount('{"creation_date"=>"17-01-2024", "update_indicator"=>"more_than_60days", "last_change_date"=>"17-10-2024", "password_change_indicator"=>"no_change", "password_change_date"=>"02-01-2025", "shipping_address_usage_indicator"=>"current_transaction", "shipping_address_date_first_used"=>"12-01-2025", "transactions_activity_last_24_hours"=>"2", "transactions_activity_previous_year"=>"10", "provision_attempts_last_24_hours"=>"1", "purchases_count_last_6_months"=>"5", "suspicious_activity_indicator"=>"no_suspicious_observed", "registration_indicator"=>"30_to_60_days", "registration_date"=>"17-01-2023"}')
->setThreedsBrowser('{"accept_header"=>"*/*", "java_enabled"=>"false", "language"=>"en-GB", "color_depth"=>"24", "screen_height"=>"900", "screen_width"=>"1440", "time_zone_offset"=>"-120", "user_agent"=>"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"}')
->setThreedsSdk('{"interface"=>"native", "ui_types"=>{"ui_type"=>"multi_select"}, "application_id"=>"fc1650c0-5778-0138-8205-2cbc32a32d65", "encrypted_data"=>"encrypted-data-here", "ephemeral_public_key_pair"=>"public-key-pair", "max_timeout"=>"10", "reference_number"=>"sdk-reference-number-here"}')
// Sca Params
->setScaExemption('low_risk');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.Sale3DRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
Sale3DRequest request = new Sale3DRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4012000000060085");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
request.setNotificationUrl(new URL("https://www.example.com/notification"));
request.setReturnSuccessUrl(new URL("http://www.example.com/success"));
request.setReturnFailureUrl(new URL("http://www.example.com/failure"));
// Threeds V2 Params
request.setThreedsThreedsMethod("{"callback_url"=>"https://www.example.com/threeds/threeds_method/callback"}");
request.setThreedsControl("{"device_type"=>"browser", "challenge_window_size"=>"full_screen", "challenge_indicator"=>"preference"}");
request.setThreedsPurchase("{"category"=>"service"}");
request.setThreedsRecurring("{"expiration_date"=>"17-07-2025", "frequency"=>30}");
request.setThreedsMerchantRisk("{"shipping_indicator"=>"verified_address", "delivery_timeframe"=>"electronic", "reorder_items_indicator"=>"reordered", "pre_order_purchase_indicator"=>"merchandise_available", "pre_order_date"=>"17-02-2025", "gift_card"=>"true", "gift_card_count"=>"2"}");
request.setThreedsCardHolderAccount("{"creation_date"=>"17-01-2024", "update_indicator"=>"more_than_60days", "last_change_date"=>"17-10-2024", "password_change_indicator"=>"no_change", "password_change_date"=>"02-01-2025", "shipping_address_usage_indicator"=>"current_transaction", "shipping_address_date_first_used"=>"12-01-2025", "transactions_activity_last_24_hours"=>"2", "transactions_activity_previous_year"=>"10", "provision_attempts_last_24_hours"=>"1", "purchases_count_last_6_months"=>"5", "suspicious_activity_indicator"=>"no_suspicious_observed", "registration_indicator"=>"30_to_60_days", "registration_date"=>"17-01-2023"}");
request.setThreedsBrowser("{"accept_header"=>"*/*", "java_enabled"=>"false", "language"=>"en-GB", "color_depth"=>"24", "screen_height"=>"900", "screen_width"=>"1440", "time_zone_offset"=>"-120", "user_agent"=>"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"}");
request.setThreedsSdk("{"interface"=>"native", "ui_types"=>{"ui_type"=>"multi_select"}, "application_id"=>"fc1650c0-5778-0138-8205-2cbc32a32d65", "encrypted_data"=>"encrypted-data-here", "ephemeral_public_key_pair"=>"public-key-pair", "max_timeout"=>"10", "reference_number"=>"sdk-reference-number-here"}");
// Sca Params
request.setScaExemption("low_risk");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.sale3d(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": 100,
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "4012000000060085",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"notification_url": "https://www.example.com/notification",
"return_success_url": "http://www.example.com/success",
"return_failure_url": "http://www.example.com/failure",
"threeds_v2_params": {
"threeds_method": {
"callback_url": "https://www.example.com/threeds/threeds_method/callback"
},
"control": {
"device_type": "browser",
"challenge_window_size": "full_screen",
"challenge_indicator": "preference"
},
"purchase": {
"category": "service"
},
"recurring": {
"expiration_date": "17-07-2025",
"frequency": 30
},
"merchant_risk": {
"shipping_indicator": "verified_address",
"delivery_timeframe": "electronic",
"reorder_items_indicator": "reordered",
"pre_order_purchase_indicator": "merchandise_available",
"pre_order_date": "17-02-2025",
"gift_card": "true",
"gift_card_count": "2"
},
"card_holder_account": {
"creation_date": "17-01-2024",
"update_indicator": "more_than_60days",
"last_change_date": "17-10-2024",
"password_change_indicator": "no_change",
"password_change_date": "02-01-2025",
"shipping_address_usage_indicator": "current_transaction",
"shipping_address_date_first_used": "12-01-2025",
"transactions_activity_last_24_hours": "2",
"transactions_activity_previous_year": "10",
"provision_attempts_last_24_hours": "1",
"purchases_count_last_6_months": "5",
"suspicious_activity_indicator": "no_suspicious_observed",
"registration_indicator": "30_to_60_days",
"registration_date": "17-01-2023"
},
"browser": {
"accept_header": "*/*",
"java_enabled": "false",
"language": "en-GB",
"color_depth": "24",
"screen_height": "900",
"screen_width": "1440",
"time_zone_offset": "-120",
"user_agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"
},
"sdk": {
"interface": "native",
"ui_types": {
"ui_type": "multi_select"
},
"application_id": "fc1650c0-5778-0138-8205-2cbc32a32d65",
"encrypted_data": "encrypted-data-here",
"ephemeral_public_key_pair": "public-key-pair",
"max_timeout": "10",
"reference_number": "sdk-reference-number-here"
}
},
"sca_params": {
"exemption": "low_risk"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>sale3d</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4012000000060085</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<notification_url>https://www.example.com/notification</notification_url>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<threeds_v2_params>
<threeds_method>
<callback_url>https://www.example.com/threeds/threeds_method/callback</callback_url>
</threeds_method>
<control>
<device_type>browser</device_type>
<challenge_window_size>full_screen</challenge_window_size>
<challenge_indicator>preference</challenge_indicator>
</control>
<purchase>
<category>service</category>
</purchase>
<merchant_risk>
<shipping_indicator>verified_address</shipping_indicator>
<delivery_timeframe>electronic</delivery_timeframe>
<reorder_items_indicator>reordered</reorder_items_indicator>
<pre_order_purchase_indicator>merchandise_available</pre_order_purchase_indicator>
<pre_order_date>17-02-2025</pre_order_date>
<gift_card>true</gift_card>
<gift_card_count>2</gift_card_count>
</merchant_risk>
<card_holder_account>
<creation_date>17-01-2024</creation_date>
<update_indicator>more_than_60days</update_indicator>
<last_change_date>17-10-2024</last_change_date>
<password_change_indicator>no_change</password_change_indicator>
<password_change_date>02-01-2025</password_change_date>
<shipping_address_usage_indicator>current_transaction</shipping_address_usage_indicator>
<shipping_address_date_first_used>12-01-2025</shipping_address_date_first_used>
<transactions_activity_last_24_hours>2</transactions_activity_last_24_hours>
<transactions_activity_previous_year>10</transactions_activity_previous_year>
<provision_attempts_last_24_hours>1</provision_attempts_last_24_hours>
<purchases_count_last_6_months>5</purchases_count_last_6_months>
<suspicious_activity_indicator>no_suspicious_observed</suspicious_activity_indicator>
<registration_indicator>30_to_60_days</registration_indicator>
<registration_date>17-01-2023</registration_date>
</card_holder_account>
<browser>
<accept_header>*/*</accept_header>
<java_enabled>false</java_enabled>
<language>en-GB</language>
<color_depth>24</color_depth>
<screen_height>900</screen_height>
<screen_width>1440</screen_width>
<time_zone_offset>-120</time_zone_offset>
<user_agent>Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36</user_agent>
</browser>
<sdk>
<interface>native</interface>
<ui_types>
<ui_type>multi_select</ui_type>
</ui_types>
<application_id>fc1650c0-5778-0138-8205-2cbc32a32d65</application_id>
<encrypted_data>encrypted-data-here</encrypted_data>
<ephemeral_public_key_pair>public-key-pair</ephemeral_public_key_pair>
<max_timeout>10</max_timeout>
<reference_number>sdk-reference-number-here</reference_number>
</sdk>
</threeds_v2_params>
<sca_params>
<exemption>low_risk</exemption>
</sca_params>
</payment_transaction>'
Frictionless Response
stdClass Object
(
[transaction_type] => sale3d
[status] => approved
[mode] => test
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:24:03.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
[threeds] => {"eci"=>"05"}
)
<payment_response content=[
<transaction_type content=[sale3d]>
<status content=[approved]>
<mode content=[test]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<timestamp content=[2025-01-16T10:24:03Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[true]>
<threeds content=[{"eci"=>"05"}]>
]>
{
transaction_type: "sale3d",
status: "approved",
mode: "test",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
timestamp: "2025-01-16T10:24:03Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "true",
threeds: "{"eci"=>"05"}",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>sale3d</transaction_type>
<status>approved</status>
<mode>test</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<timestamp>2025-01-16T10:24:03Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
<threeds>
<eci>05</eci>
</threeds>
</payment_response>
Frictionless Declined Response
stdClass Object
(
[transaction_type] => sale3d
[status] => declined
[cvv_result_code] => P
[retrieval_reference_number] => 323623238231
[scheme_response_code] => 06
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[transaction_id] => 119643250547501c79d8295
[consumer_id] => 123456
[response_code] => 05
[code] => 500
[technical_message] => Do not honour
[message] => Transaction declined, please contact support!
[mode] => test
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:24:03.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[threeds] => {"eci"=>"05"}
[sent_to_acquirer] => true
[scheme_transaction_identifier] => 019091214161031
[scheme_settlement_date] => 0117
)
<payment_response content=[
<transaction_type content=[sale3d]>
<status content=[declined]>
<cvv_result_code content=[P]>
<retrieval_reference_number content=[323623238231]>
<scheme_response_code content=[06]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<transaction_id content=[119643250547501c79d8295]>
<consumer_id content=[123456]>
<response_code content=[05]>
<code content=[500]>
<technical_message content=[Do not honour]>
<message content=[Transaction declined, please contact support!]>
<mode content=[test]>
<timestamp content=[2025-01-16T10:24:03Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<threeds content=[{"eci"=>"05"}]>
<sent_to_acquirer content=[true]>
<scheme_transaction_identifier content=[019091214161031]>
<scheme_settlement_date content=[0117]>
]>
{
transaction_type: "sale3d",
status: "declined",
cvv_result_code: "P",
retrieval_reference_number: "323623238231",
scheme_response_code: "06",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
transaction_id: "119643250547501c79d8295",
consumer_id: "123456",
response_code: "05",
code: "500",
technical_message: "Do not honour",
message: "Transaction declined, please contact support!",
mode: "test",
timestamp: "2025-01-16T10:24:03Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
threeds: "{"eci"=>"05"}",
sent_to_acquirer: "true",
scheme_transaction_identifier: "019091214161031",
scheme_settlement_date: "0117",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>sale3d</transaction_type>
<status>declined</status>
<cvv_result_code>P</cvv_result_code>
<retrieval_reference_number>323623238231</retrieval_reference_number>
<scheme_response_code>06</scheme_response_code>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<transaction_id>119643250547501c79d8295</transaction_id>
<consumer_id>123456</consumer_id>
<response_code>05</response_code>
<code>500</code>
<technical_message>Do not honour</technical_message>
<message>Transaction declined, please contact support!</message>
<mode>test</mode>
<timestamp>2025-01-16T10:24:03Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<threeds>
<eci>05</eci>
</threeds>
<sent_to_acquirer>true</sent_to_acquirer>
<scheme_transaction_identifier>019091214161031</scheme_transaction_identifier>
<scheme_settlement_date>0117</scheme_settlement_date>
</payment_response>
Diagram
Reconcile
Once the transaction reaches the final state, a single reconcile can also be performed to retrieve more detailed information about the 3D transaction. It should include information about the 3DS transaction as described in the reconcile request/response below, on the right.
Reconcile 3 D Transaction By Unique Id Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('NonFinancial\Reconcile\Transaction');
$request = $genesis->request();
$request
->setUniqueId('44177a21403427eb96664a6d7e5d5d48');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.nonfinancial.reconcile.ReconcileRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
ReconcileRequest request = new ReconcileRequest();
request.setUniqueId("44177a21403427eb96664a6d7e5d5d48");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.reconcile(
{
"unique_id": "44177a21403427eb96664a6d7e5d5d48"
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/reconcile/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<reconcile>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
</reconcile>'
Successful Reconciliation Of Frictionless 3 D Sv2 Transaction Response
stdClass Object
(
[transaction_type] => sale3d
[status] => approved
[authorization_code] => 005645
[retrieval_reference_number] => 016813015184
[payment_account_reference] => Q1HJZ28RKA1EBL470G9XYG90R5D3E
[response_code] => 00
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[transaction_id] => 119643250547501c79d8295
[mode] => test
[timestamp] => 2025-01-16T10:24:03Z
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[card_brand] => visa
[card_number] => 401200...0085
[card_type] => CREDIT
[card_subtype] => CARD SUBTYPE
[card_issuing_bank] => Issuing Bank
[card_issuing_country] => Exact Issuing country
[bank_account_number] => Bank Account Number
[bank_identifier_code] => Bank Identifier Code
[sent_to_acquirer] => true
[arn] => 74537605259536043849425
[scheme_response_code] => 00
[scheme_transaction_link_id] => TLINKIDENTIFIER4521412
[scheme_max_settlement_date] => 2024-07-31
[scheme_authentication_data_quality] => true
[threeds] => {:authentication_flow=>"frictionless", :protocol=>{:target_version=>"2", :concrete_version=>"2", :sub_version=>"2"}, :eci=>"05"}
[threeds] => {:authentication_flow=>"frictionless", :protocol=>{:target_version=>"2", :concrete_version=>"2", :sub_version=>"2"}, :eci=>"05"}
)
<payment_response content=[
<transaction_type content=[sale3d]>
<status content=[approved]>
<authorization_code content=[005645]>
<retrieval_reference_number content=[016813015184]>
<payment_account_reference content=[Q1HJZ28RKA1EBL470G9XYG90R5D3E]>
<response_code content=[00]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<transaction_id content=[119643250547501c79d8295]>
<mode content=[test]>
<timestamp content=[2025-01-16T10:24:03Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<card_brand content=[visa]>
<card_number content=[401200...0085]>
<card_type content=[CREDIT]>
<card_subtype content=[CARD SUBTYPE]>
<card_issuing_bank content=[Issuing Bank]>
<card_issuing_country content=[Exact Issuing country]>
<bank_account_number content=[Bank Account Number]>
<bank_identifier_code content=[Bank Identifier Code]>
<sent_to_acquirer content=[true]>
<arn content=[74537605259536043849425]>
<scheme_response_code content=[00]>
<scheme_transaction_link_id content=[TLINKIDENTIFIER4521412]>
<scheme_max_settlement_date content=[2024-07-31]>
<scheme_authentication_data_quality content=[true]>
<threeds content=[{:authentication_flow=>"frictionless", :protocol=>{:target_version=>"2", :concrete_version=>"2", :sub_version=>"2"}, :eci=>"05"}]>
<threeds content=[{:authentication_flow=>"frictionless", :protocol=>{:target_version=>"2", :concrete_version=>"2", :sub_version=>"2"}, :eci=>"05"}]>
]>
{
transaction_type: "sale3d",
status: "approved",
authorization_code: "005645",
retrieval_reference_number: "016813015184",
payment_account_reference: "Q1HJZ28RKA1EBL470G9XYG90R5D3E",
response_code: "00",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
transaction_id: "119643250547501c79d8295",
mode: "test",
timestamp: "2025-01-16T10:24:03Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
card_brand: "visa",
card_number: "401200...0085",
card_type: "CREDIT",
card_subtype: "CARD SUBTYPE",
card_issuing_bank: "Issuing Bank",
card_issuing_country: "Exact Issuing country",
bank_account_number: "Bank Account Number",
bank_identifier_code: "Bank Identifier Code",
sent_to_acquirer: "true",
arn: "74537605259536043849425",
scheme_response_code: "00",
scheme_transaction_link_id: "TLINKIDENTIFIER4521412",
scheme_max_settlement_date: "2024-07-31",
scheme_authentication_data_quality: "true",
threeds: "{:authentication_flow=>"frictionless", :protocol=>{:target_version=>"2", :concrete_version=>"2", :sub_version=>"2"}, :eci=>"05"}",
threeds: "{:authentication_flow=>"frictionless", :protocol=>{:target_version=>"2", :concrete_version=>"2", :sub_version=>"2"}, :eci=>"05"}",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>sale3d</transaction_type>
<status>approved</status>
<authorization_code>005645</authorization_code>
<retrieval_reference_number>016813015184</retrieval_reference_number>
<payment_account_reference>Q1HJZ28RKA1EBL470G9XYG90R5D3E</payment_account_reference>
<response_code>00</response_code>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<transaction_id>119643250547501c79d8295</transaction_id>
<mode>test</mode>
<timestamp>2025-01-16T10:24:03Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<card_brand>visa</card_brand>
<card_number>401200...0085</card_number>
<card_type>CREDIT</card_type>
<card_subtype>CARD SUBTYPE</card_subtype>
<card_issuing_bank>Issuing Bank</card_issuing_bank>
<card_issuing_country>Exact Issuing country</card_issuing_country>
<bank_account_number>Bank Account Number</bank_account_number>
<bank_identifier_code>Bank Identifier Code</bank_identifier_code>
<sent_to_acquirer>true</sent_to_acquirer>
<arn>74537605259536043849425</arn>
<scheme_response_code>00</scheme_response_code>
<scheme_transaction_link_id>TLINKIDENTIFIER4521412</scheme_transaction_link_id>
<scheme_max_settlement_date>2024-07-31</scheme_max_settlement_date>
<scheme_authentication_data_quality>true</scheme_authentication_data_quality>
<threeds>
<authentication_flow>frictionless</authentication_flow>
<protocol>
<target_version>2</target_version>
<concrete_version>2</concrete_version>
<sub_version>2</sub_version>
</protocol>
<eci>05</eci>
</threeds>
</payment_response>
Successful Reconcile Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
moto | 'true' | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech support for more details. |
avs_response_code | string(255) | Generated by the card network on trying to match the billing address when performing the address verification. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
avs_response_text | string(255) | Gives the human response text for the AVS response code above. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
cvv_result_code | string(1) | Card Verification Value response code. Optional, returned only if acquirer supports it |
authorization_code | string(6) | Generated by the card network when an authorisation has occurred, used to identify that auth. Consists of 6 alphanumeric chars |
retrieval_reference_number | string(255) | A reference number used for tracking all messages related to a given cardholder transaction returned by some acquirers. |
response_code | string(2) | Defines the result of a transaction with the acquirer, the status of a message or some action taken or required. Contact tech-support@emerchantpay.com for more details. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
partial_approval | string(4) | Optional, set to ’true’ if partial approval happened. Partially approved amount is then in the amount field. Check Partial Approvals for details |
sent_to_acquirer | string(255) | "true" or "false" |
threeds | ||
authentication_flow | string(255) | Identifies the concrete authentication flow of the 3DS transaction that it has gone through. It will be included only if the transaction reaches the final state. The possible values for 3DSv2 are frictionless, challenge. |
protocol | ||
target_version | integer | Identifies the requested version of the 3DS authentication protocol to be used. The possible values are 2. |
concrete_version | integer | Identifies the concrete version of the 3DS authentication protocol that the transaction has been processed through. The possible values are 2. |
eci | string(2) | See Electronic Commerce Indicator for details |
Notification
Once the transaction reaches final state, a notification will be sent to the notification_url
submitted in the
initial transaction request. For more information, go to Asynchronous Transactions and Notifications.
Approved Notification Example for frictionless flow
?transaction_id=119643250547501c79d8295
&unique_id=44177a21403427eb96664a6d7e5d5d48
&transaction_type=sale3d
&terminal_token=394f2ebc3646d3c017fa1e1cbc4a1e20
&status=approved
&amount=100
&signature=088e16a1019277b15d58faf0541e11910eb756f6
&eci=05
&avs_response_code=5I
&avs_response_text=Response+provided+by+issuer+processor%3B+Address+information+not+verified
&cvv_result_code=M
&authorization_code=005645
&retrieval_reference_number=016813015184
&payment_account_reference=50019P9LBXOLHN9G7QMU5VN520YSY
&scheme_transaction_link_id=TLINKIDENTIFIER4521412
&scheme_pan_indicator=V
&scheme_pan_tail=0013
&scheme_max_settlement_date=2024-07-31
&scheme_authentication_data_quality=true
&threeds_authentication_flow=frictionless
&threeds_target_protocol_version=2
&threeds_concrete_protocol_version=2
&threeds_protocol_sub_version=2
Declined Notification Example for frictionless flow
?transaction_id=119643250547501c79d8295
&unique_id=44177a21403427eb96664a6d7e5d5d48
&transaction_type=sale3d
&terminal_token=394f2ebc3646d3c017fa1e1cbc4a1e20
&status=declined
&amount=100
&signature=088e16a1019277b15d58faf0541e11910eb756f6
&eci=05
&avs_response_code=5I
&avs_response_text=Response+provided+by+issuer+processor%3B+Address+information+not+verified
&cvv_result_code=M
&authorization_code=005645
&retrieval_reference_number=016813015184
&payment_account_reference=50019P9LBXOLHN9G7QMU5VN520YSY
&scheme_transaction_link_id=TLINKIDENTIFIER4521412
&scheme_pan_indicator=V
&scheme_pan_tail=0013
&scheme_max_settlement_date=2024-07-31
&scheme_authentication_data_quality=true
&threeds_authentication_flow=frictionless
&threeds_target_protocol_version=2
&threeds_concrete_protocol_version=2
&threeds_protocol_sub_version=2
3DS Attributes
Name | Type | Description |
---|---|---|
threeds_authentication_flow | string | Identifies the concrete 3DS authentication flow that the transaction has gone through. It will be available in the notification only if the consumer has finished the 3DS authentication with the issuer. The available values for 3DSv2 are frictionless and challenge. |
threeds_method_status | string | Identifies the status of the 3DS-Method in the scope of 3DSv2 authentication protocol. The possible values are required, in_progress and completed. |
threeds_target_protocol_version | string(1) | Identifies the 3DS protocol that has been enforced. The possible values are 2. |
threeds_concrete_protocol_version | string(1) | Identifies the concrete 3DS protocol version that the transaction has gone through. The possible values are 2. |
threeds_protocol_sub_version | string(1) | Identifies the 3DS protocol sub-version that the transaction has gone through. The possible values are 1, 2, 3, 4, 5, 6, 7, 8, 9. |
threeds_authentication_status_reason_code | string(2) | See Status Reason Code for details. |
Frictionless with 3DSecure Method
A Frictionless Flow occurs when the Issuer authenticates the cardholder without cardholder involvement by evaluating the transaction's risk level.
The customer has more frictionless experience through the merchant’s platform by not being challenged. That means the drop-off rate due to the 3DSecure protocol will be drastically reduced and the customer will happily come back to the merchant’s platform.
The Frictionless Flow does not require further Cardholder interaction to achieve a successful authentication and complete the 3DSecure authentication process. The payment will be completely synchronous, the consumer won't be redirected to the Access Control Server to complete the authentication.
This flow is treated frictionless (without consumer interaction with the issuer), but with the only difference that the ACS requires a 3DSecure Method to be submitted before continuing.
Thanks to risk-based authentication performed in the ACS, frictionless flow allows issuers to approve a transaction without the need to interact with the consumer.
When the customer makes an online purchase they would add an item to their shopping cart, fill out the normal purchase information and then proceed to confirm the purchase.
Details of the purchase including device data, item purchased and value are submitted to the ACS server to determine the authenticity of the cardholder.
The ACS will then screen it with the risk-based elements. If the risk is deemed to be low, the ACS can authenticate the customer passively and not bother them with the extra confirmation.
This is a frictionless process for the customer as it happens behind the scenes. They are directed straight to the purchase confirmation screen, without even knowing that their transaction was screened.
Asynchronous 3DS Method submission
A link between the customer's browser and the card issuer must be opened with a hidden iframe.
It is used for the card issuer to load JavaScript which gathers device information to be returned to the card issuer.
The next step after initiating the iframe, is to submit an API call to the threeds_method_continue_url
using HTTP PUT,
to retrieve the next step in the authentication. The API request won't require HTTP basic authentication,
but a proper signature needs to be included to prove the authenticity of the request.
The response of this API call will be the same as the normal 3D transaction processing API response, but with the only difference
that an additional interaction with the issuer might be requested.
The asynchronous submission of the 3DS-Method might look difficult to achieve, but mitigates the risk of potential transaction processing interruptions, because the consumer redirection does not depend on a successful 3DS-Method submission. A continuation of the 3DS-Method might be requested regardless of the 3DS-Method submission result. It's a responsibility of the ACS then to take the appropriate decision how to continue with the authentication.
In order to simulate this authentication flow, use а test card 4066330000000004 for frictionless flow that requires 3DS-Method and
submit a 3DSv2 transaction in asynchronous workflow by including the threeds_v2_params
.
The response of the API will indicate that further action is required:
status
- pending_asyncthreeds_method_url
- the URL action where the 3DS-Method needs to be submitted using HTTP POSTthreeds_method_continue_url
- API endpoint that accepts HTTP PUT requests with a signature and returns transaction API response identifying what the next step is (transaction completed or consumer interaction is needed)
In order to submit a 3DS-Method, you need to create a hidden iframe in the consumer browser (client side) with an html
and body
tags as described below,
on the right side and create a hidden HTML form that:
- targets the iframe
- uses HTTP METHOD POST -
method="post"
- has an action equivalent to the value of
threeds_method_url
, received from the response of the initial transaction request - has 2 hidden inputs
unique_id
- equivalent to the value of theunique_id
, received from the response of the initial transaction requestsignature
- SHA512 of а concatenated string (unique_id, amount, timestamp, merchant_api_password), where unique_id, amount, timestamp can be taken from the response of the initial transaction request and merchant_api_password is the password used for HTTP Basic authentication to the API during the initial transaction request
- submit the HTML form in the background using JavaScript
Once the 3DS-Method submission is initiated, a callback via HTTP POST will be done inside the iframe
when the 3DS-Method reaches the final state. The 3DS-Method callback will be sent to the callback_url
(submitted in the 3DSv2 request params as described in the diagram below) and will be constructed as described below:
- with request headers
Content-Type
- application/x-www-form-urlencoded
- with POST request params
unique_id
- the exact unique_id of the transaction in the initial transaction requestthreeds_method_status
- the status of the 3DS-Method submission, expect a value of completedsignature
- SHA512 of a concatenated string with the values of unique_id, threeds_method_status, and merchant_api_password where unique_id and threeds_method_status are POST params and merchant_api_password is the password used for HTTP HTTP Basic authentication to the API during the initial transaction request
The callback above can be handled (optional) in order to get informed of the 3DS-Method status, whether it has completed or not.
Right after submitting the 3DS-Method (without waiting for the 3DS-Method completion), submit a 3DS-Method continue API call to determine what the next step that is required (as described in the diagram below):
- no further action - payment successful / failed
- consumer <--> Issuer interaction needed
In order to submit the 3DS-Method continue call, please make sure to follow the steps, as described below in the diagram:
Submit an API call using HTTP METHOD PUT to the URL returned in threeds_method_continue_url
during the initial transaction request:
- with request headers
Content-Type
- application/x-www-form-urlencoded
- with request params
signature
- the same signature used for submitting the 3DS-Method
The response of the API call will be transaction response XML indicating what is expected:
- no action, the
status
will be in final state (authentication completed without friction and authorization has been performed) - consumer redirection, the
status
will be pending_async (consumer interaction with the the issuer needed to complete the authentication)
Asynchronous 3 D Sv2 Frictionless With 3 Ds Method Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Authorize3D');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('4066330000000004')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
->setNotificationUrl('https://www.example.com/notification')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
// Threeds V2 Params
->setThreedsThreedsMethod('{"callback_url"=>"https://www.example.com/threeds/threeds_method/callback"}')
->setThreedsControl('{"device_type"=>"browser", "challenge_window_size"=>"full_screen", "challenge_indicator"=>"preference"}')
->setThreedsPurchase('{"category"=>"service"}')
->setThreedsRecurring('{"expiration_date"=>"17-07-2025", "frequency"=>30}')
->setThreedsMerchantRisk('{"shipping_indicator"=>"verified_address", "delivery_timeframe"=>"electronic", "reorder_items_indicator"=>"reordered", "pre_order_purchase_indicator"=>"merchandise_available", "pre_order_date"=>"17-02-2025", "gift_card"=>"true", "gift_card_count"=>"2"}')
->setThreedsCardHolderAccount('{"creation_date"=>"17-01-2024", "update_indicator"=>"more_than_60days", "last_change_date"=>"17-10-2024", "password_change_indicator"=>"no_change", "password_change_date"=>"02-01-2025", "shipping_address_usage_indicator"=>"current_transaction", "shipping_address_date_first_used"=>"12-01-2025", "transactions_activity_last_24_hours"=>"2", "transactions_activity_previous_year"=>"10", "provision_attempts_last_24_hours"=>"1", "purchases_count_last_6_months"=>"5", "suspicious_activity_indicator"=>"no_suspicious_observed", "registration_indicator"=>"30_to_60_days", "registration_date"=>"17-01-2023"}')
->setThreedsBrowser('{"accept_header"=>"*/*", "java_enabled"=>"false", "language"=>"en-GB", "color_depth"=>"24", "screen_height"=>"900", "screen_width"=>"1440", "time_zone_offset"=>"-120", "user_agent"=>"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"}')
->setThreedsSdk('{"interface"=>"native", "ui_types"=>{"ui_type"=>"multi_select"}, "application_id"=>"fc1650c0-5778-0138-8205-2cbc32a32d65", "encrypted_data"=>"encrypted-data-here", "ephemeral_public_key_pair"=>"public-key-pair", "max_timeout"=>"10", "reference_number"=>"sdk-reference-number-here"}')
// Sca Params
->setScaExemption('low_risk');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.Authorize3DRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
Authorize3DRequest request = new Authorize3DRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4066330000000004");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
request.setNotificationUrl(new URL("https://www.example.com/notification"));
request.setReturnSuccessUrl(new URL("http://www.example.com/success"));
request.setReturnFailureUrl(new URL("http://www.example.com/failure"));
// Threeds V2 Params
request.setThreedsThreedsMethod("{"callback_url"=>"https://www.example.com/threeds/threeds_method/callback"}");
request.setThreedsControl("{"device_type"=>"browser", "challenge_window_size"=>"full_screen", "challenge_indicator"=>"preference"}");
request.setThreedsPurchase("{"category"=>"service"}");
request.setThreedsRecurring("{"expiration_date"=>"17-07-2025", "frequency"=>30}");
request.setThreedsMerchantRisk("{"shipping_indicator"=>"verified_address", "delivery_timeframe"=>"electronic", "reorder_items_indicator"=>"reordered", "pre_order_purchase_indicator"=>"merchandise_available", "pre_order_date"=>"17-02-2025", "gift_card"=>"true", "gift_card_count"=>"2"}");
request.setThreedsCardHolderAccount("{"creation_date"=>"17-01-2024", "update_indicator"=>"more_than_60days", "last_change_date"=>"17-10-2024", "password_change_indicator"=>"no_change", "password_change_date"=>"02-01-2025", "shipping_address_usage_indicator"=>"current_transaction", "shipping_address_date_first_used"=>"12-01-2025", "transactions_activity_last_24_hours"=>"2", "transactions_activity_previous_year"=>"10", "provision_attempts_last_24_hours"=>"1", "purchases_count_last_6_months"=>"5", "suspicious_activity_indicator"=>"no_suspicious_observed", "registration_indicator"=>"30_to_60_days", "registration_date"=>"17-01-2023"}");
request.setThreedsBrowser("{"accept_header"=>"*/*", "java_enabled"=>"false", "language"=>"en-GB", "color_depth"=>"24", "screen_height"=>"900", "screen_width"=>"1440", "time_zone_offset"=>"-120", "user_agent"=>"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"}");
request.setThreedsSdk("{"interface"=>"native", "ui_types"=>{"ui_type"=>"multi_select"}, "application_id"=>"fc1650c0-5778-0138-8205-2cbc32a32d65", "encrypted_data"=>"encrypted-data-here", "ephemeral_public_key_pair"=>"public-key-pair", "max_timeout"=>"10", "reference_number"=>"sdk-reference-number-here"}");
// Sca Params
request.setScaExemption("low_risk");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.authorize3d(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": 100,
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "4066330000000004",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"notification_url": "https://www.example.com/notification",
"return_success_url": "http://www.example.com/success",
"return_failure_url": "http://www.example.com/failure",
"threeds_v2_params": {
"threeds_method": {
"callback_url": "https://www.example.com/threeds/threeds_method/callback"
},
"control": {
"device_type": "browser",
"challenge_window_size": "full_screen",
"challenge_indicator": "preference"
},
"purchase": {
"category": "service"
},
"recurring": {
"expiration_date": "17-07-2025",
"frequency": 30
},
"merchant_risk": {
"shipping_indicator": "verified_address",
"delivery_timeframe": "electronic",
"reorder_items_indicator": "reordered",
"pre_order_purchase_indicator": "merchandise_available",
"pre_order_date": "17-02-2025",
"gift_card": "true",
"gift_card_count": "2"
},
"card_holder_account": {
"creation_date": "17-01-2024",
"update_indicator": "more_than_60days",
"last_change_date": "17-10-2024",
"password_change_indicator": "no_change",
"password_change_date": "02-01-2025",
"shipping_address_usage_indicator": "current_transaction",
"shipping_address_date_first_used": "12-01-2025",
"transactions_activity_last_24_hours": "2",
"transactions_activity_previous_year": "10",
"provision_attempts_last_24_hours": "1",
"purchases_count_last_6_months": "5",
"suspicious_activity_indicator": "no_suspicious_observed",
"registration_indicator": "30_to_60_days",
"registration_date": "17-01-2023"
},
"browser": {
"accept_header": "*/*",
"java_enabled": "false",
"language": "en-GB",
"color_depth": "24",
"screen_height": "900",
"screen_width": "1440",
"time_zone_offset": "-120",
"user_agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"
},
"sdk": {
"interface": "native",
"ui_types": {
"ui_type": "multi_select"
},
"application_id": "fc1650c0-5778-0138-8205-2cbc32a32d65",
"encrypted_data": "encrypted-data-here",
"ephemeral_public_key_pair": "public-key-pair",
"max_timeout": "10",
"reference_number": "sdk-reference-number-here"
}
},
"sca_params": {
"exemption": "low_risk"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>authorize3d</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4066330000000004</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<notification_url>https://www.example.com/notification</notification_url>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<threeds_v2_params>
<threeds_method>
<callback_url>https://www.example.com/threeds/threeds_method/callback</callback_url>
</threeds_method>
<control>
<device_type>browser</device_type>
<challenge_window_size>full_screen</challenge_window_size>
<challenge_indicator>preference</challenge_indicator>
</control>
<purchase>
<category>service</category>
</purchase>
<merchant_risk>
<shipping_indicator>verified_address</shipping_indicator>
<delivery_timeframe>electronic</delivery_timeframe>
<reorder_items_indicator>reordered</reorder_items_indicator>
<pre_order_purchase_indicator>merchandise_available</pre_order_purchase_indicator>
<pre_order_date>17-02-2025</pre_order_date>
<gift_card>true</gift_card>
<gift_card_count>2</gift_card_count>
</merchant_risk>
<card_holder_account>
<creation_date>17-01-2024</creation_date>
<update_indicator>more_than_60days</update_indicator>
<last_change_date>17-10-2024</last_change_date>
<password_change_indicator>no_change</password_change_indicator>
<password_change_date>02-01-2025</password_change_date>
<shipping_address_usage_indicator>current_transaction</shipping_address_usage_indicator>
<shipping_address_date_first_used>12-01-2025</shipping_address_date_first_used>
<transactions_activity_last_24_hours>2</transactions_activity_last_24_hours>
<transactions_activity_previous_year>10</transactions_activity_previous_year>
<provision_attempts_last_24_hours>1</provision_attempts_last_24_hours>
<purchases_count_last_6_months>5</purchases_count_last_6_months>
<suspicious_activity_indicator>no_suspicious_observed</suspicious_activity_indicator>
<registration_indicator>30_to_60_days</registration_indicator>
<registration_date>17-01-2023</registration_date>
</card_holder_account>
<browser>
<accept_header>*/*</accept_header>
<java_enabled>false</java_enabled>
<language>en-GB</language>
<color_depth>24</color_depth>
<screen_height>900</screen_height>
<screen_width>1440</screen_width>
<time_zone_offset>-120</time_zone_offset>
<user_agent>Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36</user_agent>
</browser>
<sdk>
<interface>native</interface>
<ui_types>
<ui_type>multi_select</ui_type>
</ui_types>
<application_id>fc1650c0-5778-0138-8205-2cbc32a32d65</application_id>
<encrypted_data>encrypted-data-here</encrypted_data>
<ephemeral_public_key_pair>public-key-pair</ephemeral_public_key_pair>
<max_timeout>10</max_timeout>
<reference_number>sdk-reference-number-here</reference_number>
</sdk>
</threeds_v2_params>
<sca_params>
<exemption>low_risk</exemption>
</sca_params>
</payment_transaction>'
Frictionless With 3 Ds Mеthod Response
stdClass Object
(
[transaction_type] => authorize3d
[status] => pending_async
[mode] => test
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[threeds_method_url] => https://staging.gate.emerchantpay.net/threeds/threeds_method
[threeds_method_continue_url] => https://staging.gate.emerchantpay.net/threeds/threeds_method/44177a21403427eb96664a6d7e5d5d48
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:24:03.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => false
)
<payment_response content=[
<transaction_type content=[authorize3d]>
<status content=[pending_async]>
<mode content=[test]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<threeds_method_url content=[https://staging.gate.emerchantpay.net/threeds/threeds_method]>
<threeds_method_continue_url content=[https://staging.gate.emerchantpay.net/threeds/threeds_method/44177a21403427eb96664a6d7e5d5d48]>
<timestamp content=[2025-01-16T10:24:03Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[false]>
]>
{
transaction_type: "authorize3d",
status: "pending_async",
mode: "test",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
threeds_method_url: "https://staging.gate.emerchantpay.net/threeds/threeds_method",
threeds_method_continue_url: "https://staging.gate.emerchantpay.net/threeds/threeds_method/44177a21403427eb96664a6d7e5d5d48",
timestamp: "2025-01-16T10:24:03Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "false",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>authorize3d</transaction_type>
<status>pending_async</status>
<mode>test</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<threeds_method_url>https://staging.gate.emerchantpay.net/threeds/threeds_method</threeds_method_url>
<threeds_method_continue_url>https://staging.gate.emerchantpay.net/threeds/threeds_method/44177a21403427eb96664a6d7e5d5d48</threeds_method_continue_url>
<timestamp>2025-01-16T10:24:03Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
<!-- Sample HTML for the 3DS-Method submission in an iframe -->
<html>
<head>
</head>
<body onload="submitThreedsMethod()">
<iframe width="..." height="..." id="threeDSMethodIframe" name="threeDSMethodIframe">
<html>
<body>
</body>
</html>
</iframe>
<form id ="threeDSMethodForm" name="threeDSMethodForm"
enctype="application/x-www-form-urlencoded;charset=UTF-8"
style="display: none"
method="post"
action="https://staging.gate.emerchantpay.net/threeds/threeds_method"
target="threeDSMethodIframe">
<input type="hidden" name="unique_id" value="44177a21403427eb96664a6d7e5d5d48" />
<!-- The signature is built as per the above notes for merchant with API password a54a1e349b9784bb01126fdefc244b3ede19e84d -->
<input type="hidden" name="signature" value="3d4155e7be1832c6eb8902131a1f17443c0c36ca339bae1084a6d2bf70c0ac041b30079b68e4d3bf371133a928db8383b7ccbcf2f70b4d4aa5a8fadc9bd7ea45" />
</form>
</body>
<script>
function submitThreedsMethod() {
threeDSMethodForm = document.getElementById('threeDSMethodForm');
threeDSMethodForm.submit();
}
</script>
</html>
<!-- 3DS-Method Callback inside the iframe indicating the 3DS-Method completed -->
<!-- Content-Type: application/x-www-form-urlencoded -->
<!-- The signature is built as per the above notes for merchant with API password a54a1e349b9784bb01126fdefc244b3ede19e84d -->
POST https://www.example.com/threeds/threeds_method/callback
unique_id=44177a21403427eb96664a6d7e5d5d48
&threeds_method_status=completed
&signature=86bb547ba3daf8b7970d2e185404426a4c9790282a4612e21ef59dfc591a5fa227f88225571049e2242099effc19f53529433a2bd240a712d7e9ff4c8c4c65e8
<!-- 3DS-Method continue API call -->
<!-- Content-Type: application/x-www-form-urlencoded -->
<!-- The signature is built as per the above notes for merchant with API password a54a1e349b9784bb01126fdefc244b3ede19e84d -->
curl https://staging.gate.emerchantpay.net/threeds/threeds_method/44177a21403427eb96664a6d7e5d5d48 \
-X PUT \
-H "Content-Type: application/x-www-form-urlencoded" \
-d signature=3d4155e7be1832c6eb8902131a1f17443c0c36ca339bae1084a6d2bf70c0ac041b30079b68e4d3bf371133a928db8383b7ccbcf2f70b4d4aa5a8fadc9bd7ea45
3 Ds Method Continue Successful Response
stdClass Object
(
[transaction_type] => authorize3d
[status] => approved
[mode] => test
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:24:03.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => true
[scheme_transaction_identifier] => 019091214161031
[scheme_settlement_date] => 0117
[threeds] => {"eci"=>"05"}
)
<payment_response content=[
<transaction_type content=[authorize3d]>
<status content=[approved]>
<mode content=[test]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<timestamp content=[2025-01-16T10:24:03Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[true]>
<scheme_transaction_identifier content=[019091214161031]>
<scheme_settlement_date content=[0117]>
<threeds content=[{"eci"=>"05"}]>
]>
{
transaction_type: "authorize3d",
status: "approved",
mode: "test",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
timestamp: "2025-01-16T10:24:03Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "true",
scheme_transaction_identifier: "019091214161031",
scheme_settlement_date: "0117",
threeds: "{"eci"=>"05"}",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>authorize3d</transaction_type>
<status>approved</status>
<mode>test</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<timestamp>2025-01-16T10:24:03Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>true</sent_to_acquirer>
<scheme_transaction_identifier>019091214161031</scheme_transaction_identifier>
<scheme_settlement_date>0117</scheme_settlement_date>
<threeds>
<eci>05</eci>
</threeds>
</payment_response>
3 Ds Method Continue Declined Response
stdClass Object
(
[transaction_type] => authorize3d
[status] => declined
[crypto] => true
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[transaction_id] => 119643250547501c79d8295
[consumer_id] => 123456
[token] => ee946db8-d7db-4bb7-b608-b65b153e127d
[code] => 910
[technical_message] => Do not honour
[message] => Transaction declined, please contact support!
[mode] => test
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:24:03.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[threeds] => {"authentication"=>{"status_reason_code"=>"01"}, "eci"=>"07"}
[sent_to_acquirer] => false
)
<payment_response content=[
<transaction_type content=[authorize3d]>
<status content=[declined]>
<crypto content=[true]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<transaction_id content=[119643250547501c79d8295]>
<consumer_id content=[123456]>
<token content=[ee946db8-d7db-4bb7-b608-b65b153e127d]>
<code content=[910]>
<technical_message content=[Do not honour]>
<message content=[Transaction declined, please contact support!]>
<mode content=[test]>
<timestamp content=[2025-01-16T10:24:03Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<threeds content=[{"authentication"=>{"status_reason_code"=>"01"}, "eci"=>"07"}]>
<sent_to_acquirer content=[false]>
]>
{
transaction_type: "authorize3d",
status: "declined",
crypto: "true",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
transaction_id: "119643250547501c79d8295",
consumer_id: "123456",
token: "ee946db8-d7db-4bb7-b608-b65b153e127d",
code: "910",
technical_message: "Do not honour",
message: "Transaction declined, please contact support!",
mode: "test",
timestamp: "2025-01-16T10:24:03Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
threeds: "{"authentication"=>{"status_reason_code"=>"01"}, "eci"=>"07"}",
sent_to_acquirer: "false",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>authorize3d</transaction_type>
<status>declined</status>
<crypto>true</crypto>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<transaction_id>119643250547501c79d8295</transaction_id>
<consumer_id>123456</consumer_id>
<token>ee946db8-d7db-4bb7-b608-b65b153e127d</token>
<code>910</code>
<technical_message>Do not honour</technical_message>
<message>Transaction declined, please contact support!</message>
<mode>test</mode>
<timestamp>2025-01-16T10:24:03Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<threeds>
<authentication>
<status_reason_code>01</status_reason_code>
</authentication>
<eci>07</eci>
</threeds>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
A completion response will be returned by the API providing the status of the transaction.
It might also be approved
, declined
or error
depending on the authentication status and the authorization response.
Diagram
Reconcile
Once the transaction reaches the final state, a single reconcile can also be performed to retrieve more detailed information about the 3D transaction. It should include information about the 3DS transaction as described in the reconcile request/response below, on the right.
Reconcile 3 D Transaction By Unique Id Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('NonFinancial\Reconcile\Transaction');
$request = $genesis->request();
$request
->setUniqueId('44177a21403427eb96664a6d7e5d5d48');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.nonfinancial.reconcile.ReconcileRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
ReconcileRequest request = new ReconcileRequest();
request.setUniqueId("44177a21403427eb96664a6d7e5d5d48");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.reconcile(
{
"unique_id": "44177a21403427eb96664a6d7e5d5d48"
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/reconcile/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<reconcile>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
</reconcile>'
Successful Reconciliation Of Frictionless 3 D Sv2 Transaction With 3 Ds Method Response
stdClass Object
(
[transaction_type] => authorize3d
[status] => approved
[authorization_code] => 005645
[retrieval_reference_number] => 016813015184
[payment_account_reference] => Q1HJZ28RKA1EBL470G9XYG90R5D3E
[response_code] => 00
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[transaction_id] => 119643250547501c79d8295
[mode] => test
[timestamp] => 2025-01-16T10:24:03Z
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[card_brand] => visa
[card_number] => 406633...0004
[card_type] => CREDIT
[card_subtype] => CARD SUBTYPE
[card_issuing_bank] => Issuing Bank
[card_issuing_country] => Exact Issuing country
[bank_account_number] => Bank Account Number
[bank_identifier_code] => Bank Identifier Code
[sent_to_acquirer] => true
[arn] => 74537605259536043849425
[scheme_response_code] => 00
[scheme_transaction_link_id] => TLINKIDENTIFIER4521412
[scheme_max_settlement_date] => 2024-07-31
[scheme_authentication_data_quality] => true
[threeds] => {:authentication_flow=>"frictionless", :threeds_method=>{:status=>"completed"}, :protocol=>{:target_version=>"2", :concrete_version=>"2", :sub_version=>"2"}, :eci=>"05"}
[threeds] => {:authentication_flow=>"frictionless", :threeds_method=>{:status=>"completed"}, :protocol=>{:target_version=>"2", :concrete_version=>"2", :sub_version=>"2"}, :eci=>"05"}
)
<payment_response content=[
<transaction_type content=[authorize3d]>
<status content=[approved]>
<authorization_code content=[005645]>
<retrieval_reference_number content=[016813015184]>
<payment_account_reference content=[Q1HJZ28RKA1EBL470G9XYG90R5D3E]>
<response_code content=[00]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<transaction_id content=[119643250547501c79d8295]>
<mode content=[test]>
<timestamp content=[2025-01-16T10:24:03Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<card_brand content=[visa]>
<card_number content=[406633...0004]>
<card_type content=[CREDIT]>
<card_subtype content=[CARD SUBTYPE]>
<card_issuing_bank content=[Issuing Bank]>
<card_issuing_country content=[Exact Issuing country]>
<bank_account_number content=[Bank Account Number]>
<bank_identifier_code content=[Bank Identifier Code]>
<sent_to_acquirer content=[true]>
<arn content=[74537605259536043849425]>
<scheme_response_code content=[00]>
<scheme_transaction_link_id content=[TLINKIDENTIFIER4521412]>
<scheme_max_settlement_date content=[2024-07-31]>
<scheme_authentication_data_quality content=[true]>
<threeds content=[{:authentication_flow=>"frictionless", :threeds_method=>{:status=>"completed"}, :protocol=>{:target_version=>"2", :concrete_version=>"2", :sub_version=>"2"}, :eci=>"05"}]>
<threeds content=[{:authentication_flow=>"frictionless", :threeds_method=>{:status=>"completed"}, :protocol=>{:target_version=>"2", :concrete_version=>"2", :sub_version=>"2"}, :eci=>"05"}]>
]>
{
transaction_type: "authorize3d",
status: "approved",
authorization_code: "005645",
retrieval_reference_number: "016813015184",
payment_account_reference: "Q1HJZ28RKA1EBL470G9XYG90R5D3E",
response_code: "00",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
transaction_id: "119643250547501c79d8295",
mode: "test",
timestamp: "2025-01-16T10:24:03Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
card_brand: "visa",
card_number: "406633...0004",
card_type: "CREDIT",
card_subtype: "CARD SUBTYPE",
card_issuing_bank: "Issuing Bank",
card_issuing_country: "Exact Issuing country",
bank_account_number: "Bank Account Number",
bank_identifier_code: "Bank Identifier Code",
sent_to_acquirer: "true",
arn: "74537605259536043849425",
scheme_response_code: "00",
scheme_transaction_link_id: "TLINKIDENTIFIER4521412",
scheme_max_settlement_date: "2024-07-31",
scheme_authentication_data_quality: "true",
threeds: "{:authentication_flow=>"frictionless", :threeds_method=>{:status=>"completed"}, :protocol=>{:target_version=>"2", :concrete_version=>"2", :sub_version=>"2"}, :eci=>"05"}",
threeds: "{:authentication_flow=>"frictionless", :threeds_method=>{:status=>"completed"}, :protocol=>{:target_version=>"2", :concrete_version=>"2", :sub_version=>"2"}, :eci=>"05"}",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>authorize3d</transaction_type>
<status>approved</status>
<authorization_code>005645</authorization_code>
<retrieval_reference_number>016813015184</retrieval_reference_number>
<payment_account_reference>Q1HJZ28RKA1EBL470G9XYG90R5D3E</payment_account_reference>
<response_code>00</response_code>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<transaction_id>119643250547501c79d8295</transaction_id>
<mode>test</mode>
<timestamp>2025-01-16T10:24:03Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<card_brand>visa</card_brand>
<card_number>406633...0004</card_number>
<card_type>CREDIT</card_type>
<card_subtype>CARD SUBTYPE</card_subtype>
<card_issuing_bank>Issuing Bank</card_issuing_bank>
<card_issuing_country>Exact Issuing country</card_issuing_country>
<bank_account_number>Bank Account Number</bank_account_number>
<bank_identifier_code>Bank Identifier Code</bank_identifier_code>
<sent_to_acquirer>true</sent_to_acquirer>
<arn>74537605259536043849425</arn>
<scheme_response_code>00</scheme_response_code>
<scheme_transaction_link_id>TLINKIDENTIFIER4521412</scheme_transaction_link_id>
<scheme_max_settlement_date>2024-07-31</scheme_max_settlement_date>
<scheme_authentication_data_quality>true</scheme_authentication_data_quality>
<threeds>
<authentication_flow>frictionless</authentication_flow>
<threeds_method>
<status>completed</status>
</threeds_method>
<protocol>
<target_version>2</target_version>
<concrete_version>2</concrete_version>
<sub_version>2</sub_version>
</protocol>
<eci>05</eci>
</threeds>
</payment_response>
Successful Reconcile Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
moto | 'true' | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech support for more details. |
avs_response_code | string(255) | Generated by the card network on trying to match the billing address when performing the address verification. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
avs_response_text | string(255) | Gives the human response text for the AVS response code above. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
cvv_result_code | string(1) | Card Verification Value response code. Optional, returned only if acquirer supports it |
authorization_code | string(6) | Generated by the card network when an authorisation has occurred, used to identify that auth. Consists of 6 alphanumeric chars |
retrieval_reference_number | string(255) | A reference number used for tracking all messages related to a given cardholder transaction returned by some acquirers. |
response_code | string(2) | Defines the result of a transaction with the acquirer, the status of a message or some action taken or required. Contact tech-support@emerchantpay.com for more details. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
partial_approval | string(4) | Optional, set to ’true’ if partial approval happened. Partially approved amount is then in the amount field. Check Partial Approvals for details |
sent_to_acquirer | string(255) | "true" or "false" |
threeds | ||
authentication_flow | string(255) | Identifies the concrete authentication flow of the 3DS transaction that it has gone through. It will be included only if the transaction reaches the final state. The possible values for 3DSv2 are frictionless, challenge. |
threeds_method | ||
status | string(255) | Identifies the current status of 3DSv2-Method. The possible values are required, in_progress, completed. |
protocol | ||
target_version | integer | Identifies the requested version of the 3DS authentication protocol to be used. The possible values are 2. |
concrete_version | integer | Identifies the concrete version of the 3DS authentication protocol that the transaction has been processed through. The possible values are 2. |
eci | string(2) | See Electronic Commerce Indicator for details |
Notification
Once the transaction reaches final state, a notification will be sent to the notification_url
submitted in the
initial transaction request. For more information, go to Asynchronous Transactions and Notifications.
Approved Notification Example for frictionless flow with 3DS-Method
?transaction_id=119643250547501c79d8295
&unique_id=44177a21403427eb96664a6d7e5d5d48
&transaction_type=authorize3d
&terminal_token=394f2ebc3646d3c017fa1e1cbc4a1e20
&status=approved
&amount=100
&signature=088e16a1019277b15d58faf0541e11910eb756f6
&eci=05
&avs_response_code=5I
&avs_response_text=Response+provided+by+issuer+processor%3B+Address+information+not+verified
&cvv_result_code=M
&authorization_code=005645
&retrieval_reference_number=016813015184
&payment_account_reference=50019P9LBXOLHN9G7QMU5VN520YSY
&scheme_transaction_link_id=TLINKIDENTIFIER4521412
&scheme_pan_indicator=V
&scheme_pan_tail=0013
&scheme_max_settlement_date=2024-07-31
&scheme_authentication_data_quality=true
&threeds_authentication_flow=frictionless
&threeds_method_status=completed
&threeds_target_protocol_version=2
&threeds_concrete_protocol_version=2
&threeds_protocol_sub_version=2
Declined Notification Example for frictionless flow with 3DS-Method
?transaction_id=119643250547501c79d8295
&unique_id=44177a21403427eb96664a6d7e5d5d48
&transaction_type=authorize3d
&terminal_token=394f2ebc3646d3c017fa1e1cbc4a1e20
&status=declined
&amount=100
&signature=088e16a1019277b15d58faf0541e11910eb756f6
&eci=05
&avs_response_code=5I
&avs_response_text=Response+provided+by+issuer+processor%3B+Address+information+not+verified
&cvv_result_code=M
&authorization_code=005645
&retrieval_reference_number=016813015184
&payment_account_reference=50019P9LBXOLHN9G7QMU5VN520YSY
&scheme_transaction_link_id=TLINKIDENTIFIER4521412
&scheme_pan_indicator=V
&scheme_pan_tail=0013
&scheme_max_settlement_date=2024-07-31
&scheme_authentication_data_quality=true
&threeds_authentication_flow=frictionless
&threeds_method_status=completed
&threeds_target_protocol_version=2
&threeds_concrete_protocol_version=2
&threeds_protocol_sub_version=2
3DS Attributes
Name | Type | Description |
---|---|---|
threeds_authentication_flow | string | Identifies the concrete 3DS authentication flow that the transaction has gone through. It will be available in the notification only if the consumer has finished the 3DS authentication with the issuer. The available values for 3DSv2 are frictionless and challenge. |
threeds_method_status | string | Identifies the status of the 3DS-Method in the scope of 3DSv2 authentication protocol. The possible values are required, in_progress and completed. |
threeds_target_protocol_version | string(1) | Identifies the 3DS protocol that has been enforced. The possible values are 2. |
threeds_concrete_protocol_version | string(1) | Identifies the concrete 3DS protocol version that the transaction has gone through. The possible values are 2. |
threeds_protocol_sub_version | string(1) | Identifies the 3DS protocol sub-version that the transaction has gone through. The possible values are 1, 2, 3, 4, 5, 6, 7, 8, 9. |
threeds_authentication_status_reason_code | string(2) | See Status Reason Code for details. |
Challenge
If the ACS determines that further Cardholder interaction is required to complete the authentication, the Frictionless Flow transitions into the Challenge Flow. For example, a challenge may be necessary because the transaction is deemed high-risk, is above certain thresholds, or requires a higher level of authentication due to country mandates (or regulations).
The Challenge Flow occurs when the issuer assesses the risk of the transaction during the frictionless flow and determines that the transaction requires additional cardholder authentication. The frictionless flow transitions into the challenge flow
Asynchronous 3 D Sv2 Challenge Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Authorize3D');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('4918190000000002')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
->setNotificationUrl('https://www.example.com/notification')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
// Threeds V2 Params
->setThreedsThreedsMethod('{"callback_url"=>"https://www.example.com/threeds/threeds_method/callback"}')
->setThreedsControl('{"device_type"=>"browser", "challenge_window_size"=>"full_screen", "challenge_indicator"=>"preference"}')
->setThreedsPurchase('{"category"=>"service"}')
->setThreedsRecurring('{"expiration_date"=>"17-07-2025", "frequency"=>30}')
->setThreedsMerchantRisk('{"shipping_indicator"=>"verified_address", "delivery_timeframe"=>"electronic", "reorder_items_indicator"=>"reordered", "pre_order_purchase_indicator"=>"merchandise_available", "pre_order_date"=>"17-02-2025", "gift_card"=>"true", "gift_card_count"=>"2"}')
->setThreedsCardHolderAccount('{"creation_date"=>"17-01-2024", "update_indicator"=>"more_than_60days", "last_change_date"=>"17-10-2024", "password_change_indicator"=>"no_change", "password_change_date"=>"02-01-2025", "shipping_address_usage_indicator"=>"current_transaction", "shipping_address_date_first_used"=>"12-01-2025", "transactions_activity_last_24_hours"=>"2", "transactions_activity_previous_year"=>"10", "provision_attempts_last_24_hours"=>"1", "purchases_count_last_6_months"=>"5", "suspicious_activity_indicator"=>"no_suspicious_observed", "registration_indicator"=>"30_to_60_days", "registration_date"=>"17-01-2023"}')
->setThreedsBrowser('{"accept_header"=>"*/*", "java_enabled"=>"false", "language"=>"en-GB", "color_depth"=>"24", "screen_height"=>"900", "screen_width"=>"1440", "time_zone_offset"=>"-120", "user_agent"=>"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"}')
->setThreedsSdk('{"interface"=>"native", "ui_types"=>{"ui_type"=>"multi_select"}, "application_id"=>"fc1650c0-5778-0138-8205-2cbc32a32d65", "encrypted_data"=>"encrypted-data-here", "ephemeral_public_key_pair"=>"public-key-pair", "max_timeout"=>"10", "reference_number"=>"sdk-reference-number-here"}')
// Sca Params
->setScaExemption('low_risk');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.Authorize3DRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
Authorize3DRequest request = new Authorize3DRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4918190000000002");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
request.setNotificationUrl(new URL("https://www.example.com/notification"));
request.setReturnSuccessUrl(new URL("http://www.example.com/success"));
request.setReturnFailureUrl(new URL("http://www.example.com/failure"));
// Threeds V2 Params
request.setThreedsThreedsMethod("{"callback_url"=>"https://www.example.com/threeds/threeds_method/callback"}");
request.setThreedsControl("{"device_type"=>"browser", "challenge_window_size"=>"full_screen", "challenge_indicator"=>"preference"}");
request.setThreedsPurchase("{"category"=>"service"}");
request.setThreedsRecurring("{"expiration_date"=>"17-07-2025", "frequency"=>30}");
request.setThreedsMerchantRisk("{"shipping_indicator"=>"verified_address", "delivery_timeframe"=>"electronic", "reorder_items_indicator"=>"reordered", "pre_order_purchase_indicator"=>"merchandise_available", "pre_order_date"=>"17-02-2025", "gift_card"=>"true", "gift_card_count"=>"2"}");
request.setThreedsCardHolderAccount("{"creation_date"=>"17-01-2024", "update_indicator"=>"more_than_60days", "last_change_date"=>"17-10-2024", "password_change_indicator"=>"no_change", "password_change_date"=>"02-01-2025", "shipping_address_usage_indicator"=>"current_transaction", "shipping_address_date_first_used"=>"12-01-2025", "transactions_activity_last_24_hours"=>"2", "transactions_activity_previous_year"=>"10", "provision_attempts_last_24_hours"=>"1", "purchases_count_last_6_months"=>"5", "suspicious_activity_indicator"=>"no_suspicious_observed", "registration_indicator"=>"30_to_60_days", "registration_date"=>"17-01-2023"}");
request.setThreedsBrowser("{"accept_header"=>"*/*", "java_enabled"=>"false", "language"=>"en-GB", "color_depth"=>"24", "screen_height"=>"900", "screen_width"=>"1440", "time_zone_offset"=>"-120", "user_agent"=>"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"}");
request.setThreedsSdk("{"interface"=>"native", "ui_types"=>{"ui_type"=>"multi_select"}, "application_id"=>"fc1650c0-5778-0138-8205-2cbc32a32d65", "encrypted_data"=>"encrypted-data-here", "ephemeral_public_key_pair"=>"public-key-pair", "max_timeout"=>"10", "reference_number"=>"sdk-reference-number-here"}");
// Sca Params
request.setScaExemption("low_risk");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.authorize3d(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": 100,
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "4918190000000002",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"notification_url": "https://www.example.com/notification",
"return_success_url": "http://www.example.com/success",
"return_failure_url": "http://www.example.com/failure",
"threeds_v2_params": {
"threeds_method": {
"callback_url": "https://www.example.com/threeds/threeds_method/callback"
},
"control": {
"device_type": "browser",
"challenge_window_size": "full_screen",
"challenge_indicator": "preference"
},
"purchase": {
"category": "service"
},
"recurring": {
"expiration_date": "17-07-2025",
"frequency": 30
},
"merchant_risk": {
"shipping_indicator": "verified_address",
"delivery_timeframe": "electronic",
"reorder_items_indicator": "reordered",
"pre_order_purchase_indicator": "merchandise_available",
"pre_order_date": "17-02-2025",
"gift_card": "true",
"gift_card_count": "2"
},
"card_holder_account": {
"creation_date": "17-01-2024",
"update_indicator": "more_than_60days",
"last_change_date": "17-10-2024",
"password_change_indicator": "no_change",
"password_change_date": "02-01-2025",
"shipping_address_usage_indicator": "current_transaction",
"shipping_address_date_first_used": "12-01-2025",
"transactions_activity_last_24_hours": "2",
"transactions_activity_previous_year": "10",
"provision_attempts_last_24_hours": "1",
"purchases_count_last_6_months": "5",
"suspicious_activity_indicator": "no_suspicious_observed",
"registration_indicator": "30_to_60_days",
"registration_date": "17-01-2023"
},
"browser": {
"accept_header": "*/*",
"java_enabled": "false",
"language": "en-GB",
"color_depth": "24",
"screen_height": "900",
"screen_width": "1440",
"time_zone_offset": "-120",
"user_agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"
},
"sdk": {
"interface": "native",
"ui_types": {
"ui_type": "multi_select"
},
"application_id": "fc1650c0-5778-0138-8205-2cbc32a32d65",
"encrypted_data": "encrypted-data-here",
"ephemeral_public_key_pair": "public-key-pair",
"max_timeout": "10",
"reference_number": "sdk-reference-number-here"
}
},
"sca_params": {
"exemption": "low_risk"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>authorize3d</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4918190000000002</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<notification_url>https://www.example.com/notification</notification_url>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<threeds_v2_params>
<threeds_method>
<callback_url>https://www.example.com/threeds/threeds_method/callback</callback_url>
</threeds_method>
<control>
<device_type>browser</device_type>
<challenge_window_size>full_screen</challenge_window_size>
<challenge_indicator>preference</challenge_indicator>
</control>
<purchase>
<category>service</category>
</purchase>
<merchant_risk>
<shipping_indicator>verified_address</shipping_indicator>
<delivery_timeframe>electronic</delivery_timeframe>
<reorder_items_indicator>reordered</reorder_items_indicator>
<pre_order_purchase_indicator>merchandise_available</pre_order_purchase_indicator>
<pre_order_date>17-02-2025</pre_order_date>
<gift_card>true</gift_card>
<gift_card_count>2</gift_card_count>
</merchant_risk>
<card_holder_account>
<creation_date>17-01-2024</creation_date>
<update_indicator>more_than_60days</update_indicator>
<last_change_date>17-10-2024</last_change_date>
<password_change_indicator>no_change</password_change_indicator>
<password_change_date>02-01-2025</password_change_date>
<shipping_address_usage_indicator>current_transaction</shipping_address_usage_indicator>
<shipping_address_date_first_used>12-01-2025</shipping_address_date_first_used>
<transactions_activity_last_24_hours>2</transactions_activity_last_24_hours>
<transactions_activity_previous_year>10</transactions_activity_previous_year>
<provision_attempts_last_24_hours>1</provision_attempts_last_24_hours>
<purchases_count_last_6_months>5</purchases_count_last_6_months>
<suspicious_activity_indicator>no_suspicious_observed</suspicious_activity_indicator>
<registration_indicator>30_to_60_days</registration_indicator>
<registration_date>17-01-2023</registration_date>
</card_holder_account>
<browser>
<accept_header>*/*</accept_header>
<java_enabled>false</java_enabled>
<language>en-GB</language>
<color_depth>24</color_depth>
<screen_height>900</screen_height>
<screen_width>1440</screen_width>
<time_zone_offset>-120</time_zone_offset>
<user_agent>Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36</user_agent>
</browser>
<sdk>
<interface>native</interface>
<ui_types>
<ui_type>multi_select</ui_type>
</ui_types>
<application_id>fc1650c0-5778-0138-8205-2cbc32a32d65</application_id>
<encrypted_data>encrypted-data-here</encrypted_data>
<ephemeral_public_key_pair>public-key-pair</ephemeral_public_key_pair>
<max_timeout>10</max_timeout>
<reference_number>sdk-reference-number-here</reference_number>
</sdk>
</threeds_v2_params>
<sca_params>
<exemption>low_risk</exemption>
</sca_params>
</payment_transaction>'
Challenge Response
stdClass Object
(
[transaction_type] => authorize3d
[status] => pending_async
[mode] => test
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[redirect_url] => https://staging.gate.emerchantpay.net/threeds/authentication/44177a21403427eb96664a6d7e5d5d48
[redirect_url_type] => 3ds_v2_challenge
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:24:03.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => false
)
<payment_response content=[
<transaction_type content=[authorize3d]>
<status content=[pending_async]>
<mode content=[test]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<redirect_url content=[https://staging.gate.emerchantpay.net/threeds/authentication/44177a21403427eb96664a6d7e5d5d48]>
<redirect_url_type content=[3ds_v2_challenge]>
<timestamp content=[2025-01-16T10:24:03Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[false]>
]>
{
transaction_type: "authorize3d",
status: "pending_async",
mode: "test",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
redirect_url: "https://staging.gate.emerchantpay.net/threeds/authentication/44177a21403427eb96664a6d7e5d5d48",
redirect_url_type: "3ds_v2_challenge",
timestamp: "2025-01-16T10:24:03Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "false",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>authorize3d</transaction_type>
<status>pending_async</status>
<mode>test</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<redirect_url>https://staging.gate.emerchantpay.net/threeds/authentication/44177a21403427eb96664a6d7e5d5d48</redirect_url>
<redirect_url_type>3ds_v2_challenge</redirect_url_type>
<timestamp>2025-01-16T10:24:03Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
Diagram
Reconcile
Once the transaction reaches the final state, a single reconcile can also be performed to retrieve more detailed information about the 3D transaction. It should include information about the 3DS transaction as described in the reconcile request/response below, on the right.
Reconcile 3 D Transaction By Unique Id Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('NonFinancial\Reconcile\Transaction');
$request = $genesis->request();
$request
->setUniqueId('44177a21403427eb96664a6d7e5d5d48');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.nonfinancial.reconcile.ReconcileRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
ReconcileRequest request = new ReconcileRequest();
request.setUniqueId("44177a21403427eb96664a6d7e5d5d48");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.reconcile(
{
"unique_id": "44177a21403427eb96664a6d7e5d5d48"
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/reconcile/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<reconcile>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
</reconcile>'
Successful Reconciliation Of 3 D Sv2 Transaction With Challenge Response
stdClass Object
(
[transaction_type] => authorize3d
[status] => approved
[authorization_code] => 005645
[retrieval_reference_number] => 016813015184
[payment_account_reference] => Q1HJZ28RKA1EBL470G9XYG90R5D3E
[response_code] => 00
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[transaction_id] => 119643250547501c79d8295
[mode] => test
[timestamp] => 2025-01-16T10:24:03Z
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[card_brand] => visa
[card_number] => 491819...0002
[card_type] => CREDIT
[card_subtype] => CARD SUBTYPE
[card_issuing_bank] => Issuing Bank
[card_issuing_country] => Exact Issuing country
[bank_account_number] => Bank Account Number
[bank_identifier_code] => Bank Identifier Code
[sent_to_acquirer] => true
[arn] => 74537605259536043849425
[scheme_response_code] => 00
[scheme_transaction_link_id] => TLINKIDENTIFIER4521412
[scheme_max_settlement_date] => 2024-07-31
[scheme_authentication_data_quality] => true
[threeds] => {:authentication_flow=>"challenge", :protocol=>{:target_version=>"2", :concrete_version=>"2", :sub_version=>"2"}, :eci=>"05"}
[threeds] => {:authentication_flow=>"challenge", :protocol=>{:target_version=>"2", :concrete_version=>"2", :sub_version=>"2"}, :eci=>"05"}
)
<payment_response content=[
<transaction_type content=[authorize3d]>
<status content=[approved]>
<authorization_code content=[005645]>
<retrieval_reference_number content=[016813015184]>
<payment_account_reference content=[Q1HJZ28RKA1EBL470G9XYG90R5D3E]>
<response_code content=[00]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<transaction_id content=[119643250547501c79d8295]>
<mode content=[test]>
<timestamp content=[2025-01-16T10:24:03Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<card_brand content=[visa]>
<card_number content=[491819...0002]>
<card_type content=[CREDIT]>
<card_subtype content=[CARD SUBTYPE]>
<card_issuing_bank content=[Issuing Bank]>
<card_issuing_country content=[Exact Issuing country]>
<bank_account_number content=[Bank Account Number]>
<bank_identifier_code content=[Bank Identifier Code]>
<sent_to_acquirer content=[true]>
<arn content=[74537605259536043849425]>
<scheme_response_code content=[00]>
<scheme_transaction_link_id content=[TLINKIDENTIFIER4521412]>
<scheme_max_settlement_date content=[2024-07-31]>
<scheme_authentication_data_quality content=[true]>
<threeds content=[{:authentication_flow=>"challenge", :protocol=>{:target_version=>"2", :concrete_version=>"2", :sub_version=>"2"}, :eci=>"05"}]>
<threeds content=[{:authentication_flow=>"challenge", :protocol=>{:target_version=>"2", :concrete_version=>"2", :sub_version=>"2"}, :eci=>"05"}]>
]>
{
transaction_type: "authorize3d",
status: "approved",
authorization_code: "005645",
retrieval_reference_number: "016813015184",
payment_account_reference: "Q1HJZ28RKA1EBL470G9XYG90R5D3E",
response_code: "00",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
transaction_id: "119643250547501c79d8295",
mode: "test",
timestamp: "2025-01-16T10:24:03Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
card_brand: "visa",
card_number: "491819...0002",
card_type: "CREDIT",
card_subtype: "CARD SUBTYPE",
card_issuing_bank: "Issuing Bank",
card_issuing_country: "Exact Issuing country",
bank_account_number: "Bank Account Number",
bank_identifier_code: "Bank Identifier Code",
sent_to_acquirer: "true",
arn: "74537605259536043849425",
scheme_response_code: "00",
scheme_transaction_link_id: "TLINKIDENTIFIER4521412",
scheme_max_settlement_date: "2024-07-31",
scheme_authentication_data_quality: "true",
threeds: "{:authentication_flow=>"challenge", :protocol=>{:target_version=>"2", :concrete_version=>"2", :sub_version=>"2"}, :eci=>"05"}",
threeds: "{:authentication_flow=>"challenge", :protocol=>{:target_version=>"2", :concrete_version=>"2", :sub_version=>"2"}, :eci=>"05"}",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>authorize3d</transaction_type>
<status>approved</status>
<authorization_code>005645</authorization_code>
<retrieval_reference_number>016813015184</retrieval_reference_number>
<payment_account_reference>Q1HJZ28RKA1EBL470G9XYG90R5D3E</payment_account_reference>
<response_code>00</response_code>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<transaction_id>119643250547501c79d8295</transaction_id>
<mode>test</mode>
<timestamp>2025-01-16T10:24:03Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<card_brand>visa</card_brand>
<card_number>491819...0002</card_number>
<card_type>CREDIT</card_type>
<card_subtype>CARD SUBTYPE</card_subtype>
<card_issuing_bank>Issuing Bank</card_issuing_bank>
<card_issuing_country>Exact Issuing country</card_issuing_country>
<bank_account_number>Bank Account Number</bank_account_number>
<bank_identifier_code>Bank Identifier Code</bank_identifier_code>
<sent_to_acquirer>true</sent_to_acquirer>
<arn>74537605259536043849425</arn>
<scheme_response_code>00</scheme_response_code>
<scheme_transaction_link_id>TLINKIDENTIFIER4521412</scheme_transaction_link_id>
<scheme_max_settlement_date>2024-07-31</scheme_max_settlement_date>
<scheme_authentication_data_quality>true</scheme_authentication_data_quality>
<threeds>
<authentication_flow>challenge</authentication_flow>
<protocol>
<target_version>2</target_version>
<concrete_version>2</concrete_version>
<sub_version>2</sub_version>
</protocol>
<eci>05</eci>
</threeds>
</payment_response>
Successful Reconcile Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
moto | 'true' | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech support for more details. |
avs_response_code | string(255) | Generated by the card network on trying to match the billing address when performing the address verification. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
avs_response_text | string(255) | Gives the human response text for the AVS response code above. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
cvv_result_code | string(1) | Card Verification Value response code. Optional, returned only if acquirer supports it |
authorization_code | string(6) | Generated by the card network when an authorisation has occurred, used to identify that auth. Consists of 6 alphanumeric chars |
retrieval_reference_number | string(255) | A reference number used for tracking all messages related to a given cardholder transaction returned by some acquirers. |
response_code | string(2) | Defines the result of a transaction with the acquirer, the status of a message or some action taken or required. Contact tech-support@emerchantpay.com for more details. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
partial_approval | string(4) | Optional, set to ’true’ if partial approval happened. Partially approved amount is then in the amount field. Check Partial Approvals for details |
sent_to_acquirer | string(255) | "true" or "false" |
threeds | ||
authentication_flow | string(255) | Identifies the concrete authentication flow of the 3DS transaction that it has gone through. It will be included only if the transaction reaches the final state. The possible values for 3DSv2 are frictionless, challenge. |
protocol | ||
target_version | integer | Identifies the requested version of the 3DS authentication protocol to be used. The possible values are 2. |
concrete_version | integer | Identifies the concrete version of the 3DS authentication protocol that the transaction has been processed through. The possible values are 2. |
eci | string(2) | See Electronic Commerce Indicator for details |
Notification
Once the transaction reaches final state, a notification will be sent to the notification_url
submitted in the
initial transaction request. For more information, go to Asynchronous Transactions and Notifications.
Approved Notification Example for challenge flow
?transaction_id=119643250547501c79d8295
&unique_id=44177a21403427eb96664a6d7e5d5d48
&transaction_type=authorize3d
&terminal_token=394f2ebc3646d3c017fa1e1cbc4a1e20
&status=approved
&amount=100
&signature=088e16a1019277b15d58faf0541e11910eb756f6
&eci=05
&avs_response_code=5I
&avs_response_text=Response+provided+by+issuer+processor%3B+Address+information+not+verified
&cvv_result_code=M
&authorization_code=005645
&retrieval_reference_number=016813015184
&payment_account_reference=50019P9LBXOLHN9G7QMU5VN520YSY
&scheme_transaction_link_id=TLINKIDENTIFIER4521412
&scheme_pan_indicator=V
&scheme_pan_tail=0013
&scheme_max_settlement_date=2024-07-31
&scheme_authentication_data_quality=true
&threeds_authentication_flow=challenge
&threeds_target_protocol_version=2
&threeds_concrete_protocol_version=2
&threeds_protocol_sub_version=2
Declined Notification Example for challenge flow
?transaction_id=119643250547501c79d8295
&unique_id=44177a21403427eb96664a6d7e5d5d48
&transaction_type=authorize3d
&terminal_token=394f2ebc3646d3c017fa1e1cbc4a1e20
&status=declined
&amount=100
&signature=088e16a1019277b15d58faf0541e11910eb756f6
&eci=05
&avs_response_code=5I
&avs_response_text=Response+provided+by+issuer+processor%3B+Address+information+not+verified
&cvv_result_code=M
&authorization_code=005645
&retrieval_reference_number=016813015184
&payment_account_reference=50019P9LBXOLHN9G7QMU5VN520YSY
&scheme_transaction_link_id=TLINKIDENTIFIER4521412
&scheme_pan_indicator=V
&scheme_pan_tail=0013
&scheme_max_settlement_date=2024-07-31
&scheme_authentication_data_quality=true
&threeds_authentication_flow=challenge
&threeds_target_protocol_version=2
&threeds_concrete_protocol_version=2
&threeds_protocol_sub_version=2
3DS Attributes
Name | Type | Description |
---|---|---|
threeds_authentication_flow | string | Identifies the concrete 3DS authentication flow that the transaction has gone through. It will be available in the notification only if the consumer has finished the 3DS authentication with the issuer. The available values for 3DSv2 are frictionless and challenge. |
threeds_method_status | string | Identifies the status of the 3DS-Method in the scope of 3DSv2 authentication protocol. The possible values are required, in_progress and completed. |
threeds_target_protocol_version | string(1) | Identifies the 3DS protocol that has been enforced. The possible values are 2. |
threeds_concrete_protocol_version | string(1) | Identifies the concrete 3DS protocol version that the transaction has gone through. The possible values are 2. |
threeds_protocol_sub_version | string(1) | Identifies the 3DS protocol sub-version that the transaction has gone through. The possible values are 1, 2, 3, 4, 5, 6, 7, 8, 9. |
threeds_authentication_status_reason_code | string(2) | See Status Reason Code for details. |
Challenge with 3DSecure Method
If the ACS determines that further Cardholder interaction is required to complete the authentication, the Frictionless Flow transitions into the Challenge Flow. For example, a challenge may be necessary because the transaction is deemed high-risk, is above certain thresholds, or requires a higher level of authentication due to country mandates (or regulations).
The Challenge Flow occurs when the issuer assesses the risk of the transaction during the frictionless flow and determines that the transaction requires additional cardholder authentication. The frictionless flow transitions into the challenge flow
Asynchronous 3DS Method submission
A link between the customer's browser and the card issuer must be opened with a hidden iframe.
It is used for the card issuer to load JavaScript which gathers device information to be returned to the card issuer.
The next step after initiating the iframe, is to submit an API call to the threeds_method_continue_url
using HTTP PUT,
to retrieve the next step in the authentication. The API request won't require HTTP basic authentication,
but a proper signature needs to be included to prove the authenticity of the request.
The response of this API call will be the same as the normal 3D transaction processing API response, but with the only difference
that an additional interaction with the issuer might be requested.
The asynchronous submission of the 3DS-Method might look difficult to achieve, but mitigates the risk of potential transaction processing interruptions, because the consumer redirection does not depend on a successful 3DS-Method submission. A continuation of the 3DS-Method might be requested regardless of the 3DS-Method submission result. It's a responsibility of the ACS then to take the appropriate decision how to continue with the authentication.
In order to simulate this authentication flow, use а test card 4938730000000001 for challenge flow that requires 3DS-Method and
submit a 3DSv2 transaction in asynchronous workflow by including the threeds_v2_params
.
The response of the API will indicate that further action is required:
status
- pending_asyncthreeds_method_url
- the URL action where the 3DS-Method needs to be submitted using HTTP POSTthreeds_method_continue_url
- API endpoint that accepts HTTP PUT requests with a signature and returns transaction API response identifying what the next step is (transaction completed or consumer interaction is needed)
In order to submit a 3DS-Method, you need to create a hidden iframe in the consumer browser (client side) with an html
and body
tags as described below,
on the right side and create a hidden HTML form that:
- targets the iframe
- uses HTTP METHOD POST -
method="post"
- has an action equivalent to the value of
threeds_method_url
, received from the response of the initial transaction request - has 2 hidden inputs
unique_id
- equivalent to the value of theunique_id
, received from the response of the initial transaction requestsignature
- SHA512 of а concatenated string (unique_id, amount, timestamp, merchant_api_password), where unique_id, amount, timestamp can be taken from the response of the initial transaction request and merchant_api_password is the password used for HTTP Basic authentication to the API during the initial transaction request
- submit the HTML form in the background using JavaScript
Once the 3DS-Method submission is initiated, a callback via HTTP POST will be done inside the iframe
when the 3DS-Method reaches the final state. The 3DS-Method callback will be sent to the callback_url
(submitted in the 3DSv2 request params as described in the diagram below) and will be constructed as described below:
- with request headers
Content-Type
- application/x-www-form-urlencoded
- with POST request params
unique_id
- the exact unique_id of the transaction in the initial transaction requestthreeds_method_status
- the status of the 3DS-Method submission, expect a value of completedsignature
- SHA512 of a concatenated string with the values of unique_id, threeds_method_status, and merchant_api_password where unique_id and threeds_method_status are POST params and merchant_api_password is the password used for HTTP HTTP Basic authentication to the API during the initial transaction request
The callback above can be handled (optional) in order to get informed of the 3DS-Method status, whether it has completed or not.
Right after submitting the 3DS-Method (without waiting for the 3DS-Method completion), submit a 3DS-Method continue API call to determine what the next step that is required (as described in the diagram below):
- no further action - payment successful / failed
- consumer <--> Issuer interaction needed
In order to submit the 3DS-Method continue call, please make sure to follow the steps, as described below in the diagram:
Submit an API call using HTTP METHOD PUT to the URL returned in threeds_method_continue_url
during the initial transaction request:
- with request headers
Content-Type
- application/x-www-form-urlencoded
- with request params
signature
- the same signature used for submitting the 3DS-Method
The response of the API call will be transaction response XML indicating what is expected:
- no action, the
status
will be in final state (authentication completed without friction and authorization has been performed) - consumer redirection, the
status
will be pending_async (consumer interaction with the the issuer needed to complete the authentication)
Asynchronous 3 D Sv2 Challenge With 3 Ds Method Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Sale3D');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('4938730000000001')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
->setNotificationUrl('https://www.example.com/notification')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
// Threeds V2 Params
->setThreedsThreedsMethod('{"callback_url"=>"https://www.example.com/threeds/threeds_method/callback"}')
->setThreedsControl('{"device_type"=>"browser", "challenge_window_size"=>"full_screen", "challenge_indicator"=>"preference"}')
->setThreedsPurchase('{"category"=>"service"}')
->setThreedsRecurring('{"expiration_date"=>"17-07-2025", "frequency"=>30}')
->setThreedsMerchantRisk('{"shipping_indicator"=>"verified_address", "delivery_timeframe"=>"electronic", "reorder_items_indicator"=>"reordered", "pre_order_purchase_indicator"=>"merchandise_available", "pre_order_date"=>"17-02-2025", "gift_card"=>"true", "gift_card_count"=>"2"}')
->setThreedsCardHolderAccount('{"creation_date"=>"17-01-2024", "update_indicator"=>"more_than_60days", "last_change_date"=>"17-10-2024", "password_change_indicator"=>"no_change", "password_change_date"=>"02-01-2025", "shipping_address_usage_indicator"=>"current_transaction", "shipping_address_date_first_used"=>"12-01-2025", "transactions_activity_last_24_hours"=>"2", "transactions_activity_previous_year"=>"10", "provision_attempts_last_24_hours"=>"1", "purchases_count_last_6_months"=>"5", "suspicious_activity_indicator"=>"no_suspicious_observed", "registration_indicator"=>"30_to_60_days", "registration_date"=>"17-01-2023"}')
->setThreedsBrowser('{"accept_header"=>"*/*", "java_enabled"=>"false", "language"=>"en-GB", "color_depth"=>"24", "screen_height"=>"900", "screen_width"=>"1440", "time_zone_offset"=>"-120", "user_agent"=>"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"}')
->setThreedsSdk('{"interface"=>"native", "ui_types"=>{"ui_type"=>"multi_select"}, "application_id"=>"fc1650c0-5778-0138-8205-2cbc32a32d65", "encrypted_data"=>"encrypted-data-here", "ephemeral_public_key_pair"=>"public-key-pair", "max_timeout"=>"10", "reference_number"=>"sdk-reference-number-here"}')
// Sca Params
->setScaExemption('low_risk');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.Sale3DRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
Sale3DRequest request = new Sale3DRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4938730000000001");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
request.setNotificationUrl(new URL("https://www.example.com/notification"));
request.setReturnSuccessUrl(new URL("http://www.example.com/success"));
request.setReturnFailureUrl(new URL("http://www.example.com/failure"));
// Threeds V2 Params
request.setThreedsThreedsMethod("{"callback_url"=>"https://www.example.com/threeds/threeds_method/callback"}");
request.setThreedsControl("{"device_type"=>"browser", "challenge_window_size"=>"full_screen", "challenge_indicator"=>"preference"}");
request.setThreedsPurchase("{"category"=>"service"}");
request.setThreedsRecurring("{"expiration_date"=>"17-07-2025", "frequency"=>30}");
request.setThreedsMerchantRisk("{"shipping_indicator"=>"verified_address", "delivery_timeframe"=>"electronic", "reorder_items_indicator"=>"reordered", "pre_order_purchase_indicator"=>"merchandise_available", "pre_order_date"=>"17-02-2025", "gift_card"=>"true", "gift_card_count"=>"2"}");
request.setThreedsCardHolderAccount("{"creation_date"=>"17-01-2024", "update_indicator"=>"more_than_60days", "last_change_date"=>"17-10-2024", "password_change_indicator"=>"no_change", "password_change_date"=>"02-01-2025", "shipping_address_usage_indicator"=>"current_transaction", "shipping_address_date_first_used"=>"12-01-2025", "transactions_activity_last_24_hours"=>"2", "transactions_activity_previous_year"=>"10", "provision_attempts_last_24_hours"=>"1", "purchases_count_last_6_months"=>"5", "suspicious_activity_indicator"=>"no_suspicious_observed", "registration_indicator"=>"30_to_60_days", "registration_date"=>"17-01-2023"}");
request.setThreedsBrowser("{"accept_header"=>"*/*", "java_enabled"=>"false", "language"=>"en-GB", "color_depth"=>"24", "screen_height"=>"900", "screen_width"=>"1440", "time_zone_offset"=>"-120", "user_agent"=>"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"}");
request.setThreedsSdk("{"interface"=>"native", "ui_types"=>{"ui_type"=>"multi_select"}, "application_id"=>"fc1650c0-5778-0138-8205-2cbc32a32d65", "encrypted_data"=>"encrypted-data-here", "ephemeral_public_key_pair"=>"public-key-pair", "max_timeout"=>"10", "reference_number"=>"sdk-reference-number-here"}");
// Sca Params
request.setScaExemption("low_risk");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.sale3d(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": 100,
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "4938730000000001",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"notification_url": "https://www.example.com/notification",
"return_success_url": "http://www.example.com/success",
"return_failure_url": "http://www.example.com/failure",
"threeds_v2_params": {
"threeds_method": {
"callback_url": "https://www.example.com/threeds/threeds_method/callback"
},
"control": {
"device_type": "browser",
"challenge_window_size": "full_screen",
"challenge_indicator": "preference"
},
"purchase": {
"category": "service"
},
"recurring": {
"expiration_date": "17-07-2025",
"frequency": 30
},
"merchant_risk": {
"shipping_indicator": "verified_address",
"delivery_timeframe": "electronic",
"reorder_items_indicator": "reordered",
"pre_order_purchase_indicator": "merchandise_available",
"pre_order_date": "17-02-2025",
"gift_card": "true",
"gift_card_count": "2"
},
"card_holder_account": {
"creation_date": "17-01-2024",
"update_indicator": "more_than_60days",
"last_change_date": "17-10-2024",
"password_change_indicator": "no_change",
"password_change_date": "02-01-2025",
"shipping_address_usage_indicator": "current_transaction",
"shipping_address_date_first_used": "12-01-2025",
"transactions_activity_last_24_hours": "2",
"transactions_activity_previous_year": "10",
"provision_attempts_last_24_hours": "1",
"purchases_count_last_6_months": "5",
"suspicious_activity_indicator": "no_suspicious_observed",
"registration_indicator": "30_to_60_days",
"registration_date": "17-01-2023"
},
"browser": {
"accept_header": "*/*",
"java_enabled": "false",
"language": "en-GB",
"color_depth": "24",
"screen_height": "900",
"screen_width": "1440",
"time_zone_offset": "-120",
"user_agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36"
},
"sdk": {
"interface": "native",
"ui_types": {
"ui_type": "multi_select"
},
"application_id": "fc1650c0-5778-0138-8205-2cbc32a32d65",
"encrypted_data": "encrypted-data-here",
"ephemeral_public_key_pair": "public-key-pair",
"max_timeout": "10",
"reference_number": "sdk-reference-number-here"
}
},
"sca_params": {
"exemption": "low_risk"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>sale3d</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4938730000000001</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<notification_url>https://www.example.com/notification</notification_url>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<threeds_v2_params>
<threeds_method>
<callback_url>https://www.example.com/threeds/threeds_method/callback</callback_url>
</threeds_method>
<control>
<device_type>browser</device_type>
<challenge_window_size>full_screen</challenge_window_size>
<challenge_indicator>preference</challenge_indicator>
</control>
<purchase>
<category>service</category>
</purchase>
<merchant_risk>
<shipping_indicator>verified_address</shipping_indicator>
<delivery_timeframe>electronic</delivery_timeframe>
<reorder_items_indicator>reordered</reorder_items_indicator>
<pre_order_purchase_indicator>merchandise_available</pre_order_purchase_indicator>
<pre_order_date>17-02-2025</pre_order_date>
<gift_card>true</gift_card>
<gift_card_count>2</gift_card_count>
</merchant_risk>
<card_holder_account>
<creation_date>17-01-2024</creation_date>
<update_indicator>more_than_60days</update_indicator>
<last_change_date>17-10-2024</last_change_date>
<password_change_indicator>no_change</password_change_indicator>
<password_change_date>02-01-2025</password_change_date>
<shipping_address_usage_indicator>current_transaction</shipping_address_usage_indicator>
<shipping_address_date_first_used>12-01-2025</shipping_address_date_first_used>
<transactions_activity_last_24_hours>2</transactions_activity_last_24_hours>
<transactions_activity_previous_year>10</transactions_activity_previous_year>
<provision_attempts_last_24_hours>1</provision_attempts_last_24_hours>
<purchases_count_last_6_months>5</purchases_count_last_6_months>
<suspicious_activity_indicator>no_suspicious_observed</suspicious_activity_indicator>
<registration_indicator>30_to_60_days</registration_indicator>
<registration_date>17-01-2023</registration_date>
</card_holder_account>
<browser>
<accept_header>*/*</accept_header>
<java_enabled>false</java_enabled>
<language>en-GB</language>
<color_depth>24</color_depth>
<screen_height>900</screen_height>
<screen_width>1440</screen_width>
<time_zone_offset>-120</time_zone_offset>
<user_agent>Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36</user_agent>
</browser>
<sdk>
<interface>native</interface>
<ui_types>
<ui_type>multi_select</ui_type>
</ui_types>
<application_id>fc1650c0-5778-0138-8205-2cbc32a32d65</application_id>
<encrypted_data>encrypted-data-here</encrypted_data>
<ephemeral_public_key_pair>public-key-pair</ephemeral_public_key_pair>
<max_timeout>10</max_timeout>
<reference_number>sdk-reference-number-here</reference_number>
</sdk>
</threeds_v2_params>
<sca_params>
<exemption>low_risk</exemption>
</sca_params>
</payment_transaction>'
Challenge With 3 Ds Mеthod Response
stdClass Object
(
[transaction_type] => sale3d
[status] => pending_async
[mode] => test
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[threeds_method_url] => https://staging.gate.emerchantpay.net/threeds/threeds_method
[threeds_method_continue_url] => https://staging.gate.emerchantpay.net/threeds/threeds_method/44177a21403427eb96664a6d7e5d5d48
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:24:04.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => false
)
<payment_response content=[
<transaction_type content=[sale3d]>
<status content=[pending_async]>
<mode content=[test]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<threeds_method_url content=[https://staging.gate.emerchantpay.net/threeds/threeds_method]>
<threeds_method_continue_url content=[https://staging.gate.emerchantpay.net/threeds/threeds_method/44177a21403427eb96664a6d7e5d5d48]>
<timestamp content=[2025-01-16T10:24:04Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[false]>
]>
{
transaction_type: "sale3d",
status: "pending_async",
mode: "test",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
threeds_method_url: "https://staging.gate.emerchantpay.net/threeds/threeds_method",
threeds_method_continue_url: "https://staging.gate.emerchantpay.net/threeds/threeds_method/44177a21403427eb96664a6d7e5d5d48",
timestamp: "2025-01-16T10:24:04Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "false",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>sale3d</transaction_type>
<status>pending_async</status>
<mode>test</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<threeds_method_url>https://staging.gate.emerchantpay.net/threeds/threeds_method</threeds_method_url>
<threeds_method_continue_url>https://staging.gate.emerchantpay.net/threeds/threeds_method/44177a21403427eb96664a6d7e5d5d48</threeds_method_continue_url>
<timestamp>2025-01-16T10:24:04Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
<!-- Sample HTML for the 3DS-Method submission in an iframe -->
<html>
<head>
</head>
<body onload="submitThreedsMethod()">
<iframe width="..." height="..." id="threeDSMethodIframe" name="threeDSMethodIframe">
<html>
<body>
</body>
</html>
</iframe>
<form id ="threeDSMethodForm" name="threeDSMethodForm"
enctype="application/x-www-form-urlencoded;charset=UTF-8"
style="display: none"
method="post"
action="https://staging.gate.emerchantpay.net/threeds/threeds_method"
target="threeDSMethodIframe">
<input type="hidden" name="unique_id" value="44177a21403427eb96664a6d7e5d5d48" />
<!-- The signature is built as per the above notes for merchant with API password a54a1e349b9784bb01126fdefc244b3ede19e84d -->
<input type="hidden" name="signature" value="4dffd39f12f58ca6d9d2fa7544477b18c88966f74b1310d92022ca2b9fac6382cea624387dee7ecc4a1ced09e87577cb404f0979dea840a1185d4b6bf3b68502" />
</form>
</body>
<script>
function submitThreedsMethod() {
threeDSMethodForm = document.getElementById('threeDSMethodForm');
threeDSMethodForm.submit();
}
</script>
</html>
<!-- 3DS-Method Callback inside the iframe indicating the 3DS-Method completed -->
<!-- Content-Type: application/x-www-form-urlencoded -->
<!-- The signature is built as per the above notes for merchant with API password a54a1e349b9784bb01126fdefc244b3ede19e84d -->
POST https://www.example.com/threeds/threeds_method/callback
unique_id=44177a21403427eb96664a6d7e5d5d48
&threeds_method_status=completed
&signature=86bb547ba3daf8b7970d2e185404426a4c9790282a4612e21ef59dfc591a5fa227f88225571049e2242099effc19f53529433a2bd240a712d7e9ff4c8c4c65e8
<!-- 3DS-Method continue API call -->
<!-- Content-Type: application/x-www-form-urlencoded -->
<!-- The signature is built as per the above notes for merchant with API password a54a1e349b9784bb01126fdefc244b3ede19e84d -->
curl https://staging.gate.emerchantpay.net/threeds/threeds_method/44177a21403427eb96664a6d7e5d5d48 \
-X PUT \
-H "Content-Type: application/x-www-form-urlencoded" \
-d signature=4dffd39f12f58ca6d9d2fa7544477b18c88966f74b1310d92022ca2b9fac6382cea624387dee7ecc4a1ced09e87577cb404f0979dea840a1185d4b6bf3b68502
3 Ds Method Continue Response
stdClass Object
(
[transaction_type] => sale3d
[status] => pending_async
[mode] => test
[transaction_id] => 119643250547501c79d8295
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[redirect_url] => https://staging.gate.emerchantpay.net/threeds/authentication/44177a21403427eb96664a6d7e5d5d48
[redirect_url_type] => 3ds_v2_challenge
[timestamp] => DateTime Object
(
[date] => 2025-01-16 10:24:04.000000
[timezone_type] => 2
[timezone] => Z
)
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[sent_to_acquirer] => false
)
<payment_response content=[
<transaction_type content=[sale3d]>
<status content=[pending_async]>
<mode content=[test]>
<transaction_id content=[119643250547501c79d8295]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<redirect_url content=[https://staging.gate.emerchantpay.net/threeds/authentication/44177a21403427eb96664a6d7e5d5d48]>
<redirect_url_type content=[3ds_v2_challenge]>
<timestamp content=[2025-01-16T10:24:04Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<sent_to_acquirer content=[false]>
]>
{
transaction_type: "sale3d",
status: "pending_async",
mode: "test",
transaction_id: "119643250547501c79d8295",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
redirect_url: "https://staging.gate.emerchantpay.net/threeds/authentication/44177a21403427eb96664a6d7e5d5d48",
redirect_url_type: "3ds_v2_challenge",
timestamp: "2025-01-16T10:24:04Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
sent_to_acquirer: "false",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>sale3d</transaction_type>
<status>pending_async</status>
<mode>test</mode>
<transaction_id>119643250547501c79d8295</transaction_id>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<redirect_url>https://staging.gate.emerchantpay.net/threeds/authentication/44177a21403427eb96664a6d7e5d5d48</redirect_url>
<redirect_url_type>3ds_v2_challenge</redirect_url_type>
<timestamp>2025-01-16T10:24:04Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<sent_to_acquirer>false</sent_to_acquirer>
</payment_response>
The consumer needs to be redirected to the Challenge redirect_url
URL to complete the authentication with the ACS.
Once the consumer completes all the challenges of the ACS provider, will be redirected either to return_success_url
or return_failure_url
depending on the challenge authentication status and authorization response as described in the diagram below.
Diagram
Reconcile
Once the transaction reaches the final state, a single reconcile can also be performed to retrieve more detailed information about the 3D transaction. It should include information about the 3DS transaction as described in the reconcile request/response below, on the right.
Reconcile 3 D Transaction By Unique Id Request
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('NonFinancial\Reconcile\Transaction');
$request = $genesis->request();
$request
->setUniqueId('44177a21403427eb96664a6d7e5d5d48');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.nonfinancial.reconcile.ReconcileRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
ReconcileRequest request = new ReconcileRequest();
request.setUniqueId("44177a21403427eb96664a6d7e5d5d48");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.reconcile(
{
"unique_id": "44177a21403427eb96664a6d7e5d5d48"
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/reconcile/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<reconcile>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
</reconcile>'
Successful Reconciliation Of 3 D Sv2 Transaction With Challenge And 3 Ds Method Response
stdClass Object
(
[transaction_type] => sale3d
[status] => approved
[authorization_code] => 005645
[retrieval_reference_number] => 016813015184
[payment_account_reference] => Q1HJZ28RKA1EBL470G9XYG90R5D3E
[response_code] => 00
[unique_id] => 44177a21403427eb96664a6d7e5d5d48
[transaction_id] => 119643250547501c79d8295
[mode] => test
[timestamp] => 2025-01-16T10:24:04Z
[descriptor] => Descriptor one
[amount] => 100
[currency] => USD
[card_brand] => visa
[card_number] => 493873...0001
[card_type] => CREDIT
[card_subtype] => CARD SUBTYPE
[card_issuing_bank] => Issuing Bank
[card_issuing_country] => Exact Issuing country
[bank_account_number] => Bank Account Number
[bank_identifier_code] => Bank Identifier Code
[sent_to_acquirer] => true
[arn] => 74537605259536043849425
[scheme_response_code] => 00
[scheme_transaction_link_id] => TLINKIDENTIFIER4521412
[scheme_max_settlement_date] => 2024-07-31
[scheme_authentication_data_quality] => true
[threeds] => {:authentication_flow=>"challenge", :threeds_method=>{:status=>"completed"}, :protocol=>{:target_version=>"2", :concrete_version=>"2", :sub_version=>"2"}, :eci=>"05"}
[threeds] => {:authentication_flow=>"challenge", :threeds_method=>{:status=>"completed"}, :protocol=>{:target_version=>"2", :concrete_version=>"2", :sub_version=>"2"}, :eci=>"05"}
)
<payment_response content=[
<transaction_type content=[sale3d]>
<status content=[approved]>
<authorization_code content=[005645]>
<retrieval_reference_number content=[016813015184]>
<payment_account_reference content=[Q1HJZ28RKA1EBL470G9XYG90R5D3E]>
<response_code content=[00]>
<unique_id content=[44177a21403427eb96664a6d7e5d5d48]>
<transaction_id content=[119643250547501c79d8295]>
<mode content=[test]>
<timestamp content=[2025-01-16T10:24:04Z]>
<descriptor content=[Descriptor one]>
<amount content=[100]>
<currency content=[USD]>
<card_brand content=[visa]>
<card_number content=[493873...0001]>
<card_type content=[CREDIT]>
<card_subtype content=[CARD SUBTYPE]>
<card_issuing_bank content=[Issuing Bank]>
<card_issuing_country content=[Exact Issuing country]>
<bank_account_number content=[Bank Account Number]>
<bank_identifier_code content=[Bank Identifier Code]>
<sent_to_acquirer content=[true]>
<arn content=[74537605259536043849425]>
<scheme_response_code content=[00]>
<scheme_transaction_link_id content=[TLINKIDENTIFIER4521412]>
<scheme_max_settlement_date content=[2024-07-31]>
<scheme_authentication_data_quality content=[true]>
<threeds content=[{:authentication_flow=>"challenge", :threeds_method=>{:status=>"completed"}, :protocol=>{:target_version=>"2", :concrete_version=>"2", :sub_version=>"2"}, :eci=>"05"}]>
<threeds content=[{:authentication_flow=>"challenge", :threeds_method=>{:status=>"completed"}, :protocol=>{:target_version=>"2", :concrete_version=>"2", :sub_version=>"2"}, :eci=>"05"}]>
]>
{
transaction_type: "sale3d",
status: "approved",
authorization_code: "005645",
retrieval_reference_number: "016813015184",
payment_account_reference: "Q1HJZ28RKA1EBL470G9XYG90R5D3E",
response_code: "00",
unique_id: "44177a21403427eb96664a6d7e5d5d48",
transaction_id: "119643250547501c79d8295",
mode: "test",
timestamp: "2025-01-16T10:24:04Z",
descriptor: "Descriptor one",
amount: "100",
currency: "USD",
card_brand: "visa",
card_number: "493873...0001",
card_type: "CREDIT",
card_subtype: "CARD SUBTYPE",
card_issuing_bank: "Issuing Bank",
card_issuing_country: "Exact Issuing country",
bank_account_number: "Bank Account Number",
bank_identifier_code: "Bank Identifier Code",
sent_to_acquirer: "true",
arn: "74537605259536043849425",
scheme_response_code: "00",
scheme_transaction_link_id: "TLINKIDENTIFIER4521412",
scheme_max_settlement_date: "2024-07-31",
scheme_authentication_data_quality: "true",
threeds: "{:authentication_flow=>"challenge", :threeds_method=>{:status=>"completed"}, :protocol=>{:target_version=>"2", :concrete_version=>"2", :sub_version=>"2"}, :eci=>"05"}",
threeds: "{:authentication_flow=>"challenge", :threeds_method=>{:status=>"completed"}, :protocol=>{:target_version=>"2", :concrete_version=>"2", :sub_version=>"2"}, :eci=>"05"}",
}
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_type>sale3d</transaction_type>
<status>approved</status>
<authorization_code>005645</authorization_code>
<retrieval_reference_number>016813015184</retrieval_reference_number>
<payment_account_reference>Q1HJZ28RKA1EBL470G9XYG90R5D3E</payment_account_reference>
<response_code>00</response_code>
<unique_id>44177a21403427eb96664a6d7e5d5d48</unique_id>
<transaction_id>119643250547501c79d8295</transaction_id>
<mode>test</mode>
<timestamp>2025-01-16T10:24:04Z</timestamp>
<descriptor>Descriptor one</descriptor>
<amount>100</amount>
<currency>USD</currency>
<card_brand>visa</card_brand>
<card_number>493873...0001</card_number>
<card_type>CREDIT</card_type>
<card_subtype>CARD SUBTYPE</card_subtype>
<card_issuing_bank>Issuing Bank</card_issuing_bank>
<card_issuing_country>Exact Issuing country</card_issuing_country>
<bank_account_number>Bank Account Number</bank_account_number>
<bank_identifier_code>Bank Identifier Code</bank_identifier_code>
<sent_to_acquirer>true</sent_to_acquirer>
<arn>74537605259536043849425</arn>
<scheme_response_code>00</scheme_response_code>
<scheme_transaction_link_id>TLINKIDENTIFIER4521412</scheme_transaction_link_id>
<scheme_max_settlement_date>2024-07-31</scheme_max_settlement_date>
<scheme_authentication_data_quality>true</scheme_authentication_data_quality>
<threeds>
<authentication_flow>challenge</authentication_flow>
<threeds_method>
<status>completed</status>
</threeds_method>
<protocol>
<target_version>2</target_version>
<concrete_version>2</concrete_version>
<sub_version>2</sub_version>
</protocol>
<eci>05</eci>
</threeds>
</payment_response>
Successful Reconcile Response Parameters
Parameter | Type | Description |
---|---|---|
transaction_type | string(255) | The transaction type |
status | string(255) | Status of the transaction, see states |
transaction_id | string(255) | Unique transaction id defined by merchant |
unique_id | string(32) | Unique id defined by gate (must later be used if capturing, voiding or refunding a transaction) |
moto | 'true' | Signifies whether a MOTO (mail order telephone order) transaction is performed. Contact tech support for more details. |
avs_response_code | string(255) | Generated by the card network on trying to match the billing address when performing the address verification. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
avs_response_text | string(255) | Gives the human response text for the AVS response code above. Optional, returned if config is enabled and acquirer supports it. Check AVS Status Codes for details. |
cvv_result_code | string(1) | Card Verification Value response code. Optional, returned only if acquirer supports it |
authorization_code | string(6) | Generated by the card network when an authorisation has occurred, used to identify that auth. Consists of 6 alphanumeric chars |
retrieval_reference_number | string(255) | A reference number used for tracking all messages related to a given cardholder transaction returned by some acquirers. |
response_code | string(2) | Defines the result of a transaction with the acquirer, the status of a message or some action taken or required. Contact tech-support@emerchantpay.com for more details. |
mode | string(4) | Mode of the transaction’s terminal, can be test or live |
timestamp | string(255) | Time when the transaction was processed in ISO 8601 Combined date and time e.g. 2007-08- 30T17:46:11Z |
descriptor | string(255) | Static descriptor MID info as configured on the gateway |
amount | integer | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | string(255) | Currency code in ISO 4217 |
partial_approval | string(4) | Optional, set to ’true’ if partial approval happened. Partially approved amount is then in the amount field. Check Partial Approvals for details |
sent_to_acquirer | string(255) | "true" or "false" |
threeds | ||
authentication_flow | string(255) | Identifies the concrete authentication flow of the 3DS transaction that it has gone through. It will be included only if the transaction reaches the final state. The possible values for 3DSv2 are frictionless, challenge. |
threeds_method | ||
status | string(255) | Identifies the current status of 3DSv2-Method. The possible values are required, in_progress, completed. |
protocol | ||
target_version | integer | Identifies the requested version of the 3DS authentication protocol to be used. The possible values are 2. |
concrete_version | integer | Identifies the concrete version of the 3DS authentication protocol that the transaction has been processed through. The possible values are 2. |
eci | string(2) | See Electronic Commerce Indicator for details |
Notification
Once the transaction reaches final state, a notification will be sent to the notification_url
submitted in the
initial transaction request. For more information, go to Asynchronous Transactions and Notifications.
Approved Notification Example for challenge flow with 3DS-Method
?transaction_id=119643250547501c79d8295
&unique_id=44177a21403427eb96664a6d7e5d5d48
&transaction_type=sale3d
&terminal_token=394f2ebc3646d3c017fa1e1cbc4a1e20
&status=approved
&amount=100
&signature=088e16a1019277b15d58faf0541e11910eb756f6
&eci=05
&avs_response_code=5I
&avs_response_text=Response+provided+by+issuer+processor%3B+Address+information+not+verified
&cvv_result_code=M
&authorization_code=005645
&retrieval_reference_number=016813015184
&payment_account_reference=50019P9LBXOLHN9G7QMU5VN520YSY
&scheme_transaction_link_id=TLINKIDENTIFIER4521412
&scheme_pan_indicator=V
&scheme_pan_tail=0013
&scheme_max_settlement_date=2024-07-31
&scheme_authentication_data_quality=true
&threeds_authentication_flow=challenge
&threeds_method_status=completed
&threeds_target_protocol_version=2
&threeds_concrete_protocol_version=2
&threeds_protocol_sub_version=2
Declined Notification Example for challenge flow with 3DS-Method
?transaction_id=119643250547501c79d8295
&unique_id=44177a21403427eb96664a6d7e5d5d48
&transaction_type=sale3d
&terminal_token=394f2ebc3646d3c017fa1e1cbc4a1e20
&status=declined
&amount=100
&signature=088e16a1019277b15d58faf0541e11910eb756f6
&eci=05
&avs_response_code=5I
&avs_response_text=Response+provided+by+issuer+processor%3B+Address+information+not+verified
&cvv_result_code=M
&authorization_code=005645
&retrieval_reference_number=016813015184
&payment_account_reference=50019P9LBXOLHN9G7QMU5VN520YSY
&scheme_transaction_link_id=TLINKIDENTIFIER4521412
&scheme_pan_indicator=V
&scheme_pan_tail=0013
&scheme_max_settlement_date=2024-07-31
&scheme_authentication_data_quality=true
&threeds_authentication_flow=challenge
&threeds_method_status=completed
&threeds_target_protocol_version=2
&threeds_concrete_protocol_version=2
&threeds_protocol_sub_version=2
3DS Attributes
Name | Type | Description |
---|---|---|
threeds_authentication_flow | string | Identifies the concrete 3DS authentication flow that the transaction has gone through. It will be available in the notification only if the consumer has finished the 3DS authentication with the issuer. The available values for 3DSv2 are frictionless and challenge. |
threeds_method_status | string | Identifies the status of the 3DS-Method in the scope of 3DSv2 authentication protocol. The possible values are required, in_progress and completed. |
threeds_target_protocol_version | string(1) | Identifies the 3DS protocol that has been enforced. The possible values are 2. |
threeds_concrete_protocol_version | string(1) | Identifies the concrete 3DS protocol version that the transaction has gone through. The possible values are 2. |
threeds_protocol_sub_version | string(1) | Identifies the 3DS protocol sub-version that the transaction has gone through. The possible values are 1, 2, 3, 4, 5, 6, 7, 8, 9. |
threeds_authentication_status_reason_code | string(2) | See Status Reason Code for details. |
Status Reason Code
The authentication status reason code is a predefined code as per the EMVCo specification and provides further information about the reason for the failed/declined 3DS authentication or the error that has occurred while trying to authenticate the cardholder.
Code | Description |
---|---|
01 | Card authentication failed |
02 | Unknown Device |
03 | Unsupported Device |
04 | Exceeds authentication frequency limit |
05 | Expired card |
06 | Invalid card number |
07 | Invalid transaction |
08 | No Card record |
09 | Security failure |
10 | Stolen card |
11 | Suspected fraud |
12 | Transaction not permitted to cardholder |
13 | Cardholder not enrolled in service |
14 | Transaction timed out at the ACS |
15 | Low confidence |
16 | Medium confidence For 01-PA, required if the Transaction Status field = N, U, or R. For 02-NPA, Conditional asdefined by the DS. |
17 | High confidence |
18 | Very High confidence |
19 | Exceeds ACS maximum challenges |
20 | Non-Payment transaction not supported |
21 | 3RI transaction not supported |
22 | ACS technical issue |
23 | Decoupled Authentication required by ACS but not requested by 3DS Requestor |
24 | 3DS Requestor Decoupled Max Expiry Time exceeded |
25 | Decoupled Authentication was provided insufficient time to authenticate cardholder. ACS will not make attempt |
26 | Authentication attempted but not performed by the cardholder |
27–79 | Reserved for EMVCo future use (values invalid until defined by EMVCo) |
87 | Transaction is excluded from Attempts Processing (includes non-reloadable pre-paid cards and Non-Payments (NPA)) (Visa only) |
Testing
Scenario | 3DSecure Method | 3DSecure Challenge | Result | Card Number | Note |
---|---|---|---|---|---|
Frictionless | - | - | Authenticated | 4012000000060085 | |
Frictionless | - | - | Authenticated | 4901170000000003 | |
Frictionless | - | - | Authenticated | 4901164281364345 | |
Frictionless | - | - | Authenticated | 4378510000000004 | |
Frictionless | - | - | Attempted | 4456530000001005 | |
Frictionless | - | - | Attempted | 5200000000001054 | |
Frictionless | Y | - | Authenticated | 4066330000000004 | |
Frictionless | Y | - | Authenticated | 5200000000001021 | |
Low risk exemption accepted (MasterCard) | - | - | Authenticated | 5169750000001111 | Used only for synchronous 3DS workflow. |
Low risk exemption accepted (Visa) | - | - | Authenticated | 4378510000000004 | Used only for synchronous 3DS workflow. |
Frictionless | - | - | Not authenticated | 4111110000000922 | |
Frictionless | - | - | Not authenticated | 5200000000001047 | |
Frictionless | Y | - | Not authenticated | 4111112232423922 | |
Challenge | - | Y | Choose Challenge result | 4918190000000002 | |
Challenge | - | Y | Choose Challenge result | 5433300000000133 | |
Challenge | Y | Y | Choose Challenge result | 4938730000000001 | |
Challenge | Y | Y | Choose Challenge result | 5200000000001005 |
Authentication Services
Introduction
Authentication Services provide Strong Customer Authentication (SCA) which is a type of authentication relying on two or more independent elements.
SCA as defined by the European Central Bank (ECB) and in the context of the EU’s Payment Services Directive (PSD2) is:
”a procedure based on the use of two or more of the following elements categorised as knowledge, ownership and inherence:
something only the user knows, e.g. static password, code, personal identification number;
something only the user possesses, e.g.token, smart card, mobile phone;
something the user is, e.g. biometric characteristic, such as a fingerprint.
In addition, the elements selected must be mutually independent, i.e. the breach of one does not compromise the other(s).
At least one of the elements should be non-reusable and non-replicable (except for inherence), and not capable of being surreptitiously stolen via the Internet.
The strong authentication procedure should be designed in such a way as to protect the confidentiality of the authentication data.”
Using multiple solutions from the same category would not constitute SCA.
SCA with 3DSecure
Only the newest variant of 3DSecure involving one-time passwords (OTP) constitutes a form of SCA.
3DSecure however might be a weak SCA solution for several reasons:
it relies on the cards being actively enrolled by the cardholder after issuing, i.e prior any transaction made with it and
it is not available on all card schemes.
Alternative services
A number of services exist that provide SCA in a compliant way.
They rely on different solutions like generating payment ”secrets”, one-time passwords etc. Key advantage of such services is that they allow cards to be enrolled ”on-the-fly”, i.e. during a transaction rather than having to be pre-enrolled after issuing.
Such services could potentially work with any card and are thus card scheme agnostic.
Genesis KYC Services
General Info
Genesis KYC Services gives us the ability to perform particular checks on the integrity of the consumer data. Based on the returned consumer score we can decide whether we want to reject/approve a given transaction or perform another action for this consumer.
Create Consumer Registration
Review all aspects of the customer’s information, as it is received in the registration process, against local and external databases to increase accuracy and produce a risk score for that customer.
POST /api/v1/create_consumer
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.kyc.emerchantpay.net/api/v1/create_consumer \
-X POST \
-H "Content-Type: application/json" \
-d '
{
"customer_information": {
"first_name": "John",
"last_name": "Doe",
"customer_email": "jdoe@example.com",
"address1": "Sample Address",
"address2": "4th floor",
"city": "MyCity",
"zip_code": "32132",
"country": "BG",
"province": "ProvinceName",
"phone1": "0883113332",
"phone2": "0883113334",
"birth_date": "1987-03-03",
"document_number": "f2345838972",
"document_type": 3,
"gender": "M"
},
"customer_unique_id": "21343253",
"customer_registration_date": "2016-12-12",
"customer_registration_ip_address": "255.255.255.255",
"customer_username": "dimo16",
"customer_registration_device_id": "12343242",
"third_party_device_id": "3432424",
"profile_action_type": 1,
"device_fingerprint_type": 1,
"current_profile_status": 1,
"bonus_code": "1922",
"bonus_amount": 100,
"merchant_website": "dai.com",
"how_did_you_hear": "friend",
"affiliate_id": "1922"
}'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
session_id | optional | string | If this value is not provided the user email account should be complete and valid |
customer_information | required | object | Customer information. See below for each of the nested required fields |
customer_username | optional | string | Username of the customer on your system |
customer_unique_id | required | string | Unique user identificator on your system |
customer_registration_date | required | string | Date in which the customer was registered in the system OR the date in which the customer was created in the cashier Database yyyy-mm-dd |
customer_registration_ip_address | required | string | IP address of customer used when the customer was registered in the system OR the current IP address |
customer_registration_device_id | optional | string | Propietary DeviceId technology, refer to the DeviceId Instruction Manual (provided on request) |
third_party_device_id | optional | string | Third Party DeviceId |
device_fingerprint | optional | string | Open Source DeviceId technologies (Interpreted as a String) |
device_fingerprint_type | optional | enum | 1 - Custom; 2 - Open Source; 3 - Open Source 2; |
profile_action_type | optional | enum | 1 - Registration;2 - Profile Update; |
profile_current_status | optional | enum | 0 - Undefined;1 - Review;2 - Denied;3 - Approved; |
bonus_code | optional | string | Open text variable. Represents the code entered by the customer |
bonus_submission_date | optional | string | |
bonus_amount | optional | number | |
merchant_website | optional | string | Website URL of the merchant initiating the wallet transfer |
industry_type | optional | string | 1 - Finance; 2 - Gambling; 3 - Crypto; 4 - Travel; 5 - Retail; 6 - Risk Vendor; 7 - Adult; 8 - Remittance/Transfer; 9 - Other; |
how_did_you_hear | optional | string | |
affiliate_id | optional | string | |
rule_context | optional | number | Number assigned to a given rule context. Please contact to get the available contexts |
required* = conditionally required
Customer Information Fields
The fields of the customer information object.
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
first_name | required | string | Customer first name |
middle_name | optional | string | |
last_name | required | string | Customer last name |
customer_email | required | string | Must contain valid e-mail of customer |
address1 | required | string | Primary address |
address2 | optional | string | Secondary address |
city | required | string | City |
province | required | string | |
zip_code | required | string | ZIP code |
country | required | string | two-letter iso codes |
phone1 | optional | number | |
phone2 | optional | number | |
birth_date | optional | string | Required for Visa only when MCC is a Financial Services one (e.g. MCC 6012) |
document_type | optional | enum | 0 - SSN; 1 - Passport Registry; 2 - Personal ID / National ID; 3 - Identity Card; 4 - Driver License; 8 - Travel Document; 12 - Residence Permit; 13 - Identity Certificate; 16 - Registro Federal de Contribuyentes; 17 - Credencial de Elector; 18 - CPF |
document_number | optional | string | |
gender | optional | enum | F - female; M - male |
required* = conditionally required
Successful Response
{
"code": 0,
"message": "Successful Response",
"technical_message": "Successful Response",
"details": [
{
"reference_id": "233",
"risk_score": 98,
"kyc_provider_recommendation": "Reject",
"rules_triggered": [
{
"name": "Multi-Accounting : IP shared to Chargeback reason",
"risk_score": "100.00",
"display_to_merchant": 1
}
],
"scrubber_results": {
"geo_check": "",
"address_verification": "",
"phone_verify": "",
"idv_usa": "",
"idv_global": "",
"gav": "",
"idv_br": "",
"bav_usa": "",
"bav_advanced": "",
"cb_aml": "",
"cb_bvs": "",
"email_age": "",
"compliance_watchlist": "",
"iovation": "",
"idv_advance": ""
},
"result_confidence_level": 91.5
}
]
}
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
code | number | genesis success code - 0 |
message | string | const ’Successful Response’ |
technical_message | string | const ’Successful Response’ |
details | ||
reference_id | string | KYC provider internal id |
risk_score | number | risk score low is better |
kyc_provider_recommendation | string | KYC service provider recommendation |
result_confidence_level | number | Confidence level in percentages |
... | string | additional response data |
Update Consumer Registration
Update the customer registration to be able to pass on the latest status required so we can continue improving the data models and provide the best scores and recommendations possible.
POST /api/v1/update_consumer
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.kyc.emerchantpay.net/api/v1/update_consumer \
-X POST \
-H "Content-Type: application/json" \
-d '
{
"reference_id": "9999333344443",
"profile_current_status": 2,
"status_reason": "Reject"
}'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
reference_id | required | number | Unique id returned by corresponding transaction |
profile_current_status | required | enum | 0 - Undefined; 1 - Review; 2 - Denied; 3 - Approved; |
status_reason | optional | string | Required only if status is Reject / Decline / Chargeback / Refund / Return / Void |
required* = conditionally required
Make sure that reference_id
points to a preliminary created transaction (will describe transactions below).
Successful Response
{
"code": 0,
"message": "Successful Response",
"technical_message": "Successful Response",
"details": [
{
"reference_id": "9999333344443"
}
]
}
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
code | number | genesis success code - 0 |
message | string | const ’Successful Response’ |
technical_message | string | const ’Successful Response’ |
details | ||
reference_id | string | KYC provider internal id |
Create Transaction
Implement this to scrub a new transaction. We will take the information specific to that transaction and run various verification checks available, returning the recommendation, score, and third-party verification scrubbing results.
POST /api/v1/create_transaction
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.kyc.emerchantpay.net/api/v1/create_transaction \
-X POST \
-H "Content-Type: application/json" \
-d '
{
"customer_information": {
"first_name": "John",
"last_name": "Doe",
"customer_email": "jdoe@example.com",
"address1": "Sample address",
"city": "Paris",
"zip_code": "666",
"country": "FR",
"province": "MyProvince"
},
"deposit_limits": {
"payment_method": "CC"
},
"transaction_unique_id": "1332",
"payment_details": {
"bin": "411111",
"tail": "1111"
},
"customer_ip_address": "255.255.255.255",
"transaction_created_at": "2016-12-12 23:23:23",
"currency": "USD",
"amount": 99999
}'
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.kyc.emerchantpay.net/api/v1/create_transaction \
-X POST \
-H "Content-Type: application/json" \
-d '
{
"customer_information": {
"first_name": "John",
"last_name": "Doe",
"customer_email": "jdoe@example.com",
"address1": "Sample address",
"city": "Paris",
"zip_code": "666",
"country": "FR",
"province": "MyProvince"
},
"deposit_limits": {
"payment_method": "CC"
},
"transaction_unique_id": "1332",
"payment_details": {
"ewallet_id": "test@example.com"
},
"customer_ip_address": "255.255.255.255",
"transaction_created_at": "2016-12-12 23:23:23",
"currency": "USD",
"amount": 99999
}'
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.kyc.emerchantpay.net/api/v1/create_transaction \
-X POST \
-H "Content-Type: application/json" \
-d '
{
"customer_information": {
"first_name": "John",
"last_name": "Doe",
"customer_email": "jdoe@example.com",
"address1": "Sample address",
"city": "Paris",
"zip_code": "666",
"country": "FR",
"province": "MyProvince"
},
"deposit_limits": {
"payment_method": "CC"
},
"transaction_unique_id": "1332",
"payment_details": {
"bin": "411111",
"tail": "1111",
"cvv_present": "YES"
},
"customer_ip_address": "255.255.255.255",
"transaction_created_at": "2016-12-12 23:23:23",
"currency": "USD",
"amount": 99999
}'
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.kyc.emerchantpay.net/api/v1/create_transaction \
-X POST \
-H "Content-Type: application/json" \
-d '
{
"customer_information": {
"first_name": "John",
"last_name": "Doe",
"customer_email": "jdoe@example.com",
"address1": "Sample address",
"city": "Paris",
"zip_code": "666",
"country": "FR",
"province": "MyProvince"
},
"deposit_limits": {
"payment_method": "EC"
},
"transaction_unique_id": "1332",
"payment_details": {
"routing": "1912",
"account": "0000012345123451234500000"
},
"customer_ip_address": "255.255.255.255",
"transaction_created_at": "2016-12-12 23:23:23",
"currency": "USD",
"amount": 99999
}'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
session_id | optional | string | If this value is not provided the user email account should be complete and valid |
customer_username | optional | string | Username of the customer on your system |
customer_unique_id | optional | string | Unique user identificator on your system |
customer_status | optional | string | Current status of the customer account in your system |
customer_loyalty_level | optional | string | Customer loyalty level; for example: VIP; Bronze; Platinum; Gold; etc. This is an open text variable |
customer_registration_date | optional | string | Date in which the customer was registered in the system OR the date in which the customer was created in the cashier Database yyyy-mm-dd |
customer_registration_ip_address | optional | string | IP address of customer used when the customer was registered in the system OR the current IP address |
customer_registration_device_id | optional | string | Propietary DeviceId technology, refer to the DeviceId Instruction Manual (provided on request) |
customer_information | required | object | Customer information. See below for each of the nested required fields |
first_deposit_date | optional | string | Empty if first deposit yyyy-mm-dd |
first_withdrawal_date | optional | string | Empty if 0 withdrawals yyyy-mm-dd |
deposits_count | optional | number | |
withdrawals_count | optional | number | |
current_balance | optional | number | |
deposit_limits | required | object | See below |
transaction_unique_id | required | string | Transaction id |
billing_information | optional | object | See below |
shipping_information | optional | object | See below |
payment_details | required | object | See below |
amount | optional | number | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | optional | string | ISO 4217 Three digits |
transaction_created_at | required | string | Represents the time of the transaction on the Merchant server. Format: yyyy-mmdd hh:mm:ss |
transaction_status | optional | enum | Transaction status; it is recommended to send 0 on the initial call. Afterwards call Update Transaction endpoint to update the status. 0 - numberUndefined; 1 - number- Approved; 2 - number- Pre-Auth; 3 - number- Settled; 4 - number- Void; 5 - number- Rejected internally by Negative Database or other scrubber decided to reject the transaction; 6 - number- Declined the bank / gateway / processor rejected the transaction; 7 - number- Chargeback; 8 - number- Return;9 - number- Pending; 10 - number- Pass Transaction validation;11 - number- Failed Transaction validation; 12 - number- efund; 13 - number- Approved Review; 14 - number- Abandon This status is used when the user just leaves the transaction; |
customer_ip_address | required | string | Customers IP address |
customer_device_id | optional | string | Propietary DeviceId technology; refer to the DeviceId Instruction Manual (provided on request) |
third_party_device_id | optional | string | Third Party DeviceId |
device_fingerprint | optional | string | Open Source DeviceId technologies (Interpreted as a String) |
device_fingerprint_type | optional | enum | 1 - Custom; 2 - Open Source; 3 - Open Source 2; |
shopping_cart_items_count | optional | number | Represents the quantity of items in the shopping cart |
local_time | optional | string | Represents the local time of the customer doing the transaction. Format: yyyy-mmdd hh:mm:ss |
order_source | optional | enum | internet; mobile; inhouse |
merchant_website | optional | string | Open text variable; it represents the website name or URL that submitted the transaction |
industry_type | optional | enum | Definition of the industry type the transaction was performed on; 1-number - Finance; 2-number - Gambling; 3-number - Crypto; -number - Travel; 5-number - Retail; 6-number - Risk Vendor; 7-number - Adult; 8-number - Remittance/Transfer; 9-number - Other; |
customer_password | optional | string | Open text variable; it represents the customers password in hashed format (using MD5) some companies share that information in order to look for patterns |
rule_context | optional | number | Number assigned to a given rule context. Please contact to get the available contexts. |
custom_variable | optional | string | Represents anything the merchant wants to store with this transaction |
required* = conditionally required
Deposit Limits Fields
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
payment_method | required | enum | CC; EC - CreditCard; Echeck |
minimum | optional | number | Lowest valid amount for deposit in minor currency units; ex: 100 = $1 |
daily_maximum | optional | number | In minor currency units |
weekly_maximum | optional | string | In minor currency units |
monthly_maximum | optional | string | In minor currency units |
required* = conditionally required
Billing Information Fields
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
first_name | optional | string | Customer first name |
last_name | optional | string | Customer last name |
customer_email | optional | string | Must contain valid e-mail of customer |
address1 | optional | string | Primary address |
address2 | optional | string | Secondary address |
city | optional | string | City |
province | optional | string | |
zip_code | optional | string | ZIP code |
country | optional | string | ISO 3166-1 Alpha-2. For example: USD |
phone1 | optional | number | Numbers only; no dash or any other separator. Please include area code if applicable. Country code is not required |
birth_date | optional | string | yyyy-mm-dd |
gender | optional | enum | M; F |
required* = conditionally required
Shipping Information Fields
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
first_name | optional | string | Customer first name |
last_name | optional | string | Customer last name |
customer_email | optional | string | Must contain valid e-mail of customer |
address1 | optional | string | Primary address |
address2 | optional | string | Secondary address |
city | optional | string | City |
province | optional | string | |
zip_code | optional | string | ZIP code |
country | optional | string | ISO 3166-1 Alpha-2. For example: USD |
phone1 | optional | number | Numbers only; no dash or any other separator. Please include area code if applicable. Country code is not required |
required* = conditionally required
Payment Details Fields
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
bin | optional | string | First 6 digits of the card number; Only required if Payment Method Type is Credit Card; |
tail | optional | string | Last 4 digits of the card number; Only required if Payment Method Type is Credit Card; |
cvv_present | optional | string | Indicator if the CVV was received or not; The expected values in this field are Yes or No; |
hashed_pan | optional | string | Only required if Payment Method Type is Credit Card; It should be hashed using SHA256; the string to be hashed is Card Number and the MD5 hash of the Expiration Date; For example; if the card number is 1111-2222-3333-4444 with expiration date 01/22; The have should be done on the string without spaces nor dash nor other special chars; The MD5 of the Expiration Date 0122 is f0f4b6598f2cee45644673998b4f44be; That said; the string to be hashed is 1111222233334444f0f4b6598f2cee45644673998b4f44be which generates the following result fecd244b7d647b0db391e35910e0d42aaf88f7633a4f4f4883b109abad1d6d7 |
routing | optional | string | Routing number; Only required if Payment Method Type is eCheck; |
account | optional | string | Only numbers up to 30 digits; Only required if Payment Method Type is eCheck; |
ewallet_id | optional | string | Most of the times its an email; Only required if Payment Method Type is eWallet; |
required* = conditionally required
- For payment method CC
- bin
- tail
- For payment method CC OPTIONAL
- cvv_present
- hashed_pan
- For payment method EC
- routing
- account
Successful Response
{
"code": 0,
"message": "Successful Response",
"technical_message": "Successful Response",
"details": [
{
"reference_id": "481119",
"kyc_provider_recommendation": "Approve",
"risk_score": 0.39,
"third_party": "",
"processors": "",
"reason": "",
"result_confidence_level": 91.5,
"rules_triggered": [
{
"name": "Address Verification : Global 25",
"score": "0",
"display_to_merchant": 1
}
],
"bin_information": {
"bank_name": "BANCO NACIONAL DE COSTA RICA",
"bank_location": "COSTA RICA",
"card_type": "STANDARD",
"card_level": "DEBIT",
"iso_card_country": "CR",
"card_brand_db": "MASTERCARD",
"card_brand_script": "MASTERCARD"
},
"scrubber_results": {
"geo_check": "",
"address_verification": "",
"phone_verify": "",
"idv_usa": "",
"idv_global": "",
"gav": "",
"idv_br": "",
"bav_usa": "",
"bav_advanced": "",
"cb_aml": "",
"cb_bvs": "",
"email_age": "",
"compliance_watchlist": "",
"iovation": "",
"idv_advance": ""
}
}
]
}
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
code | number | genesis success code - 0 |
message | string | const ’Successful Response’ |
technical_message | string | const ’Successful Response’ |
details | ||
reference_id | string | KYC provider internal id |
kyc_provider_recommendation | string | KYC provider recommendation |
risk_score | number | risk score low is better |
result_confidence_level | number | KYC service level of decision confidence |
... | * | KYC provider additional data |
Update Transaction
Utilize this method to update a particular transaction status so we can continue improving the data models and provide the best scores and recommendations.
POST /api/v1/update_transaction
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.kyc.emerchantpay.net/api/v1/update_transaction \
-X POST \
-H "Content-Type: application/json" \
-d '
{
"transaction_status": 1,
"reference_id": "4454982",
"reason": "a reason message",
"transaction_unique_id": "1332",
"cvv_check_result": "",
"avs_check_result": "",
"processor_identifier": ""
}'
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.kyc.emerchantpay.net/api/v1/update_transaction \
-X POST \
-H "Content-Type: application/json" \
-d '
{
"transaction_status": 2,
"transaction_unique_id": "1332"
}'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
session_id | optional | string | If this value is not provided the user email account should be complete and valid |
transaction_unique_id | required | string | Transaction id |
reference_id | optional | number | Required only if status is Reject / Decline / Chargeback / Refund / Return / Void |
transaction_status | optional | enum (number) | 1-Approved; 2-Pre-Auth; 3-Settled; 4-Void; 5-Rejected internally by Negative Database or other scrubber decided to reject the transaction; 6-Declined the bank / gateway / processor rejected the transaction; 7-Chargeback; 8-Return; 9-Pending; 10-Pass Transaction validation; 11-Failed transaction validation; 12-Refund; 13-Approved Review; 14-Abandon This status is used when the user just leaves the transaction; |
reason | optional | string | Required only if status is Reject / Decline / Chargeback / Refund / Return / Void |
cvv_check_result | optional | string | Response from processor regarding CVV check |
avs_check_result | optional | string | Result from processor regarding AVS check |
processor_identifier | optional | string | Unique identifier of the processor attempted |
required* = conditionally required
Successful Response
{
"code": 0,
"message": "Successful Response",
"technical_message": "Successful Response",
"details": [
{
"reference_id": "481119"
}
]
}
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
code | number | genesis success code - 0 |
message | string | const ’Successful Response’ |
technical_message | string | const ’Successful Response’ |
details | ||
reference_id | string | KYC provider internal id |
Identity Document Upload
Used to verify documents provided by the customer.
When called this action returns the following:
- An instant response with a reference id and additional keys by which the particular query could be addressed.
- Async responses with answers from the performed checks (OCR, manual, etc.). Usually, this responses arrive after 5-7 minutes. The notification url is agreed on environment basis. Create a new transaction for the particular user before making a call of this kind.
POST /api/v1/upload_document
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.kyc.emerchantpay.net/api/v1/upload_document \
-X POST \
-H "Content-Type: application/json" \
-d '
{
"transaction_unique_id": "1332",
"doc": {
"mime_type": "image/jpeg",
"base64_content": "{base_64_endcoded_content}"
}
}'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
customer_username | optional | string | Username of the customer on your system |
customer_unique_id | optional | string | Unique user identificator on your system |
transaction_unique_id | required* | string | Unique Transaction Id with info of the customer to be verified. Please note; if Transaction Id and Customer Registration Id are provided the system will use the Transaction Id. Please provide the Transaction Id or the Customer Registration Id; one of them must be provided |
reference_id | required* | string | Unique Customer Registration Id with info of the customer to be verified |
method | required | enum (number) | 1 - Manual; 2 - OCR; 3 - Both; |
doc | required | object | see below |
doc2; doc3; doc4 | optional | object | additional document images |
required* = conditionally required
One of transaction_unique_id
and reference_id
fields is required.
Document Fields
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
base64_content | required | string | |
mime_type | required | string |
required* = conditionally required
Successful Response
{
"code": 0,
"message": "Successful Response",
"technical_message": "Successful Response",
"details": [
{
"kyc_source": "OCR",
"reference_id": "382"
},
{
"kyc_source": "Semi-manual",
"reference_id": "129"
}
],
"doc": "51f7e411cd1202e040b21655738beb89",
"doc2": "b0139d3fb1785c1e57ac5a6b054692eb",
"doc3": "e0059153192876ce8ab36d8cd8ab1bca"
}
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
code | number | genesis success code - 0 |
message | string | const ’Successful Response’ |
technical_message | string | const ’Successful Response’ |
details | ||
kyc_source | string | KYC service name triggered for verification |
reference_id | string | id used for reference when verification result is received |
Identity Document Download
Uploaded documents will be stored by legal provisions and they can be requested for review. Just post a JSON body with the identity document id of the given document and a response with the filename and the base64 encoded content of that file would be returned.
POST /api/v1/download_document
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.kyc.emerchantpay.net/api/v1/download_document \
-X POST \
-H "Content-Type: application/json" \
-d '
{
"identity_document_id": "676a053b16781e43db7e75dcb1444ef8"
}'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
identity_document_id | required | string | document id |
required* = conditionally required
Successful Response
{
"code": 0,
"message": "Successful Response",
"technical_message": "Successful Response",
"details": [
{
"document": {
"file_name": "430d595c22dbae26ef39ed91c3aabb49.jpg",
"base64_content": "{base_64_endcoded_content}"
}
}
]
}
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
code | number | genesis success code - 0 |
message | string | const ’Successful Response’ |
technical_message | string | const ’Successful Response’ |
details | ||
file_name | string | file name |
base64_content | string | base64 encoded document content |
Make call
This method is used to make a call or send an SMS to a given phone number. This method is used to complement the verification process. The system will make a call and dictates the verification code to be typed in the website. The following is a transcript of the voice message the system will use when en-US is used as language:
The following is an example of the SMS text the system will use when en-US is used as language:
POST /api/v1/create_authentication
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.kyc.emerchantpay.net/api/v1/create_authentication \
-X POST \
-H "Content-Type: application/json" \
-d '
{
"customer_username": "896342",
"customer_unique_id": "2",
"transaction_unique_id": "387783428790324",
"customer_phone_number": "372489879342",
"service_language": "bg",
"security_code": "3423",
"service_type": 1
}'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
customer_username | optional | string | Username of the customer on your system |
customer_unique_id | optional | string | Unique user identificator on your system |
transaction_unique_id | required | string | Transaction identification in the merchants system; If not provided the system won't be able to link with the transaction that is being verified |
customer_phone_number | required | string | Phone number to call; It must be complete country code + phone number; No dashes; For example: 50622560000 |
service_language | required | string | a string value; See below |
security_code | required | string | Numeric value - 4 digits only; It cannot start with 0; The boot is going to say this numeric value so the user can type it back on the website; |
service_type | required | string | Numeric value to indicate if the system will send a text message or make a voice call; 1 for SMS; 2 for Voice call; |
required* = conditionally required
Available languages for t_language
Language | Code |
---|---|
Arabic | a |
Cantonese, Chinese/Hong Kong | zh-HK |
Catalan | ca |
Croatian | hr |
Czech | cs |
Danish | da |
Dutch | nl |
English, Australian | en-AU |
English, UK | en-GB |
English, US | en-US |
Estonian | et |
Filipino | fil |
Finnish | fi |
French | fr |
French, Canadian | fr-CA |
German | de |
Greek | el |
Hebrew | he |
Hindi | hi |
Hungarian | hu |
Icelandic | is |
Indonesian | id |
Italian | it |
Japanese | ja |
Korean | ko |
Latvian | lv |
Lingala | ln |
Lithuanian | lt |
Mandarin | zh-CN |
Norwegian | no |
Polish | pl |
Portuguese, Brazilian | pt-BR |
Portuguese, European | pt |
Romanian | ro |
Russian | ru |
Slovakian | sk |
Spanish, European | es |
Spanish, Latin American | es-419 |
Swedish | sv |
Thai | th |
Turkish | tr |
Ukrainian | uk |
Vietnamese | vi |
Successful Response
{
"code": 0,
"message": "Successful Response",
"technical_message": "Successful Response",
"details": [
{
"reference_id": "233"
}
]
}
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
code | number | genesis success code - 0 |
message | string | const ’Successful Response’ |
technical_message | string | const ’Successful Response’ |
details | ||
reference_id | string | id used for future reference |
Update call
This method is used to update the call status with the latest info received from the main system. It also updates the transaction associated with this verification call.
POST /api/v1/update_authentication
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.kyc.emerchantpay.net/api/v1/update_authentication \
-X POST \
-H "Content-Type: application/json" \
-d '
{
"reference_id": 1237834,
"security_code_input": "4322",
"verification_status": "4"
}'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
reference_id | required | string | Unique value to identify the call in back office. |
security_code_input | required | string | Transaction identification in the merchants system; If not provided the system won't be able to link with the transaction that is being verified |
verification_status | required | string | The first two values are defined by the system when the call is created; the ones accepted in this call are the status 3; 4 and 5 only 1-In Progress; 2-Failed; 3-Verification Failed; 4-Verification Successful; 5-Abandon; |
required* = conditionally required
Successful Response
{
"code": 0,
"message": "Successful Response",
"technical_message": "Successful Response",
"details": [
{
"reference_id": "233"
}
]
}
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
code | number | genesis success code - 0 |
message | string | const ’Successful Response’ |
technical_message | string | const ’Successful Response’ |
details | ||
reference_id | string | id used for future reference |
Create Verification
The verification request will provide a link that will be used to redirect the customer. The customer will provide the required documents and will be verified against them. As a result, the user will be redirected back to merchant based on the provided redirect URL.
POST /api/v1/verifications
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.kyc.emerchantpay.net/api/v1/verifications \
-X POST \
-H "Content-Type: application/json" \
-d '
{
"email": "test@email.com",
"country": "US",
"language": "EN",
"redirect_url": "https://merchant.com/from_kyc",
"reference_id": "123456",
"document_supported_types": [
"id_card",
"passport"
],
"address_supported_types": [
"id_card",
"passport"
],
"face": {
"allow_offline": true,
"allow_online": true,
"check_duplicate_request": true
},
"backside_proof_required": true,
"address_backside_proof_required": true,
"expiry_date": "2021-10-10",
"background_checks": {
"date_of_birth": "1995-10-10",
"async_update": true,
"first_name": "John",
"middle_name": "Carter",
"last_name": "Doe",
"full_name": "John Carter Doe",
"filters": [
"sanction",
"warning",
"fitness-probity",
"pep",
"pep-class-1",
"pep-class-2",
"pep-class-3",
"pep-class-4",
"adverse-media"
],
"match_score": 100
},
"document": {
"date_of_birth": "1995-10-10",
"first_name": "John",
"last_name": "Doe",
"allow_offline": false,
"allow_online": true
},
"allow_retry": true,
"verification_mode": "image_only"
}'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
required | string | User's email | |
country | optional | string | Country code in ISO 3166 |
language | optional | string | Supported Language Code. Check Supported Languages |
redirect_url | optional | string | URL where the customer is sent to after completing the verification process |
reference_id | optional | string | Unique value to identify the performed verification. Should be not less than 6 characters, and not more than 250 characters. |
document_supported_types | optional | array | Supported types of document that can be verified. Check Supported Document Types |
address_supported_types | optional | string | Supported types of address that can be verified, Check Supported Address Types |
face | Represents the options to be supplied to the service in order to provide face verification functionality | ||
allow_offline | optional | boolean | Whether uploading of previously taken picture is allowed for verification of document/face |
allow_online | optional | boolean | Whether the realtime usage of device camera is allowed for verification of document/face |
check_duplicate_request | optional | boolean | Whether to enable the duplicate account detection service |
backside_proof_required | optional | boolean | Signifies that both sides of the document are required to verify the identity |
address_backside_proof_required | optional | boolean | Signifies that both sides of the document are required to verify the address |
expiry_date | optional | yyyy-mm-dd | Document's expiry date at yyyy-mm-dd format, for example - 2025-12-31, can be a blank string. A blank string means that the user will need to enter the expiry date from the UI |
allow_retry | optional | boolean | If the parameter value is set to 'true', the customer will be able to retry if the verification request is declined by the AI. On retry, the customer can re-upload the verification proof after correcting the indicated issues. |
verification_mode | optional | string | This key specifies the types of proof that can be used for verification. Check Supported Address Types |
background_checks | optional | An AML (anti-money laundering) background check will be done based on the provided data. Please note that the name and the date of birth keys will be extracted from the document service if they are missing. | |
first_name | optional | string | Customer's first name |
middle_name | optional | string | Customer's middle name |
last_name | optional | string | Customer's last name |
full_name | optional | string | Customer's full name |
date_of_birth | optional | yyyy-mm-dd | Customer's date of birth. just, without at yyyy-mm-dd format, for example - 1990-12-31 |
async_update | optional | boolean | Will allow the system to send notifications with information about the checked person when the status has been changed. The registered asynchronous update doesn't expire and notification will be sent on each change, but not often than 15 minutes |
filters | optional | array | One or more AML Filters to query. Check AML Filters for more information |
match_score | optional | number | Minimum match score to consider the match successful. Default: 100 |
document | optional | Document represents the data used by the document verification service to check the authenticity of identity documents submitted by customers | |
first_name | optional | string | Customer's first name |
last_name | optional | string | Customer's last name |
date_of_birth | optional | yyyy-mm-dd | Customer's date of birth. just, without at yyyy-mm-dd format, for example - 1990-12-31 |
allow_offline | optional | boolean | Whether uploading of previously taken picture is allowed for verification of document/face |
allow_online | optional | boolean | Whether the realtime usage of device camera is allowed for verification of document/face |
required* = conditionally required
Successful Response
{
"code": 0,
"message": "Successful Response",
"technical_message": "Successful Response",
"status": "pending",
"verification_url": "https://app.shuftipro.com/process/kyc/code",
"reference_id": "123456"
}
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
code | number | 0 - for successful response or genesis error code, see below |
message | string | code description, ’Successful Response’ for code - 0 |
technical_message | string | ’Successful Response’, or technical error description |
status | string | Status of verification, Check Available Statuses Types |
verification_url | string | URL that should be used by end user to submit verification process |
reference_id | string | Unique value to identify the performed verification |
Supported Document Types
Supported Types |
---|
passport |
id_card |
driving_license |
credit_or_debit_card |
Supported Address Types
Supported Types |
---|
id_card |
passport |
driving_license |
utility_bill |
bank_statement |
rent_agreement |
employer_letter |
insurance_agreement |
tax_bill |
envelope |
cpr_smart_card_reader_copy |
Available Statuses
Status |
---|
pending |
error |
cancelled |
timeout |
error |
accepted |
declined |
changed |
deleted |
received |
Supported Languages
Country Name | Language Code |
---|---|
Afrikaans | AF |
Albanian | SQ |
Amharic | AM |
Arabic | AR |
Armenian | HY |
Azerbaijani | AZ |
Basque | EU |
Belarusian | BE |
Bengali | BN |
Bosnian | BS |
Bulgarian | BG |
Burmese | MY |
Catalan | CA |
Chichewa | NY |
Chinese | ZH |
Corsican | CO |
Croatian | HR |
Czech | CS |
Danish | DA |
Dutch | NL |
English | EN |
Esperanto | EO |
Estonian | ET |
Filipino | TL |
Finnish | FI |
French | FR |
Frisian | FY |
Galician | GL |
Georgian | KA |
German | DE |
Greek (modern) | EL |
Gujarati | GU |
Haitian, Haitian Creole | HT |
Hausa | HA |
Hebrew (modern) | HE |
Hindi | HI |
Hungarian | HU |
Indonesian | ID |
Irish | GA |
Igbo | IG |
Icelandic | IS |
Italian | IT |
Japanese | JA |
Javanese | JV |
Kannada | KN |
Kazakh | KK |
Khmer | KM |
Kirghiz, Kyrgyz | KY |
Korean | KO |
Kurdish | KU |
Latin | LA |
Luxembourgish, Letzeburgesch | LB |
Lao | LO |
Lithuanian | LT |
Latvian | LV |
Macedonian | MK |
Malagasy | MG |
Malay | MS |
Malayalam | ML |
Maltese | MT |
Maori | MI |
Marathi | MR |
Mongolian | MN |
Nepali | NE |
Norwegian | NO |
Punjabi | PA |
Persian | FA |
Polish | PL |
Pashto | PS |
Portuguese | PT |
Romanian | RO |
Russian | RU |
Sindhi | SD |
Samoan | SM |
Serbian | SR |
Scottish Gaelic | GD |
Shona | SN |
Sinhala | SI |
Slovak | SK |
Slovenian | SL |
Somali | SO |
Sesotho | ST |
Spanish | ES |
Sundanese | SU |
Swahili | SW |
Swedish | SV |
Tamil | TA |
Telugu | TE |
Tajik | TG |
Thai | TH |
Turkish | TR |
Ukrainian | UK |
Urdu | UR |
Uzbek | UZ |
Vietnamese | VI |
Welsh | CY |
Xhosa | XH |
Yiddish | YI |
Yoruba | YO |
Zulu | ZU |
Supported Verification Modes
Verification Modes |
---|
any |
image_only |
video_only |
AML Filters
AML Filters | Default |
---|---|
sanction | Yes |
warning | Yes |
fitness-probity | Yes |
pep | Yes |
pep-class-1 | Yes |
pep-class-2 | Yes |
pep-class-3 | Yes |
pep-class-4 | Yes |
adverse-media | Yes |
adverse-media-general | No |
adverse-media-narcotics | No |
adverse-media-fraud | No |
adverse-media-terrorism | No |
adverse-media-sexual-crime | No |
adverse-media-violent-crime | No |
adverse-media-financial-crime | No |
adverse-media-v2-other-minor | No |
adverse-media-v2-other-serious | No |
adverse-media-v2-other-financial | No |
adverse-media-v2-violence-non-aml-cft | No |
adverse-media-v2-financial-difficulty | No |
adverse-media-v2-regulatory | No |
adverse-media-v2-general-aml-cft | No |
adverse-media-v2-cybercrime | No |
adverse-media-v2-terrorism | No |
adverse-media-v2-violence-aml-cft | No |
adverse-media-v2-narcotics-aml-cft | No |
adverse-media-v2-fraud-linked | No |
adverse-media-v2-financial-aml-cft | No |
adverse-media-v2-property | No |
Verification Status
Verification status check request can be performed by reference_id. A status check may be needed if async notification has not arrived yet or when kyc notifications are not used in general.
POST /api/v1/verifications/status
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.kyc.emerchantpay.net/api/v1/verifications/status \
-X POST \
-H "Content-Type: application/json" \
-d '
{
"reference_id": "2021-01-27-14:55:22-abb6966a-a6d4-4a3a-a364-ea3347384a90"
}'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
reference_id | required | string | Unique value to identify the performed verification |
required* = conditionally required
Successful Response
{
"code": 0,
"message": "Successful Response",
"technical_message": "Successful Response",
"status": "timeout",
"reference_id": "2021-01-27-14:55:22-abb6966a-a6d4-4a3a-a364-ea3347384a90",
"proofs": {
"document": {
"proof": "https://api.shuftipro.com/storage/proof.png",
"additional_proof": "https://api.shuftipro.com/storage/additionalproof.png"
},
"access_token": "6bf8a72b18062532576b30a2da8b881bbcb1bd4727a97a439270bec90943478e"
},
"background_checks": {
"aml_filters": [
"sanction",
"pep",
"pep-class-1"
],
"aml_hits": [
{
"entity_type": "person",
"score": 33.411358,
"match_types": [
"name_exact",
"year_of_birth"
],
"sources": [
"european-union-council",
"complyadvantage-adverse-media"
],
"types": [
"adverse-media",
"pep",
"pep-class-1"
],
"name": "Boyko John Smith",
"associates": [
{
"association": "spouse",
"name": "Sue Smith"
}
]
}
]
},
"verification": {
"document_expiry_date": "2030-11-12"
}
}
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
code | number | 0 - for successful response or genesis error code, see below |
message | string | code description, ’Successful Response’ for code - 0 |
technical_message | string | ’Successful Response’, or technical error description |
status | string | Status of verification, Check Available Statuses Types |
reference_id | string | Unique value to identify the performed verification |
proofs | ||
document | ||
proof | string | Link to the proof document uploaded by the user (access_token is required to access it). |
additional_proof | string | Link to any additional proof documents uploaded by the user (access_token is required to access it). |
access_token | string | Token that must be included in POST requests to access documents from the proofs object. |
background_checks | ||
aml_filters | array | Applied AML filters |
aml_hits | ||
entity_type | string | Type of checked entry |
score | float | Compliance score |
sources | array | Sources of information |
match_types | array | Contains AML match types |
types | array | Contains AML types |
name | string | Name of checked entry |
associates | array | Information about the associates |
verification | ||
document_expiry_date | string | Expiration date of used identity document |
Verification Register
Verification register request can be performed by reference_id. A reference id registration allows you to store the reference id in Genesis and receive notifications in Genesis for it.
POST /api/v1/verifications/register
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.kyc.emerchantpay.net/api/v1/verifications/register \
-X POST \
-H "Content-Type: application/json" \
-d '
{
"reference_id": "2021-01-27-14:55:22-abb6966a-a6d4-4a3a-a364-ea3347384a90"
}'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
reference_id | required | string | Unique value to identify the performed verification |
required* = conditionally required
Successful Response
{
"code": 0,
"message": "Successful Response",
"technical_message": "Successful Response",
"reference_id": "2021-01-27-14:55:22-abb6966a-a6d4-4a3a-a364-ea3347384a90"
}
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
code | number | 0 - for successful response or genesis error code, see below |
message | string | code description, ’Successful Response’ for code - 0 |
technical_message | string | ’Successful Response’, or technical error description |
reference_id | string | Unique value to identify the performed verification |
Error Response
Error Response
{
"code": 404,
"message": "Passed attribute is invalid!",
"technical_message": "The property ’#/’ did not contain a required property of ’customer_information’"
}
Error Response
{
"code": 803,
"message": "KYC Services not configured!",
"technical_message": "KYC Services not configured for Merchant!"
}
Error Response Parameters
Parameter | Type | Description |
---|---|---|
code | number | Genesis internal error code |
message | string | Short explanation of occurred error |
technical_message | string | More detailed explanation of occurred error |
Kyc Service Notification
Since identity document verification is time consuming(can take up to 3-7 minutes) it is an asynchronous call. Notification params may vary based on the performed checks. When verification is done a notification will be sent to configured Merchant notification url with all the details of the review along with the risk score. Note that multiple notifications can be expected so please always check the Score Complete parameter as if we have multiple DocumentId Verify providers, the score will be complemented with more info as we receive the data from the KYC sources. The count of expected notifications will be declared in initial IdentityDocumentUpload response.
KYC Notification Example
?kyc_source=OCR
&reference_id=1912
&score=10
&score_complete=0
&uid=5486354658
&error_message=
&analysis_ref_uid=148871
&controls_identifier=MODEL_VALIDITY
&controls_title_msg=OK
&controls_result_msg=OK
&controls_result=OK
&controls_control_identifier=MODEL_RECOGNIZED
&controls_control_title_msg=OK
&controls_control_result_msg=OK
&controls_control_result=OK
&document_classification_id_type=V
&document_detail_emit_country=USA
&document_detail_expiration_date_day=23
&document_detail_expiration_date_month=12
&document_detail_expiration_date_year=2004
&document_detail_document_number=555123ABC
&document_detail_extra_infos_data_key=PERSONAL_NUMBER
&document_detail_extra_infos_data_value=IFLND00AMS803085
&document_detail_extra_infos_title=Personal_Number
&holder_detail_last_name=TRAVELER
&holder_detail_first_name=HAPPYPERSON
&holder_detail_nationality=GBR
&holder_detail_gender=F
&holder_detail_birth_date_day=5
&holder_detail_birth_date_month=2
&holder_detail_birth_date_year=1965
&mrz_line1=VIUSATRAVELER_HAPPYPERSON
&mrz_line2=555123ABC6GBR6502056F0412236IFLND00AMS803085
&check_report_summary_check_identifier=SUMMARY_ID_COPY
&check_report_summary_check_title_msg=OK
&check_report_summary_check_result_msg=Original_Document
&check_report_summary_check_result=OK
¬ification_type=kyc_service_execution
&signature=secure-signature
KYC Verification Request Notification Example
?reference_id=2021-01-28-09%3A47%3A50-443bc6b7-1f89-4774-a1f7-24eaf345d605
&verification_url=https%3A%2F%2Fapp.shuftipro.com%2Fprocess%2Fkyc%2FNl7Jpjbg2KIrGuWRUcAx5A7f11h8K1d4gkS1J8SUBaaIepuQ46izboRUEJDkTISq
&status=cancelled
&declined_reason
&email=john.doe1%40example.com
¬ification_type=kyc_service_execution
&additional_data=additional_data_object
&signature=secure-signature
Notification Parameters Response Parameters
Parameter | Type | Description |
---|---|---|
kyc_source | string | name of the KYC source performed the validation |
reference_id | string | Unique id for reference to document upload request |
risk_score | number | Score product of validation rules |
external_unique_id | string | Unique ID Reference from External Service Provider |
analysis_reference_id | string | UniqueID Reference from Genesis |
controls_identifier | string | List of all MAIN controls performed on the document |
... | string | Additional information related to verification process |
notification_type | string | constant value ”kyc service response” |
status | string | Status of verification, Check Available Statuses Types |
verification_url | string | URL that should be used by end user to submit verification process, receives only for ”pending” status |
string | User's email | |
declined_reason | string | Declined verification reason |
additional_data | object | Additional data information related to verification request notification |
signature | string | the signature of the notification, should be used to verify the the notification was sent by Genesis |
The signature is a security measure meant to ensure that the gateway is really the sender of the notification. It is generated by concatenating the reference id with your API login and generating a SHA-512 Hash (Hex) of the string:
SHA-512 Hash Hex of [reference_id][Your Merchant API login]
Notification signature examples
reference_id | API login | signature |
---|---|---|
1912 | login1 | 38b4f52584e6b1393db1503ee1ac10d10af2b39b69bfdff9828baebcec33e430e08c0013e5f3309ad5363458523084f81f21a5aad216c60933a470c9f08b8aca |
1818 | login2 | 0e40af69db1c06832fa66bc37bdd79c7a4b795810d92e50b2daaa6b8a8db9ff83524ccc3b3afbd5cb4dc99126042acb16bdf8060117acb09cad326cbe34279ee |
When receiving the notification, you are required to render an XML page containing the transaction’s reference id so that the gateway knows that you have accepted the notification. If the XML is not delivered, the notification is sent periodically as per the rules for notifications delivery.
Notification Response Response
<?xml version="1.0" encoding="UTF-8"?>
<notification_echo>
<notification_echo>reference_id</notification_echo>
</notification_echo>
CPF check
Check the status of a specific Brazilian personal's CPF number. The CPF number is provided in the request URL as a parameter.
POST /api/v1/cpf/DOCUMENT_ID
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.kyc.emerchantpay.net/api/v1/cpf/40442820135 \
-X POST \
Successful Response
{
"document_id": "40442820135",
"account_holder": "Nome do CPF 404.428.201-35",
"status": {
"code": "active",
"description": "Active"
},
"date_of_birth": "14111970"
}
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
document_id | string | individual taxpayer identification number |
account_holder | string | name of Individual |
status | ||
code | string | registration status of the individual taxpayer identification number |
description | string | description of the registration status of the individual taxpayer identification number |
date_of_birth | string | birthdate of individual, in the format DDMMYYYY |
CNPJ check
Check the status of a specific Brazilian company's CNPJ number. The CNPJ number is provided in the request URL as a parameter.
POST /api/v1/cnpj/DOCUMENT_ID
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.kyc.emerchantpay.net/api/v1/cnpj/54447820000155 \
-X POST \
Successful Response
{
"document_id": "54447820000155",
"establishment_type": "Parent company",
"company_name": "OWMKX NX OIWUQD UW",
"fancy_name": "NQIHKWX BHIWD",
"register_situation": {
"code": "active",
"description": "Active",
"situation_date": "2005-11-03"
},
"legal_nature": {
"code": "2038",
"description": "GovernmentControlled Company",
"open_date": "1966-08-01"
}
}
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
document_id | string | individual taxpayer identification number |
establishment_type | string | definition of the company, parent company or subsidiary |
company_name | string | company name of the legal entity |
fancy_name | string | legal name of legal Entity |
register_situation | ||
code | string | registration status code |
description | string | description of the cadastral situation |
situation_date | string | date of the cadastral situation |
legal_nature | ||
code | string | legal nature code |
description | string | description of legal nature |
open_date | string | establishment date |
Genesis Fx Services
General Info
Genesis Fx(Forex) Services provides the ability to retrieve up-to-date Fx rates. The API is synchronous and is based on RESTFul practices. Be sure to set Content-type: application/json in your headers.
To interact with the Fx API, you need to provide login credentials using standard HTTP Basic Authentication. (credentials can be found in your Admin interface.)
Get Tiers
This call is used to return all Tiers that are related to your account.
GET /v1/fx/tiers
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/v1/fx/tiers \
-X GET \
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
[
{
"id": 1,
"name": "Tier Name",
"description": "Tier Description",
"tier_id": "Tier Identifier",
"enabled": true
}
]
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
id | number | tier id - 1 |
name | string | name of the tier |
description | string | description of the tier |
tier_id | string | identification of the tier |
enabled | boolean | state of the tier |
Get Tier
This call is used to return information about selected Tier for your merchant.
GET /v1/fx/tiers/:id
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/v1/fx/tiers/1 \
-X GET \
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
{
"id": 1,
"name": "Tier Name",
"description": "Tier Description",
"tier_id": "Tier Identifier",
"enabled": true
}
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
id | number | tier id - 1 |
name | string | name of the tier |
description | string | description of the tier |
tier_id | string | identification of the tier |
enabled | boolean | state of the tier |
Get Rates
This call is used to return all rates for Tier.
GET /v1/fx/tiers/:tier_id/rates
Note: :tier_id
is the ID of Tier, not to be mistaken with :tier_id
of the same entity.
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/v1/fx/tiers/1/rates \
-X GET \
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
[
{
"id": 2,
"source_currency": "AUD",
"target_currency": "EUR",
"trading_rate": 0.0763
}
]
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
id | number | rate id - 2 |
source_currency | string | source currency of the rate |
target_currency | string | target currency of the rate |
trading_rate | float | trading rate |
Get Rate
This call is used to return information about selected Rate for merchant.
GET /v1/fx/tiers/:tier_id/rates/:id
Note: :tier_id
is the ID of Tier, not to be mistaken with :tier_id
of the same entity.
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/v1/fx/tiers/1/rates/1 \
-X GET \
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
{
"id": 1,
"source_currency": "CHF",
"target_currency": "USD",
"trading_rate": 1.0763
}
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
id | number | rate id - 1 |
source_currency | string | source currency of the rate |
target_currency | string | target currency of the rate |
trading_rate | float | trading rate |
Search Rate
This call is used to return information about selected Rate by currency pair.
POST /v1/fx/tiers/:tier_id/rates/search
Note: :tier_id
is the ID of Tier, not to be mistaken with :tier_id
of the same entity.
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/v1/fx/tiers/:tier_id/rates/search \
-X POST \
-H "Content-Type: application/json" \
-d '
{
"source_currency": "EUR",
"target_currency": "USD"
}'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
source_currency | required | string | source currency |
target_currency | required | string | target currency |
required* = conditionally required
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
{
"id": 1,
"source_currency": "Tier Name",
"target_currency": "Tier Description",
"trading_rate": "Tier Identifier",
"enabled": null
}
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
id | number | rate id - 1 |
source_currency | string | source currency of the rate |
target_currency | string | target currency of the rate |
trading_rate | string | trading rate |
Consumers
Introduction
The Consumer entity brings Tokenization,
Transactions and Web Payment Forms (WPF) together. It
is a representation of a customer that can serve different purposes. A consumer
is identified by providing both consumer ID and email. It is explicitly
created via our Consumer API or implicitly by providing
customer_email
in either Transactions or WPF
APIs. The main purpose of consumers is to group web payment forms and payment
transactions. Using the merchant console, one can track consumers and find
high-volume ones. The other role of consumers is to provide simplified, one-step
tokenization of cardholder details. For Processing API that means securely
storing card data in exchange for a token, which can be used for future
payments. For WPF, customers can choose either to use previously stored cards or
remember a new payment method.
Consumer API
Create consumer
Creates a consumer based on email address. Optionally, one can provide billing and shipping address. Addresses will be used, if none given, in Processing or WPF APIs.
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.gate.emerchantpay.net/v1/create_consumer/ \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<create_consumer_request>
<email>consumer@email.com</email>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<shipping_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10001</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</shipping_address>
</create_consumer_request>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
required | email address | The consumer email address must be unique. If another consumer exists with this email address, the request will be rejected. | |
billing_address | optional | See Required vs Optional API params for details | |
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<create_consumer_response>
<consumer_id>123456</consumer_id>
<email>consumer@email.com</email>
<status>enabled</status>
</create_consumer_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
consumer_id | string(10) | Consumer unique reference |
email address | Consumer email address | |
status | string | Status of the consumer |
Error Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<create_consumer_response>
<status>error</status>
<code>330</code>
<technical_message>Invalid email format!</technical_message>
<message>Something went wrong, please contact support!</message>
</create_consumer_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
status | string | Status of the consumer |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
Retrieve consumer
Retrieves consumer details based on consumer id or email.
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.gate.emerchantpay.net/v1/retrieve_consumer/ \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<retrieve_consumer_request>
<consumer_id>123456</consumer_id>
</retrieve_consumer_request>'
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.gate.emerchantpay.net/v1/retrieve_consumer/ \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<retrieve_consumer_request>
<email>consumer@email.com</email>
</retrieve_consumer_request>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
consumer_id | required | string(10) | Consumer unique reference. Required if the email is not provided |
required | email address | Consumer email address. Required if the consumer_id is not provided |
required* = conditionally required
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<retrieve_consumer_response>
<consumer_id>123456</consumer_id>
<email>consumer@email.com</email>
<status>enabled</status>
</retrieve_consumer_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
consumer_id | string(10) | Consumer unique reference |
email address | Consumer email address | |
status | string | Status of the consumer |
Error Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<retrieve_consumer_response>
<status>error</status>
<code>702</code>
<technical_message>Consumer not found!</technical_message>
<message>Something went wrong, please contact support!</message>
</retrieve_consumer_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
status | string | Status of the consumer |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
Update consumer
Updates consumer email and addresses.
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.gate.emerchantpay.net/v1/update_consumer/ \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<update_consumer_request>
<consumer_id>123456</consumer_id>
<email>consumer@email.com</email>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<shipping_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10001</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</shipping_address>
</update_consumer_request>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
consumer_id | required | string(10) | Consumer unique reference |
required | email address | New email address | |
billing_address | optional | See Required vs Optional API params for details | |
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
shipping_address | optional | ||
first_name | optional | string(255) | Customer first name |
last_name | optional | string(255) | Customer last name |
address1 | optional | string(255) | Primary address |
address2 | optional | string(255) | Secondary address |
zip_code | optional | string | ZIP code |
city | optional | string(255) | City |
state | optional | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | optional | string(2) | Country code in ISO 3166 |
required* = conditionally required
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<update_consumer_response>
<consumer_id>123456</consumer_id>
<email>consumer@email.com</email>
<status>enabled</status>
</update_consumer_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
consumer_id | string(10) | Consumer unique reference |
email address | Consumer email address | |
status | string | Status of the consumer |
Error Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<update_consumer_response>
<status>error</status>
<code>702</code>
<technical_message>Consumer not found!</technical_message>
<message>Something went wrong, please contact support!</message>
</update_consumer_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
status | string | Status of the consumer |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
Disable consumer
Disable consumer from usage until further action.
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.gate.emerchantpay.net/v1/disable_consumer/ \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<disable_consumer_request>
<consumer_id>123456</consumer_id>
<email>consumer@email.com</email>
</disable_consumer_request>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
consumer_id | required | string(10) | Consumer unique reference |
required | email address | Consumer email address |
required* = conditionally required
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<disable_consumer_response>
<consumer_id>123456</consumer_id>
<email>consumer@email.com</email>
<status>disabled</status>
</disable_consumer_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
consumer_id | string(10) | Consumer unique reference |
email address | Consumer email address | |
status | string | Status of the consumer |
Error Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<disable_consumer_response>
<status>error</status>
<code>702</code>
<technical_message>Consumer not found!</technical_message>
<message>Something went wrong, please contact support!</message>
</disable_consumer_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
status | string | Status of the consumer |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
Enable consumer
Enable consumer that was disabled in the past.
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.gate.emerchantpay.net/v1/enable_consumer/ \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<enable_consumer_request>
<consumer_id>123456</consumer_id>
<email>consumer@email.com</email>
</enable_consumer_request>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
consumer_id | required | string(10) | Consumer unique reference |
required | email address | Consumer email address |
required* = conditionally required
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<enable_consumer_response>
<consumer_id>123456</consumer_id>
<email>consumer@email.com</email>
<status>enabled</status>
</enable_consumer_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
consumer_id | string(10) | Consumer unique reference |
email address | Consumer email address | |
status | string | Status of the consumer |
Error Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<enable_consumer_response>
<status>error</status>
<code>702</code>
<technical_message>Consumer not found!</technical_message>
<message>Something went wrong, please contact support!</message>
</enable_consumer_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
status | string | Status of the consumer |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
Get consumer cards
Get previously tokenized card details for a consumer.
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.gate.emerchantpay.net/v1/get_consumer_cards/ \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<get_consumer_cards_request>
<consumer_id>123456</consumer_id>
<email>consumer@email.com</email>
</get_consumer_cards_request>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
consumer_id | required | string(10) | Consumer unique reference |
required | email address | Consumer email address |
required* = conditionally required
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<get_consumer_cards_response>
<total>1</total>
<card>
<card_number>409603...0106</card_number>
<card_holder>Travis Pastrana</card_holder>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<card_brand>master</card_brand>
</card>
</get_consumer_cards_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
total | string(255) | Number of non-expired consumer cards |
card | ||
card_number | string(13..19) | Masked credit card number |
card_holder | string(255) | Full name of customer as printed on credit card (first name and last name at least) |
expiration_month | MM | Expiration month as printed on credit card |
expiration_year | YYYY | Expiration year as printed on credit card |
card_brand | string | Credit card brand |
Error Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<get_consumer_cards_response>
<status>error</status>
<code>702</code>
<technical_message>Consumer not found!</technical_message>
<message>Something went wrong, please contact support!</message>
</get_consumer_cards_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
status | string | Status of the consumer |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
Managed Recurring
Introduction
Managed Recurring provides the option to automatically schedule recurring transactions for a specific day and time. Managed Recurring is available after additional configuration.
How to use managed recurring in Processing API
Requests
Merchants can send managed recurring params in the request when creating Init Recurring Sale or Init Recurring Sale3D transactions via our Processing API.
Managed Recurring
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Recurring\InitRecurringSale');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setToken('ee946db8-d7db-4bb7-b608-b65b153e127d')
->setCardHolder('Travis Pastrana')
->setCvv('834')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
->setManagedRecurring('{"mode"=>"automatic", "interval"=>"days", "first_date"=>"2021-12-18", "time_of_day"=>5, "period"=>22, "amount"=>500, "max_count"=>10}');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.recurring.InitRecurringSale;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
InitRecurringSale request = new InitRecurringSale();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setToken("ee946db8-d7db-4bb7-b608-b65b153e127d");
request.setCardHolder("Travis Pastrana");
request.setCvv("834");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
request.setManagedRecurring("{"mode"=>"automatic", "interval"=>"days", "first_date"=>"2021-12-18", "time_of_day"=>5, "period"=>22, "amount"=>500, "max_count"=>10}");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.init_recurring_sale(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"token": "ee946db8-d7db-4bb7-b608-b65b153e127d",
"card_holder": "Travis Pastrana",
"cvv": "834",
"expiration_month": "12",
"expiration_year": 2026,
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"managed_recurring": {
"mode": "automatic",
"interval": "days",
"first_date": "2021-12-18",
"time_of_day": 5,
"period": 22,
"amount": 500,
"max_count": 10
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<token>ee946db8-d7db-4bb7-b608-b65b153e127d</token>
<card_holder>Travis Pastrana</card_holder>
<cvv>834</cvv>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<managed_recurring>
<mode>automatic</mode>
<interval>days</interval>
<first_date>2021-12-18</first_date>
<time_of_day>5</time_of_day>
<period>22</period>
<amount>500</amount>
<max_count>10</max_count>
</managed_recurring>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
managed_recurring | required | ||
mode | required | String | Fill in with 'automatic'. This indicates that the gateway will automatically manage the subsequent recurring transactions. |
interval | optional | String(6) | The interval type for the period: days or months. The default value is days |
first_date | optional | String(10) | Specifies the date of the first recurring event in the future, default value is date of creation + period. The format is ISO 8601 date format YYYY-MM-DD. |
time_of_day | optional | Integer | Specifies the UTC hour in the day for the execution of the recurring transaction, default value 0. |
period | required | Integer | Rebill period in days(30) or months(12). |
amount | optional | Integer | Amount for the recurring transactions. |
max_count | optional | Integer | Maximum number of times a recurring will occur. Omit this parameter for unlimited recurring. |
required* = conditionally required
How to use managed recurring in WPF API
Requests
Merchants can send managed recurring params in the request when creating Init Recurring Sale and Init Recurring Sale3D transactions via our WPF API.
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('WPF\Create');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setDescription('You are about to buy 3 shoes at www.shoes.com!')
->setNotificationUrl('https://www.example.com/notification')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setReturnCancelUrl('http://www.example.com/cancel.html')
->setAmount('100')
->setCurrency('USD')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
->setLifetime('60')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
// Risk Params
->setRiskUserId('123456')
// Transaction Types
->addTransactionType('transaction_type')
->setRememberCard('true');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.wpf.WPFCreateRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
WPFCreateRequest request = new WPFCreateRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setDescription("You are about to buy 3 shoes at www.shoes.com!");
request.setNotificationUrl(new URL("https://www.example.com/notification"));
request.setReturnSuccessUrl(new URL("http://www.example.com/success"));
request.setReturnFailureUrl(new URL("http://www.example.com/failure"));
request.setReturnCancelUrl(new URL("http://www.example.com/cancel.html"));
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
request.setLifetime(60);
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
// Risk Params
request.setRiskUserId("123456");
// Transaction Types
request.addTransactionType("transaction_type").done();
request.setRememberCard("true");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.wpf_create(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"description": "You are about to buy 3 shoes at www.shoes.com!",
"notification_url": "https://www.example.com/notification",
"return_success_url": "http://www.example.com/success",
"return_failure_url": "http://www.example.com/failure",
"return_cancel_url": "http://www.example.com/cancel.html",
"amount": "100",
"currency": "USD",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"lifetime": 60,
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"risk_params": {
"user_id": "123456"
},
"transaction_types": [
"transaction_type"
],
"remember_card": "true"
}
).send()
.then(success)
.catch(failure);
Request
curl https://staging.wpf.emerchantpay.net/wpf \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<wpf_payment>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<description>You are about to buy 3 shoes at www.shoes.com!</description>
<notification_url>https://www.example.com/notification</notification_url>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<return_cancel_url>http://www.example.com/cancel.html</return_cancel_url>
<amount>100</amount>
<currency>USD</currency>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<lifetime>60</lifetime>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<risk_params>
<user_id>123456</user_id>
</risk_params>
<transaction_types>
<transaction_type>
<name>init_recurring_sale</name>
<managed_recurring>
<mode>automatic</mode>
<interval>days</interval>
<first_date>2021-12-18</first_date>
<time_of_day>5</time_of_day>
<period>22</period>
<amount>500</amount>
<max_count>10</max_count>
</managed_recurring>
</transaction_type>
</transaction_types>
<remember_card>true</remember_card>
</wpf_payment>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
managed_recurring | required | ||
mode | required | String | Fill in with 'automatic'. This indicates that the gateway will automatically manage the subsequent recurring transactions. |
interval | optional | String(6) | The interval type for the period: days or months. The default value is days |
first_date | optional | String(10) | Specifies the date of the first recurring event in the future, default value is date of creation + period. The format is ISO 8601 date format YYYY-MM-DD. |
time_of_day | optional | Integer | Specifies the UTC hour in the day for the execution of the recurring transaction, default value 0. |
period | required | Integer | Rebill period in days(30) or months(12). |
amount | optional | Integer | Amount for the recurring transactions. |
max_count | optional | Integer | Maximum number of times a recurring will occur. Omit this parameter for unlimited recurring. |
required* = conditionally required
Tokenization
Introduction
Tokenization is the process of replacing sensitive cardholder data with a surrogate value ("token"). The data to be tokenized must include at least the primary account number (PAN).
Tokenization greatly reduces the sensitive data that businesses need to store, thus improving security of credit card transactions and minimizing the costs related to PCI DSS compliance.
We issue reversible non-cryptographic tokens to merchants via our Tokenization API and take care to store safely the tokenized cardholder data. Merchants are able to use the issued tokens instead of the cardholder data when creating credit card transactions via our Processing API. PCI DSS compliant merchants have also the possibility to exchange the token for the original cardholder data via our Tokenization API ("detokenization").
Tokenization API
Accepted cardholder parameters
All cardholder data parameters are accepted for tokenization - card number, cardholder, expiration year, expiration month. Please note - CVV is not accepted.
Consumer required
An enabled consumer is required in order to use this API. You have to create one or use existing, please check Consumer API.
Tokenize
Tokenizes cardholder data and issues a corresponding token. Merchants should take care to save the plain-text token value in their system as once issued it is not possible to obtain it again. Attempting to tokenize the same cardholder data will issue a new token. The token can be used in the Processing API instead of the cardholder data.
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.gate.emerchantpay.net/v1/tokenize/ \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<tokenize_request>
<consumer_id>123456</consumer_id>
<email>consumer@email.com</email>
<token_type>uuid</token_type>
<card_data>
<card_number>4200000000000000</card_number>
<card_holder>John Doe</card_holder>
<expiration_month>05</expiration_month>
<expiration_year>2026</expiration_year>
</card_data>
</tokenize_request>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
consumer_id | required | string(10) | Consumer unique reference |
required | e-mail address | Consumer e-mail address | |
token_type | required | uuid | Token type format |
card_data | required | ||
card_number | required | string(13..19) | Complete credit/debit card number of customer |
card_holder | optional | string(255) | Full name of customer as printed on credit card (first name and last name at least) |
expiration_month | optional | MM | Expiration month as printed on credit card |
expiration_year | optional | YYYY | Expiration year as printed on credit card |
required* = conditionally required
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<tokenize_response>
<status>active</status>
<token_id>34567</token_id>
<token>ee946db8-d7db-4bb7-b608-b65b153e127d</token>
<token_type>uuid</token_type>
<consumer_id>123456</consumer_id>
</tokenize_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
status | string | Status of the token |
token_id | string(32) | Unique token id |
token | string(36) | Plain-text token value |
token_type | uuid | Token type format |
consumer_id | string(10) | Consumer unique reference |
Error Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<tokenize_response>
<status>error</status>
<code>720</code>
<technical_message>Invalid token type!</technical_message>
<message>Something went wrong, please contact support!</message>
</tokenize_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
status | string | Status of the token |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
Detokenize
Exchanges the token with the tokenized cardholder data
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.gate.emerchantpay.net/v1/detokenize/ \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<detokenize_request>
<consumer_id>123456</consumer_id>
<email>consumer@email.com</email>
<token>ee946db8-d7db-4bb7-b608-b65b153e127d</token>
<token_type>uuid</token_type>
</detokenize_request>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
consumer_id | required | string(10) | Consumer unique reference |
required | e-mail address | Consumer e-mail address | |
token | required | string(36) | Plain-text token value |
token_type | required | uuid | Token type format |
required* = conditionally required
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<detokenize_response>
<status>active</status>
<token_id>34567</token_id>
<token_type>uuid</token_type>
<card_data>
<card_number>4200000000000000</card_number>
<card_holder>John Doe</card_holder>
<expiration_month>05</expiration_month>
<expiration_year>2026</expiration_year>
</card_data>
</detokenize_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
status | string | Status of the token |
token_id | string(32) | Unique token id |
token | string(36) | Plain-text token value |
token_type | uuid | Token type format |
card_data | ||
card_number | string(13..19) | Complete credit/debit card number of customer |
card_holder | string(255) | Full name of customer as printed on credit card (first name and last name at least) |
expiration_month | MM | Expiration month as printed on credit card |
expiration_year | YYYY | Expiration year as printed on credit card |
Error Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<detokenize_response>
<status>error</status>
<code>730</code>
<technical_message>Invalid token!</technical_message>
<message>Something went wrong, please contact support!</message>
</detokenize_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
status | string | Status of the token |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
Update token
Updates the tokenized data corresponding to an existing valid token.
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.gate.emerchantpay.net/v1/update_token/ \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<update_token_request>
<consumer_id>123456</consumer_id>
<email>consumer@email.com</email>
<token>ee946db8-d7db-4bb7-b608-b65b153e127d</token>
<token_type>uuid</token_type>
<card_data>
<card_number>4200000000000000</card_number>
<card_holder>John Doe</card_holder>
<expiration_month>05</expiration_month>
<expiration_year>2026</expiration_year>
</card_data>
</update_token_request>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
consumer_id | required | string(10) | Consumer unique reference |
required | e-mail address | Consumer e-mail address | |
token | required | string(36) | Plain-text token value |
token_type | required | uuid | Token type format |
card_data | required | ||
card_number | required | string(13..19) | Complete credit/debit card number of customer |
card_holder | optional | string(255) | Full name of customer as printed on credit card (first name and last name at least) |
expiration_month | optional | MM | Expiration month as printed on credit card |
expiration_year | optional | YYYY | Expiration year as printed on credit card |
required* = conditionally required
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<update_token_response>
<status>active</status>
<token>ee946db8-d7db-4bb7-b608-b65b153e127d</token>
<token_type>uuid</token_type>
</update_token_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
status | string | Status of the token |
token | string(36) | Plain-text token value |
token_type | uuid | Token type format |
Error Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<update_token_response>
<status>error</status>
<code>730</code>
<technical_message>Invalid token!</technical_message>
<update_token_response>message'</update_token_response>
</update_token_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
status | string | Status of the token |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
Validate Token
Validates if a token is active, owned by a merchant, etc.
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.gate.emerchantpay.net/v1/validate_token/ \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<validate_token_request>
<consumer_id>123456</consumer_id>
<email>consumer@email.com</email>
<token>ee946db8-d7db-4bb7-b608-b65b153e127d</token>
<token_type>uuid</token_type>
</validate_token_request>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
consumer_id | required | string(10) | Consumer unique reference |
required | e-mail address | Consumer e-mail address | |
token | required | string(36) | Plain-text token value |
token_type | required | uuid | Token type format |
required* = conditionally required
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<validate_token_response>
<status>active</status>
<token_id>34567</token_id>
<token_type>uuid</token_type>
</validate_token_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
status | string | Status of the token |
token_id | string(32) | Unique token id |
token_type | uuid | Token type format |
Error Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<validate_token_response>
<status>error</status>
<code>720</code>
<technical_message>Invalid token type!</technical_message>
<message>Something went wrong, please contact support!</message>
</validate_token_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
status | string | Status of the token |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
Delete Token
Deletes a token.
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.gate.emerchantpay.net/v1/delete_token/ \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<delete_token_request>
<consumer_id>123456</consumer_id>
<email>consumer@email.com</email>
<token>ee946db8-d7db-4bb7-b608-b65b153e127d</token>
<token_type>uuid</token_type>
</delete_token_request>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
consumer_id | required | string(10) | Consumer unique reference |
required | e-mail address | Consumer e-mail address | |
token | required | string(36) | Plain-text token value |
token_type | required | uuid | Token type format |
required* = conditionally required
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<delete_token_response>
<status>active</status>
<token_id>34567</token_id>
<token_type>uuid</token_type>
</delete_token_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
status | string | Status of the token |
token_id | string(32) | Unique token id |
token_type | uuid | Token type format |
Error Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<delete_token_response>
<status>error</status>
<code>720</code>
<technical_message>Invalid token type!</technical_message>
<message>Something went wrong, please contact support!</message>
</delete_token_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
status | string | Status of the token |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
Get card
Exchanges the token with the tokenized masked cardholder data
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.gate.emerchantpay.net/v1/get_card/ \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<get_card_request>
<consumer_id>123456</consumer_id>
<email>consumer@email.com</email>
<token>ee946db8-d7db-4bb7-b608-b65b153e127d</token>
<token_type>uuid</token_type>
</get_card_request>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
consumer_id | required | string(10) | Consumer unique reference |
required | e-mail address | Consumer e-mail address | |
token | required | string(36) | Plain-text token value |
token_type | required | uuid | Token type format |
required* = conditionally required
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<get_card_response>
<status>active</status>
<token_id>34567</token_id>
<token_type>uuid</token_type>
<card_data>
<card_number>420000...0000</card_number>
<card_holder>John Doe</card_holder>
<expiration_month>05</expiration_month>
<expiration_year>2026</expiration_year>
<card_brand>visa</card_brand>
</card_data>
</get_card_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
status | string | Status of the token |
token_id | string(32) | Unique token id |
token | string(36) | Plain-text token value |
token_type | uuid | Token type format |
card_data | ||
card_number | string(13..19) | Complete credit/debit card number of customer |
card_holder | string(255) | Full name of customer as printed on credit card (first name and last name at least) |
expiration_month | MM | Expiration month as printed on credit card |
expiration_year | YYYY | Expiration year as printed on credit card |
Error Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<detokenize_response>
<status>error</status>
<code>730</code>
<technical_message>Invalid token!</technical_message>
<message>Something went wrong, please contact support!</message>
</detokenize_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
status | string | Status of the token |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
How to tokenize cardholder data in Processing API
In order to tokenize card details you need to set the remember_card
flag to "true".
Create a Consumer
Please provide customer_email
in addition to cardholder details and the
remember_card
flag. This will create a consumer and tokenize cardholder
details. consumer_id
and token
will be returned in the response and
notification. consumer_id
will be returned in the reconcile response.
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Sale');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('4200000000000000')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
->setRememberCard('true');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.SaleRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
SaleRequest request = new SaleRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4200000000000000");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
request.setRememberCard("true");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.sale(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "4200000000000000",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"remember_card": "true"
}
).send()
.then(success)
.catch(failure);
Request
curl https://staging.gate.emerchantpay.net/process/TERMINAL_TOKEN/ \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>sale</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4200000000000000</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<remember_card>true</remember_card>
</payment_transaction>'
Use existing consumer
Please provide consumer_id
and customer_email
in addition to cardholder
details and the remember_card
flag. An existing consumer will be used, if
identified. consumer_id
and token
will be returned in the response and
notification. consumer_id
will be returned in the reconcile response.
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Sale');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('4200000000000000')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
->setRememberCard('true')
->setConsumerId('123456');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.SaleRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
SaleRequest request = new SaleRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4200000000000000");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
request.setRememberCard("true");
request.setConsumerId("123456");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.sale(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "4200000000000000",
"expiration_month": "12",
"expiration_year": 2026,
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"remember_card": "true",
"consumer_id": "123456"
}
).send()
.then(success)
.catch(failure);
Request
curl https://staging.gate.emerchantpay.net/process/TERMINAL_TOKEN/ \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>sale</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4200000000000000</card_number>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<remember_card>true</remember_card>
<consumer_id>123456</consumer_id>
</payment_transaction>'
How to use tokens in Processing API
Requests
Merchants can substitute cardholder parameters with tokens in the request when
creating credit card transactions via our Processing API. Please note: merchants
may choose to tokenize all cardholder parameters or only a subset. In the latter
case the remaining parameters would need to be provided in the request. An
enabled consumer is required to use tokens in Processing API. Please provide
consumer_id
and customer_email
along with the token
.
All Cardholder Parameters Have Been Tokenized
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Sale');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setToken('ee946db8-d7db-4bb7-b608-b65b153e127d')
->setCvv('834')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
->setConsumerId('123456');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.SaleRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
SaleRequest request = new SaleRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setToken("ee946db8-d7db-4bb7-b608-b65b153e127d");
request.setCvv("834");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
request.setConsumerId("123456");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.sale(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"token": "ee946db8-d7db-4bb7-b608-b65b153e127d",
"cvv": "834",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"consumer_id": "123456"
}
).send()
.then(success)
.catch(failure);
Request
curl https://staging.gate.emerchantpay.net/process/TERMINAL_TOKEN/ \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>sale</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<token>ee946db8-d7db-4bb7-b608-b65b153e127d</token>
<cvv>834</cvv>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<consumer_id>123456</consumer_id>
</payment_transaction>'
Only Pan Has Been Tokenized
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Sale');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setToken('ee946db8-d7db-4bb7-b608-b65b153e127d')
->setCardHolder('Travis Pastrana')
->setCvv('834')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
->setConsumerId('123456');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.SaleRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
SaleRequest request = new SaleRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setToken("ee946db8-d7db-4bb7-b608-b65b153e127d");
request.setCardHolder("Travis Pastrana");
request.setCvv("834");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
request.setConsumerId("123456");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.sale(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"token": "ee946db8-d7db-4bb7-b608-b65b153e127d",
"card_holder": "Travis Pastrana",
"cvv": "834",
"expiration_month": "12",
"expiration_year": 2026,
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"consumer_id": "123456"
}
).send()
.then(success)
.catch(failure);
Request
curl https://staging.gate.emerchantpay.net/process/TERMINAL_TOKEN/ \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>sale</transaction_type>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<token>ee946db8-d7db-4bb7-b608-b65b153e127d</token>
<card_holder>Travis Pastrana</card_holder>
<cvv>834</cvv>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<consumer_id>123456</consumer_id>
</payment_transaction>'
How to tokenize cardholder data in WPF API
In order to offer saving a payment method for future use, set the
remember_card
flag to "true".
Create a Consumer
Please provide customer_email
in addition to the remember_card
flag. This
will create a consumer and offer the user to save cardholder details
(tokenize). consumer_id
will be returned in the response and reconcile
response. consumer_id
and token
will be returned in the notification.
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('WPF\Create');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setDescription('You are about to buy 3 shoes at www.shoes.com!')
->setNotificationUrl('https://www.example.com/notification')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setReturnCancelUrl('http://www.example.com/cancel.html')
->setAmount('100')
->setCurrency('USD')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
->setLifetime('60')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
// Risk Params
->setRiskUserId('123456')
// Transaction Types
->addTransactionType('authorize')
->addTransactionType('sale')
->setRememberCard('true');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.wpf.WPFCreateRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
WPFCreateRequest request = new WPFCreateRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setDescription("You are about to buy 3 shoes at www.shoes.com!");
request.setNotificationUrl(new URL("https://www.example.com/notification"));
request.setReturnSuccessUrl(new URL("http://www.example.com/success"));
request.setReturnFailureUrl(new URL("http://www.example.com/failure"));
request.setReturnCancelUrl(new URL("http://www.example.com/cancel.html"));
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
request.setLifetime(60);
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
// Risk Params
request.setRiskUserId("123456");
// Transaction Types
request.addTransactionType("authorize").done();
request.addTransactionType("sale").done();
request.setRememberCard("true");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.wpf_create(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"description": "You are about to buy 3 shoes at www.shoes.com!",
"notification_url": "https://www.example.com/notification",
"return_success_url": "http://www.example.com/success",
"return_failure_url": "http://www.example.com/failure",
"return_cancel_url": "http://www.example.com/cancel.html",
"amount": "100",
"currency": "USD",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"lifetime": 60,
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"risk_params": {
"user_id": "123456"
},
"transaction_types": [
"authorize",
"sale"
],
"remember_card": "true"
}
).send()
.then(success)
.catch(failure);
Request
curl https://staging.wpf.emerchantpay.net/wpf \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<wpf_payment>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<description>You are about to buy 3 shoes at www.shoes.com!</description>
<notification_url>https://www.example.com/notification</notification_url>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<return_cancel_url>http://www.example.com/cancel.html</return_cancel_url>
<amount>100</amount>
<currency>USD</currency>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<lifetime>60</lifetime>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<risk_params>
<user_id>123456</user_id>
</risk_params>
<transaction_types>
<transaction_type>authorize</transaction_type>
<transaction_type>sale</transaction_type>
</transaction_types>
<remember_card>true</remember_card>
</wpf_payment>'
Use existing consumer
Please provide consumer_id
and customer_email
in addition to the
remember_card
flag. An existing consumer will be used, if identified, and
offer the user to save cardholder details (tokenize). consumer_id
will be
returned in the response and reconcile response. consumer_id
and token
will
be returned in the notification.
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('WPF\Create');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setDescription('You are about to buy 3 shoes at www.shoes.com!')
->setNotificationUrl('https://www.example.com/notification')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setReturnCancelUrl('http://www.example.com/cancel.html')
->setAmount('100')
->setCurrency('USD')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
->setLifetime('60')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
// Risk Params
->setRiskUserId('123456')
// Transaction Types
->addTransactionType('authorize')
->addTransactionType('sale')
->setRememberCard('true')
->setConsumerId('123456');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.wpf.WPFCreateRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
WPFCreateRequest request = new WPFCreateRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setDescription("You are about to buy 3 shoes at www.shoes.com!");
request.setNotificationUrl(new URL("https://www.example.com/notification"));
request.setReturnSuccessUrl(new URL("http://www.example.com/success"));
request.setReturnFailureUrl(new URL("http://www.example.com/failure"));
request.setReturnCancelUrl(new URL("http://www.example.com/cancel.html"));
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
request.setLifetime(60);
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
// Risk Params
request.setRiskUserId("123456");
// Transaction Types
request.addTransactionType("authorize").done();
request.addTransactionType("sale").done();
request.setRememberCard("true");
request.setConsumerId("123456");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.wpf_create(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"description": "You are about to buy 3 shoes at www.shoes.com!",
"notification_url": "https://www.example.com/notification",
"return_success_url": "http://www.example.com/success",
"return_failure_url": "http://www.example.com/failure",
"return_cancel_url": "http://www.example.com/cancel.html",
"amount": "100",
"currency": "USD",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"lifetime": 60,
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"risk_params": {
"user_id": "123456"
},
"transaction_types": [
"authorize",
"sale"
],
"remember_card": "true",
"consumer_id": "123456"
}
).send()
.then(success)
.catch(failure);
Request
curl https://staging.wpf.emerchantpay.net/wpf \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<wpf_payment>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<description>You are about to buy 3 shoes at www.shoes.com!</description>
<notification_url>https://www.example.com/notification</notification_url>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<return_cancel_url>http://www.example.com/cancel.html</return_cancel_url>
<amount>100</amount>
<currency>USD</currency>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<lifetime>60</lifetime>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<risk_params>
<user_id>123456</user_id>
</risk_params>
<transaction_types>
<transaction_type>authorize</transaction_type>
<transaction_type>sale</transaction_type>
</transaction_types>
<remember_card>true</remember_card>
<consumer_id>123456</consumer_id>
</wpf_payment>'
How to use tokens in WPF API
Please provide consumer_id
and customer_email
. An existing consumer will be
used, if identified, and offer the user to select a previously stored card for
payment.
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('WPF\Create');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setDescription('You are about to buy 3 shoes at www.shoes.com!')
->setNotificationUrl('https://www.example.com/notification')
->setReturnSuccessUrl('http://www.example.com/success')
->setReturnFailureUrl('http://www.example.com/failure')
->setReturnCancelUrl('http://www.example.com/cancel.html')
->setAmount('100')
->setCurrency('USD')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
->setLifetime('60')
// Billing Address
->setBillingFirstName('Travis')
->setBillingLastName('Pastrana')
->setBillingAddress1('Muster Str. 12')
->setBillingZipCode('10178')
->setBillingCity('Los Angeles')
->setBillingNeighborhood('Hollywood')
->setBillingState('CA')
->setBillingCountry('US')
// Risk Params
->setRiskUserId('123456')
// Transaction Types
->addTransactionType('authorize')
->addTransactionType('sale')
->setConsumerId('123456');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.wpf.WPFCreateRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
public class GenesisExample {
public static void main() throws MalformedURLException {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
WPFCreateRequest request = new WPFCreateRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setDescription("You are about to buy 3 shoes at www.shoes.com!");
request.setNotificationUrl(new URL("https://www.example.com/notification"));
request.setReturnSuccessUrl(new URL("http://www.example.com/success"));
request.setReturnFailureUrl(new URL("http://www.example.com/failure"));
request.setReturnCancelUrl(new URL("http://www.example.com/cancel.html"));
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
request.setLifetime(60);
// Billing Address
request.setBillingFirstname("Travis");
request.setBillingLastname("Pastrana");
request.setBillingPrimaryAddress("Muster Str. 12");
request.setBillingZipCode("10178");
request.setBillingCity("Los Angeles");
request.setBillingNeighborhood("Hollywood");
request.setBillingState("CA");
request.setBillingCountry("US");
// Risk Params
request.setRiskUserId("123456");
// Transaction Types
request.addTransactionType("authorize").done();
request.addTransactionType("sale").done();
request.setConsumerId("123456");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.wpf_create(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"description": "You are about to buy 3 shoes at www.shoes.com!",
"notification_url": "https://www.example.com/notification",
"return_success_url": "http://www.example.com/success",
"return_failure_url": "http://www.example.com/failure",
"return_cancel_url": "http://www.example.com/cancel.html",
"amount": "100",
"currency": "USD",
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"lifetime": 60,
"billing_address": {
"first_name": "Travis",
"last_name": "Pastrana",
"address1": "Muster Str. 12",
"zip_code": "10178",
"city": "Los Angeles",
"neighborhood": "Hollywood",
"state": "CA",
"country": "US"
},
"risk_params": {
"user_id": "123456"
},
"transaction_types": [
"authorize",
"sale"
],
"consumer_id": "123456"
}
).send()
.then(success)
.catch(failure);
Request
curl https://staging.wpf.emerchantpay.net/wpf \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<wpf_payment>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<description>You are about to buy 3 shoes at www.shoes.com!</description>
<notification_url>https://www.example.com/notification</notification_url>
<return_success_url>http://www.example.com/success</return_success_url>
<return_failure_url>http://www.example.com/failure</return_failure_url>
<return_cancel_url>http://www.example.com/cancel.html</return_cancel_url>
<amount>100</amount>
<currency>USD</currency>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<lifetime>60</lifetime>
<billing_address>
<first_name>Travis</first_name>
<last_name>Pastrana</last_name>
<address1>Muster Str. 12</address1>
<zip_code>10178</zip_code>
<city>Los Angeles</city>
<neighborhood>Hollywood</neighborhood>
<state>CA</state>
<country>US</country>
</billing_address>
<risk_params>
<user_id>123456</user_id>
</risk_params>
<transaction_types>
<transaction_type>authorize</transaction_type>
<transaction_type>sale</transaction_type>
</transaction_types>
<consumer_id>123456</consumer_id>
</wpf_payment>'
Supported transaction types
All transaction types accepting cardholder data are supported - Account Verification, Authorize, Authorize3D, Sale, Sale3D, InitRecurringSale, InitRecurringSale3D, Payout, Intersolve, Fashioncheque.
Importation of external tokens and card details
Input CSV file format
CSV file headers:
Header | req? | Description |
---|---|---|
token | required | Plain-text token value (merchant/PSP token to migrate to us) |
token_type | optional | Token type format |
status | optional | Status of the token |
card_number | required | Credit card number |
card_holder | required | Full name of customer as printed on cc (first name and last name at least) |
expiration_month | required | Expiration month as printed on credit card |
expiration_year | required | Expiration year as printed on credit card |
required | Customer email | |
first_name | optional | Customer first name used for billing address details |
last_name | optional | Customer last name used for billing address details |
address1 | optional | Customer primary address used for billing address details |
address2 | optional | Customer secondary address used for billing address details |
zip_code | optional | Zip code used for billing address details |
city | optional | Customer city used for billing address details |
state | optional | State code in ISO 3166-2, used for billing address details |
country | optional | Country code in ISO 3166 used for billing address details |
Encryption of the CSV file
The CSV contains sensitive data and therefore it must be encrypted. A public GPG key should be used for this purpose.
Command to encrypt the file. It will generate encrypted file ending with .gpg extension:
Uploading the encrypted CSV file to remote SFTP server
Once the CSV file is encrypted it must be uploaded to our remote SFTP server for processing and importing its content.
The remote SFTP connection has the following options which should be provided on demand (please, contact tech-support@emerchantpay.com for more details):
Commands to upload the encrypted CSV file to remote SFTP server:
Once connected to the remote SFTP:
Downloading a response CSV file from the remote SFTP server
Once the tokens are imported in Genesis together with the relevant card details, a response CSV file would be generated. It will contain mapping between the tokens and the consumer ids and emails associated with them. They would be needed for successful usage of the imported tokens.
Response CSV file format
CSV file headers:
Header | Type | Description |
---|---|---|
token | string(36) | Plain-text newly generated token value |
consumer_id | string(10) | ID of the created consumer entity |
old_token | string | Plain-text old token value (merchant/PSP token passed to us for migration) |
token_id | string(32) | ID for the newly generated token |
token_type | uuid | Token type format |
status | string | Status of the token |
Commands to retrieve the response CSV files from the remote SFTP server:
Once connected to the remote SFTP:
Transaction API
Transaction Card Expiry Date Update API
Each card-based transaction has an expiration date, which can be updated using the Transaction Card Expiry Date Update API.
The API endpoint is suitable for recurring payments where the card has been renewed and has now a different expiration date.
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.gate.emerchantpay.net/v1/transaction/expiry_date/:transaction_unique_id \
-X PUT \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<update_card_expiration_request>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
</update_card_expiration_request>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
expiration_month | required | MM | Expiration month as printed on credit card |
expiration_year | required | YYYY | Expiration year as printed on credit card |
required* = conditionally required
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<update_card_expiration_response>
<status>success</status>
<code>200</code>
<message>Card expiry date updated successfully!</message>
</update_card_expiration_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
status | string(255) | Status of the response |
code | integer | Successful code (200) |
message | string(255) | Human readable error message which can be displayed to users. |
Error Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<update_card_expiration_response>
<status>error</status>
<code>300</code>
<technical_message>The provided expiration date must be in the future and after the current one</technical_message>
<message>Please check input data for errors!</message>
</update_card_expiration_response>
Error Response Parameters
Parameter | Type | Description |
---|---|---|
status | string(255) | Status of the response |
code | integer | Error code according to Error code table |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
message | string(255) | Human readable error message which can be displayed to users. |
APM Services
Alipay Register Merchant
Introduction
Alipay Register Merchant call allows to register merchants of online payments into Alipay system or to update the registration information of merchants.
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/v1/alipay/register_merchant/:terminal_token \
-X POST \
-H "Content-Type: application/json" \
-d '
{
"merchant_type": "ENTERPRISE",
"site_information": {
"type": "APP",
"url": "https://example.com",
"name": "Example"
},
"contact_number": "1234567",
"registration_number": "1234567",
"representative_id": "1234567",
"representative_name": "Your Name"
}'
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
{
"success": "true"
}
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/v1/alipay/register_merchant/:terminal_token \
-X POST \
-H "Content-Type: application/json" \
-d '
{
"merchant_type": "INDIVIDUAL",
"site_information": {
"type": "WEB",
"url": "https://example.com",
"name": "Example"
},
"contact_number": "1234567",
"registration_number": "1234567",
"shareholder_id": "1234567",
"shareholder_name": "Your Name"
}'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
merchant_type | required | string | Merchant type, the value can be INDIVIDUAL for the sole proprietorship or ENTERPRISE. |
site_information | required | object | This field is in JSON object. See site_infos for details. |
shareholder_id | required* | string(128) | ID or passport number, or business registration number of the primary shareholder of the merchant. Specify this field only when the merchant type is ENTERPRISE. |
shareholder_name | required* | string(64) | Legal name of the primary shareholder of the merchant. Specify this field only when the merchant type is ENTERPRISE. |
registration_number | required* | string(128) | Business registration number specified on the business registration document. Note: This field is not required when the merchant type is INDIVIDUAL and no registration number exists. |
representative_name | required* | string(64) | Full legal name of the business owner. Specify this field only when the merchant type is INDIVIDUAL. This field is optional if the merchant type is ENTERPRISE. |
representative_id | required* | string(128) | ID or passport number of the business owner. Specify this field only when the merchant type is INDIVIDUAL. This field is optional if the merchant type is ENTERPRISE. |
settlement_number | optional | string(64) | Settlement bank account number of the merchant. Use letters and numbers only. |
contact_number | required | string(64) | Contact phone number of the merchant, numbers and special characters +-() only. |
contact_email | optional | string(128) | Contact email address of the merchant. |
customer_service_number | optional | string(64) | Customer service phone number of the merchant, numbers and special characters +-() only. |
customer_service_email | optional | string(128) | Customer service email address of the merchant. |
required* = conditionally required
Alipay Register Merchant Site info parameters
Site info
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
type | required | string | Site type. For website URL, the value of this parameter must be WEB. For app download URL, the value of this parameter must be APP. Use uppercase. |
url | required | string(256) | Site URL. When site_type is WEB, pass the URL in this format: http/https + SLD + TLD. When site_type is APP, pass the APP download URL starting with http/https. |
name | optional | string(512) | Site name. |
required* = conditionally required
Klarna
Introduction
Klarna Services provides the ability for merchants to release remaining authorization, resend invoice, update order items or to update order address of a transaction.
Release Remaining Authorization API
The URL for Release Remaining Authorization API is:
Production:
https://gate.emerchantpay.net/klarna/release_remaining_authorization
Staging (for integration):
https://staging.gate.emerchantpay.net/klarna/release_remaining_authorization
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.gate.emerchantpay.net/klarna/release_remaining_authorization \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<release_remaining_authorization_request>
<transaction_id>a1qf12e81eb23d0e00ffb85b1db7d152</transaction_id>
</release_remaining_authorization_request>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_id | required | string(255) | Unique transaction id defined by merchant |
required* = conditionally required
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<release_remaining_authorization_request>
<status>success</status>
<technical_message>Transaction operation successful!</technical_message>
</release_remaining_authorization_request>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
status | string(255) | Status of the transaction, see states |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
Resend Invoice API
The URL for Resend Invoice API is:
Production:
https://gate.emerchantpay.net/klarna/resend_invoice
Staging (for integration):
https://staging.gate.emerchantpay.net/klarna/resend_invoice
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.gate.emerchantpay.net/klarna/resend_invoice \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<resend_invoice_request>
<transaction_id>a1qf12e81eb23d0e00ffb85b1db7d152</transaction_id>
</resend_invoice_request>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_id | required | string(255) | Unique transaction id defined by merchant |
required* = conditionally required
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<resend_invoice_request>
<status>success</status>
<technical_message>Transaction operation successful!</technical_message>
</resend_invoice_request>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
status | string(255) | Status of the transaction, see states |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
Update Order Items API
The URL for Update Order Items API is:
Production:
https://gate.emerchantpay.net/klarna/update_order_items
Staging (for integration):
https://staging.gate.emerchantpay.net/klarna/update_order_items
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.gate.emerchantpay.net/klarna/update_order_items \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<update_order_items_request>
<transaction_id>a1qf12e81eb23d0e00ffb85b1db7d152</transaction_id>
<amount>10000</amount>
<items>
<item>
<type>physical</type>
<reference>19-402-BG1</reference>
<name>BatteryPowerPack</name>
<quantity>1</quantity>
<unit_price>5000</unit_price>
<tax_rate>0</tax_rate>
<total_amount>5000</total_amount>
<total_discount_amount>0</total_discount_amount>
<total_tax_amount>0</total_tax_amount>
</item>
</items>
</update_order_items_request>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_id | required | string(255) | Unique transaction id defined by merchant |
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
items | required | List with items | |
item_type | required | string(255) | Order line type. Possible values: Supported item types |
quantity | required | integer | Non-negative. The item quantity |
unit_price | required | integer | Minor units. Includes tax, excludes discount(max value: 100000000) |
total_amount | required | integer | Includes tax and discount. Must match (quantity unit price) - total discount amount divided by quantity (max value: 100000000) |
reference | optional | string(255) | Article number, SKU or similar |
name | optional | string(255) | Descriptive item name |
tax_rate | optional | integer | Non-negative. In percent, two implicit decimals. I.e 2500 = 25.00 percent |
total_discount_amount | optional | integer | Non-negative minor units. Includes tax |
total_tax_amount | optional | integer | Must be within 1 of total amount - total_amount * 10000 / (10000 + tax rate). Negative when type is discount |
image_url | optional | url | URL to an image that can be later embedded in communications between Klarna and the customer. (max 1024 characters) |
product_url | optional | url | URL to an image that can be later embedded in communications between Klarna and the customer. (max 1024 characters) |
quantity_unit | optional | string(8) | Unit used to describe the quantity, e.g. kg, pcs... If defined has to be 1-8 characters |
product_identifiers | optional | List with product identifiers | |
brand | optional | string(255) | The product's brand name as generally recognized by consumers. If no brand is available for a product, do not supply any value |
category_path | optional | string(255) | The product's category path as used in the merchant's webshop. Include the full and most detailed category and separate the segments with ' > ' |
global_trade_item_number | optional | string(255) | The product's Global Trade Item Number (GTIN). Common types of GTIN are EAN, ISBN or UPC. Exclude dashes and spaces, where possible |
manufacturer_part_number | optional | string(255) | The product's Manufacturer Part Number (MPN), which - together with the brand - uniquely identifies a product. Only submit MPNs assigned by a manufacturer and use the most specific MPN possible |
merchant_data | optional | List with merchant data | |
marketplace_seller_info | optional | string(255) | Information for merchant marketplace |
required* = conditionally required
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<update_order_items_request>
<status>success</status>
<technical_message>Transaction operation successful!</technical_message>
</update_order_items_request>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
status | string(255) | Status of the transaction, see states |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
Update Order Address API
The URL for Update Order Address API is:
Production:
https://gate.emerchantpay.net/klarna/update_order_address
Staging (for integration):
https://staging.gate.emerchantpay.net/klarna/update_order_address
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://staging.gate.emerchantpay.net/klarna/update_order_address \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<update_order_address_request>
<transaction_id>a1qf12e81eb23d0e00ffb85b1db7d152</transaction_id>
<billing_address>
<first_name>Barney</first_name>
<last_name>Rubble</last_name>
<address1>14, Nerazdelni str</address1>
<zip_code>1407</zip_code>
<city>Berlin</city>
<neighborhood>Lichtenberg</neighborhood>
<country>DE</country>
</billing_address>
<shipping_address>
<first_name>Barney</first_name>
<last_name>Rubble</last_name>
<address1>14, Nerazdelni str</address1>
<zip_code>1407</zip_code>
<city>Berlin</city>
<neighborhood>Lichtenberg</neighborhood>
<country>DE</country>
</shipping_address>
</update_order_address_request>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
transaction_id | required | string(255) | Unique transaction id defined by merchant |
billing_address | required | See Required vs Optional API params for details | |
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
shipping_address | required | ||
first_name | required* | string(255) | Customer first name |
last_name | required* | string(255) | Customer last name |
address1 | required* | string(255) | Primary address |
address2 | required* | string(255) | Secondary address |
zip_code | required* | string | ZIP code |
city | required* | string(255) | City |
neighborhood | required* | string(255) | Neighborhood |
state | required* | string(2) | State code in ISO 3166-2, required for USA and Canada |
country | required | string(2) | Country code in ISO 3166 |
required* = conditionally required
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<update_order_address_request>
<status>success</status>
<technical_message>Transaction operation successful!</technical_message>
</update_order_address_request>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
status | string(255) | Status of the transaction, see states |
technical_message | string(255) | Technical error message (for internal use only, not to be displayed to users). |
Trustly Select Account
Introduction
Trustly Select Account call allows the consumer to select their Trustly account, which is later on used to complete a Trustly Bank Pay-out transaction.
A typical flow is:
The merchant makes an API call to SelectAccount and redirects the consumer to the url.
The consumer selects his/her bank and completes the identification process.
The consumer is redirected back to the merchant at the SuccessURL, note that the account might not be verified yet at this point.
When the account is verified, Trustly sends an account notification ( Account_ID) to the merchant's system with information about the selected account and Account_id unique for each user's bank account.
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/v1/trustly/select_account/:terminal_token \
-X POST \
-H "Content-Type: application/json" \
-d '
{
"country": "UK",
"first_name": "Travis",
"last_name": "Pastrana",
"ip_address": "255.255.255.255",
"mobile_phone": "+441509813888",
"national_id": "8910103344",
"birth_date": "1989-10-10",
"success_url": "https://example.com/success",
"failure_url": "https://example.com/failure",
"user_id": "12345678",
"unique_id": "gp634ec5e7dbe6ca3871974accb875cd",
"locale": "en_US"
}'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
country | required | string(2) | Country code in ISO 3166 |
first_name | required | string(255) | Customer first name |
ip_address | required | string(255) | IP address of the customer |
required | e-mail address | Must contain valid e-mail of the customer | |
mobile_phone | required | string(32) | Must contain valid phone number of the customer |
national_id | required | string(20) | National Identifier number of the customer |
birth_date | required | yyyy-mm-dd | Must contain valid birth date of the customer |
success_url | required | url | URL where the customer is sent to after successful authentication |
failure_url | required | url | URL where the customer is sent to after failed authentication |
user_id | required | string(255) | Unique user identifier defined by merchant in their own system. ID, username, hash or anything uniquely identifying the consumer requesting the deposit. Must be static per each consumer for any type of transaction where this consumer is involved (trustly_sale, bank pay_out, register_account, select account). |
unique_id | required | string(255) | Unique identifier defined by merchant |
locale | required | string(20) | Customer's localization preference in the format [language[_territory]]. Language is the ISO 639 code and the territory ISO 3166 code. |
required* = conditionally required
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
{
"order_id": "4014321",
"url": "http://example.com/customer_redirect"
}
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
order_id | string(255) | Order identifier |
url | url | URL where user has to be redirected to complete select account process. |
Trustly Register Account
Introduction
Trustly Register Account call allows the merchant to verify customer's bank account details and get the associated account id which can be saved and used for future payouts.
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/v1/trustly/register_account/:terminal_token \
-X POST \
-H "Content-Type: application/json" \
-d '
{
"first_name": "Travis",
"last_name": "Pastrana",
"mobile_phone": "+441509813888",
"national_id": "8910103344",
"birth_date": "1989-10-10",
"user_id": "12345678",
"clearing_house": "SPAIN",
"account_number": "ES8701820004756386447000",
"bank_number": ""
}'
List of supported clearinghouses:
AUSTRIA, BELGIUM, BULGARIA, CROATIA, CYPRUS, CZECH_REPUBLIC, DENMARK, ESTONIA, FINLAND, FRANCE, GERMANY, GREECE, HUNGARY, IRELAND, ITALY, LATVIA, LITHUANIA, LUXEMBOURG, MALTA, NETHERLANDS, NORWAY, POLAND, PORTUGAL, ROMANIA, SLOVAKIA, SLOVENIA, SPAIN, SWEDEN, UNITED_KINGDOM
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
{
"account_id": "1044806532",
"clearing_house": "SPAIN",
"bank": "BBVA",
"descriptor": "******************447000"
}
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/v1/trustly/register_account/:terminal_token \
-X POST \
-H "Content-Type: application/json" \
-d '
{
"first_name": "Travis",
"last_name": "Pastrana",
"mobile_phone": "+441509813888",
"national_id": "123456789",
"birth_date": "1989-10-10",
"user_id": "12345678",
"clearing_house": "SWEDEN",
"account_number": "8257466",
"bank_number": "5839"
}'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
first_name | required | string(255) | Customer first name |
last_name | required | string(255) | Customer last name |
optional | e-mail address | Must contain valid e-mail of the customer | |
mobile_phone | optional | string(32) | Must contain valid phone number of the customer |
national_id | optional | string(20) | National Identifier number of the customer |
birth_date | required | yyyy-mm-dd | Must contain valid birth date of the customer |
user_id | required | string(255) | Unique user identifier defined by merchant in their own system. ID, username, hash or anything uniquely identifying the consumer requesting the deposit. Must be static per each consumer for any type of transaction where this consumer is involved (trustly_sale, bank pay_out, register_account, select account). |
clearing_house | required | string(255) | The clearing house of the customer's bank account. Typically the name of a country in uppercase letters. |
account_number | required | string(32) | The account number of the customer's bank account. Can be either IBAN or country-specific format. |
bank_number | required | string(32) | The bank number of the customer's account in the given clearing house. For bank accounts in IBAN format, just provide an empty string ("") |
required* = conditionally required
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
{
"account_id": "7653385737",
"clearing_house": "SWEDEN",
"bank": "Skandiabanken",
"descriptor": "*******4057"
}
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
account_id | string(255) | Unique identifier associated with the account |
clearing_house | string(255) | The clearing house of the account |
bank | string(255) | Name of the bank for this account |
descriptor | string(255) | A descriptor for this account |
TransferTo
Introduction
TransferTo API endpoint provides merchants with the ability to retrieve an up-to-date list of TransferTo Payers. Those are the institutions that provide the money to the consumers.
Retrieve Payers API
This request is used to retrieve up-to-date TransferTo Payers list.
GET /transfer_to_payers/payers
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/transfer_to_payers/payers \
-X GET \
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payers_response>
<payers>
<payer>
<id>1</id>
<name>Sample Payer 1</name>
<currency>USD</currency>
<country_iso_code>USA</country_iso_code>
<service>BankAccount</service>
<transfer_type>B2C</transfer_type>
<transaction_requirements>{"sample":"requirements"}</transaction_requirements>
</payer>
<payer>
<id>2</id>
<name>Sample Payer 2</name>
<currency>EUR</currency>
<country_iso_code>FRA</country_iso_code>
<service>MobileWallet</service>
<transfer_type>B2C</transfer_type>
<transaction_requirements>{"sample":"requirements"}</transaction_requirements>
</payer>
</payers>
</payers_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
payer | ||
id | string | ID of the Payer (used as payer_id in the TransferToPayout transaction) |
name | string | Name of the Payer |
currency | string(3) | The currency in which the Payer provides the money |
country_iso_code | string(3) | The ISO code of the country in which the Payer operates |
service | string | The service used by the Payer to provide the money |
transfer_type | string(3) | The money transfer type. Can be B2B , B2C or C2C . |
transaction_requirements | string(1024) | JSON containing the Payer's requirements |
Errors
Error groups table
Code | Name | Description |
---|---|---|
(100..199) | Systems errors | Transaction could not be processed and was not passed to issuer. |
(200..299) | Communication errors | Transaction could not be processed properly. Issuer could not be reached or returned invalid data. Errors 230 - 250 need to be reconciled as they might have been processed properly issuer-wise. |
(300..399) | Input data errors | Transactions cannot be processed due to invalid incoming data in your request. |
(400..499) | Workflow errors | Workflow errors will occur if you trigger a transaction that is not possible at this time in the workflow, e.g. a refund on a declined transaction. |
(500..599) | Processing errors | These errors occur when a transaction was declined by the issuer. |
(600..699) | Risk errors | Risk errors occur when any of the risk management systems will not let the transaction pass through. |
(700..799) | Tokenization errors | Tokenization related errors. |
(800..899) | Genesis KYC Services errors | Genesis KYC Services errors |
(900..999) | Issuer errors | Issuer errors occur when the issuer is unreachable or has other technical problems. If you experience this kind of errors, contact support. |
Error codes tables
System Errors
Code | Name | Description |
---|---|---|
100 | SystemError | A general system error occurred |
101 | MaintenanceError | System is undergoing maintenance, request could not be handled. |
110 | AuthenticationError | Login failed. Check your API credentials. |
120 | ConfigurationError | Configuration error occurred, e.g. terminal not config- ured properly. Check terminal settings. |
Communication Errors
Code | Name | Description |
---|---|---|
200 | CommunicationError | Communication with issuer failed, please contact sup- port. |
210 | ConnectionError | Connection to issuer could not be established, please contact support. |
220 | AccountError | Issuer account data invalid, please contact support. |
230 | TimeoutError | Issuer does not respond within given timeframe - please reconcile |
240 | ResponseError | Issuer returned invalid response - please reconcile and contact support |
250 | ParsingError | Issuer response could not be parsed - please reconcile and contact support. |
Input Data Errors
Code | Name | Description |
---|---|---|
300 | InputDataError | Invalid were data sent to the API. |
310 | InvalidTransactionTypeError | Invalid transaction type was passed to API. See transaction types. |
320 | InputDataMissingError | Required argument is missing. Check parameters. |
330 | InputDataFormatError | Argument passed in invalid format. Check parame- ters. |
340 | InputDataInvalidError | Argument passed in valid format but makes no sense (e.g. incorrect country code or currency). Check parameters. |
350 | InvalidXmlError | The input XML could not be parsed due to invalid code. Please check XML data. |
360 | InvalidContentTypeError | Missing or invalid content type: should be text/xml! |
Workflow Errors
Code | Name | Description |
---|---|---|
400 | WorkflowError | A transaction was triggered that is not possible at this time in the workflow, e.g. a refund on a declined transaction. |
410 | ReferenceNotFoundError | Reference transaction was not found. |
420 | ReferenceWorkflowError | Wrong Workflow specified. |
430 | ReferenceInvalidatedError | Reference transaction already invalidated! |
440 | ReferenceMismatchError | Data mismatch with reference, e.g. amount exceeds reference |
450 | DoubletTransactionError | Transaction doublet was detected, transaction was blocked. This happens if several transactions with same amount, cardholder, cc number, cvv and expiry date are sent within 5 minutes. |
460 | TransactionNotFoundError | The referenced transaction could not be found. |
470 | ChargebackNotFoundError | Chargeback not found! |
471 | RapidDisputeResolutionNotFoundError | Rapid Dispute Resolution not found! |
480 | RetrievalRequestNotFoundError | Retrieval Request not found! |
490 | FraudReportNotFoundError | Fraud Report not found! |
Processing Errors
Code | Name | Description |
---|---|---|
500 | ProcessingError | Transaction declined by issuer |
510 | InvalidCardError | Transaction declined, Credit card number is invalid. |
511 | IssuerOctNotEnabledError | OCT not enabled error. |
520 | ExpiredCardError | Transaction declined, expiration date not in the future or date invalid. |
530 | TransactionPendingError | Transaction pending. |
540 | CreditExceededError | Amount excceds credit card limit. |
550 | IssuingError | The voucher could not be issued! |
551 | ScaRequiredError | SCA required! |
Risk Errors
Code | Name | Description |
---|---|---|
600 | RiskError | Transaction declined by risk management |
601 | InterchangeRejectError | Interchange reject received for transaction! |
609 | BinCountryCheckError | Card bin does not match billing country |
610 | CardBlacklistError | Card is blacklisted |
611 | BinBlacklistError | BIN blacklisted. |
612 | CountryBlacklistError | Country blacklisted. |
613 | IpBlacklistError | IP address blacklisted. |
614 | BlacklistError | value from payment transaction or risk params is blacklisted. |
615 | CardWhitelistError | PAN Whitelist Filter blocked the transaction. This filter - like the above one - uses the PAN blacklist (BL) to perform CC number checks against the BL in the DB. This filter however will reject transactions from a CC with a number which is not whitelisted. |
620 | CardLimitExceededError | Card limit exceeded configured limits. |
621 | TerminalLimitExceededError | Terminal limits exceeded. |
622 | ContractLimitExceededError | MID limits exceeded. |
623 | CardVelocityExceededError | Velocity by unknown card exceeded! |
624 | CardTicketSizeExceededError | Ticketsize by unknown card exceeded! |
625 | UserLimitExceededError | User limit exceeded configured limits. |
626 | MultipleFailureDetectionError | Found user transaction declined by issuer. Try again later! |
627 | CSDetectionError | The CrossSellingFilter blocks duplicated transactions when an approved transaction has been found on another mid. That is, if the transaction has already been processed successfully on a different mid and within the specified time frame, context entity / scope and possibly within the issuer scope (or not), it will be rejected in order to prevent duplicates. |
628 | RecurringLimitExceededError | Amount/count by recurring subscription exceeded. |
629 | IrisFilterDeclinedError | Transaction declined by risk management. |
630 | IrisFilterOnHoldError | Transaction on hold, a manual review will be done |
690 | AvsError | Address Verification failed. |
691 | MaxMindRiskError | If a transaction is considered high risk by MaxMind minFraud service, a MaxMindRiskError is raised. |
692 | ThreatMetrixRiskError | Transaction declined by ThreatMetrix risk module. |
693 | IpNotWhitelistedError | Transaction declined by risk management, IP is NOT whitelisted! |
694 | DomainBlacklistedError | Transaction declined by risk management, domain is blacklisted! |
695 | FraudError | Risk Error: Please contact the risk team! |
696 | IbanBlacklistError | Transaction declined by risk management, iban blacklisted! |
Tokenization Errors
Code | Name | Description |
---|---|---|
701 | ConsumerUniquenessError | Consumer with this consumer_id, email combination already exists! |
702 | InvalidConsumerError | Consumer not found! |
703 | DisabledConsumerError | Consumer is disabled! |
700 | TokenizationError | General tokenization error. |
710 | TokenizationNotEnabledError | Tokenization is not enabled for the merchant or the terminal! Contact support. |
720 | InvalidTokenTypeError | Unsupported token type! |
730 | InvalidTokenError | Invalid token! |
740 | DetokenizeForbiddenError | Detokenize action is forbidden! |
741 | TokenizeForbiddenError | Tokenize action is forbidden! |
742 | UpdateTokenForbiddenError | Update token action is forbidden! |
743 | ValidateTokenForbiddenError | Validate token action is forbidden! |
744 | DeleteTokenForbiddenError | Delete token action is forbidden! |
Client-side encryption-related errors
750 | ClientSideEncryptionError | Client-side encryption error! 751 | ClientSideEncryptionNotEnabledError | Client-side Encryption is not enabled!
KYC Errors
Code | Name | Description |
---|---|---|
800 | KycServiceError | General KYC Service Error |
801 | DocumentMimeTypeUnsupportedError | Uploaded document MIME type is not supported by KYC provider |
802 | InvalidRequestAttributesError | Passed attributes are invalid! |
803 | KycServiceNotConfiguredError | KYC Services not configured for Merchant! |
804 | KycServiceProviderError | KYC Service provider Error! |
805 | KycServiceNotificationError | Notification already received |
806 | KycServiceUnacceptableMerchantStateError | Merchant state does not allow using KYC Service API! |
Remote Errors
Code | Name | Description |
---|---|---|
900 | RemoteError | Some error occurred on the issuer. Contact support. |
910 | RemoteSystemError | Some error occurred on the issuer |
920 | RemoteConfigurationError | Issuer configuration error |
930 | RemoteDataError | Some passed data caused an error on the issuer |
940 | RemoteWorkflowError | Remote workflow error |
950 | RemoteTimeoutError | Issuer has timeouted with clearing network |
Client Integrations
There are client libraries and examples for a few programming languages to ease the merchant integration effort:
Language | Github | Description |
---|---|---|
.NET | Genesis .NET | .NET client library |
Java | Genesis Java | Java client library |
Kotlin | Genesis Android | Android client library |
Node.js | Genesis Node | Node.js client library |
PHP | Genesis PHP | PHP client library |
Swift | Genesis Swift | iOS client library |
Ruby | Genesis Ruby | Ruby client library |
Should you have any questions or suggestions regarding the client libraries and improvements, contact the IT Support team at tech-support@emerchantpay.com.
You can also fork the repo(s) and send us pull requests directly at our Github account.
Client-side encryption
The Client-side Encryption (CSE) allows merchants to accept payments on their website while encrypting card data in their customer's browser with our JavaScript encryption library.
To help merchants encrypt all sensitive card data on the customer's side, emerchantpay hosts the JavaScript library and merchant's encryption key. In addition, the merchants can decide to host the library by themselves, but we strongly recommend the Client-side encryption library hosted by our services to be used.
If the merchants want to use the Client-Side Encryption (CSE) library, it needs to contact tech-support@emerchantpay.com in order to enable this feature for them. Then the merchant will be allowed to obtain the public key and the library in the merchant web console.
Client side
<head>
...
<script src="https://{CDN}/encrypto-{VERSION}.js"
integrity="sha512-lJxHl93A/b8peqxz/mdLj7jD58N2zvHiiYhw8...=="
crossorigin="anonymous"></script>
</head>
<body>
<form method="POST" action="/request-payment" id="encrypto-form">
<div>
<input type="text" data-encrypted-name="card_number"/>
<input type="text" data-encrypted-name="card_holder"/>
...
<input type="text" data-encrypted-name="cvv"/>
...
<input type="text" name="country"/>
<input type="text" name="city"/>
</div>
...
<input type="submit" value="Pay"/>
</form>
<script>
var publicKey = '...';
Encrypto.createEncryptedForm(publicKey, { // Required
// formId: 'encrypto-form', // Optional
// onSubmit: function(form) { // Optional
// console.log(form.fields);
// }
})
</script>
</body>
First, the merchant needs to create a payment form integrated with the Client-Side Encryption (CSE) library which can be retrieved from the Client Side Encryption panel in the merchant console at the merchant configuration page.
Make sure that payment form contains all required fields for the transaction type which it's going to be used. Consult with our Transactions documentation. Don't forget to replace the form action with the payment handler URL of the merchant's server.
Flag all card input fields for encryption by annotating them with the data-encrypted-name
attribute.
The name attribute should not be used for card input fields. The fields allowed for encryption are
card_holder
, card_number
, expiration_month
, expiration_year
, and cvv
.
Eventually, the form may have a custom ID attribute. The formId
option can be used to set any string as an ID for the payment form.
Make sure to update the HTML form with the configured option. They both must match.
Options
option | type | description |
---|---|---|
formId | string | Use to set custom form ID. Default value encrypto-form |
onSubmit | function | Use to set custom on submit callback |
Prevent form submit action
Encrypto.createEncryptedForm(publicKey, {
onSubmit: function(form) {
// console.log(form.fields);
}
})
In the case of a single-page application or a form that uses AJAX, maybe it's not desirable the form to reload the page when the payment gets submitted.
For that reason, we provide onSubmit
option. This option gives access to all the form data(including the encrypted fields) and allows to submit it via any AJAX library.
JavaScript only
<head>
...
<script src="https://{CDN}/encrypto-{VERSION}.js"
integrity="sha512-lJxHl93A/b8peqxz/mdLj7jD58N2zvHiiYhw8...=="
crossorigin="anonymous"></script>
</head>
<body>
<script>
var publicKey = '...';
var cse = Encrypto.createEncryption(publicKey);
let data = {
cvv: '123',
card_number: '42000...'
};
var encryptedData = cse.encrypt(data);
</script>
</body>
In case the merchant does not have an HTML form, our library provides HTML-independent encryption. In this scenario, it's important to remember it's the merchant responsibility to make sure the card data is encrypted before sending it to the server.
The JavaScript-only option can be convenient in case of a more complex single-page application which relies on state management library before sending any data to the server.
Server side
From the merchant's server, an HTTP POST request needs to be made to the gateway API endpoints. The workflow is the same as in the classic Client Integrations. The only difference when the Client-Side Encryption (CSE) library is used is that our gateway will receive the card data encrypted.
Do not worry about the decryption. Our gateway will handle the API request as a standard transaction. Make sure to always use the correct public key in the client-side code.
Shopping Carts
Genesis has a number of shopping cart plugins to ease the merchant integration effort:
Shopping cart | Github | More Info | Description |
---|---|---|---|
Magento 2.x CE, EE, ECE | Magento 2.x CE, EE, ECE | Magento2 Integration | Shopping Cart plugin for Magento 2.x supported from Community Edition, Enterprise Edition and Enterprise Cloud Edition |
OpenCart | OpenCart | OpenCart Integration | Shopping cart plugin for OpenCart |
osCommerce | osCommerce | Shopping cart plugin for osCommerce | |
PrestaShop | PrestaShop | PrestaShop Integration | Shopping cart plugin for PrestaShop |
Shopify | Internal integration | Shopify Integration | Shopping cart Integration for Shopify |
Shopware 6.x | Shopware 6.x | Shopware_6.x Integration | Shopping cart plugin for Shopware 6.x |
Spree | Spree Commerce | Spree Integration | Shopping cart plugin for Spree Commerce |
WooCommerce | WooCommerce | WooCommerce Integration | Shopping cart plugin for WooCommerce |
X-Cart | X-Cart | X-Cart Integration | Shopping cart plugin for X-Cart |
Zen Cart | Zen Cart | Zen Cart Integration | Shopping cart plugin for Zen Cart |
Should you have any questions or suggestions regarding the shopping cart plugins and improvements, contact the IT Support team at tech-support@emerchantpay.com.
You can also fork the repo(s) and send us pull requests directly at our Github account.
Testing
For information about the testing environment see Environments.
For testing first login to the gateway admin and create a terminal.
The url for test admin is:
https://staging.merchant.emerchantpay.net/
The api base url for test processing is:
https://staging.gate.emerchantpay.net/process/TERMINAL_TOKEN
The api base url for test single transaction reconciling is:
https://staging.gate.emerchantpay.net/reconcile/TERMINAL_TOKEN
The api base url for test date range reconciling is:
https://staging.gate.emerchantpay.net/reconcile/by_date/TERMINAL_TOKEN
For testing the gateway the following credit card numbers can be used:
card number | card brand | transaction result |
---|---|---|
4200000000000000 | Visa | successful transaction |
4111111111111111 | Visa | transaction declined |
5555555555554444 | Master Card | successful transaction |
5105105105105100 | Master Card | transaction declined |
For 3DSecure testing the following credit card numbers can be used:
3DS v2
Scenario | 3DSecure Method | 3DSecure Challenge | Result | Card Number | Note |
---|---|---|---|---|---|
Frictionless | - | - | Authenticated | 4012000000060085 | |
Frictionless | - | - | Authenticated | 4901170000000003 | |
Frictionless | - | - | Authenticated | 4901164281364345 | |
Frictionless | - | - | Authenticated | 4378510000000004 | |
Frictionless | - | - | Attempted | 4456530000001005 | |
Frictionless | - | - | Attempted | 5200000000001054 | |
Frictionless | Y | - | Authenticated | 4066330000000004 | |
Frictionless | Y | - | Authenticated | 5200000000001021 | |
Low risk exemption accepted (MasterCard) | - | - | Authenticated | 5169750000001111 | Used only for synchronous 3DS workflow. |
Low risk exemption accepted (Visa) | - | - | Authenticated | 4378510000000004 | Used only for synchronous 3DS workflow. |
Frictionless | - | - | Not authenticated | 4111110000000922 | |
Frictionless | - | - | Not authenticated | 5200000000001047 | |
Frictionless | Y | - | Not authenticated | 4111112232423922 | |
Challenge | - | Y | Choose Challenge result | 4918190000000002 | |
Challenge | - | Y | Choose Challenge result | 5433300000000133 | |
Challenge | Y | Y | Choose Challenge result | 4938730000000001 | |
Challenge | Y | Y | Choose Challenge result | 5200000000001005 |
AVS
The following amounts can be used to return specific avs response code and avs response description:
Code | Amount | BIN Country | Response Description |
---|---|---|---|
A | 1.00 | UK, US | Address matches - ZIP Code does not match |
B | 1.01 | UK, US | Street address match, Postal code in wrong format (international issuer) |
C | 1.02 | UK, US | Street address and postal code in wrong formats |
D | 1.03 | UK, US | Street address and postal code match (international issuer) |
F | 1.04 | UK | Address does compare and five-digit ZIP code does compare (UK only) |
G | 1.05 | UK, US | Service not supported by non-US issuer |
I | 1.06 | UK, US | Address information not verified by international issuer |
M | 1.07 | UK, US | Street Address and Postal code match (international issuer) |
N | 1.08 | UK, US | No Match on Address (Street) or ZIP |
P | 1.09 | UK, US | Postal codes match, Street address not verified due to incompatible formats |
R | 1.10 | UK, US | Retry, System unavailable or Timed out |
S | 1.11 | UK, US | Service not supported by issuer |
U | 1.12 | UK, US | Address information is unavailable |
W | 1.13 | US | 9-digit ZIP matches, Address (Street) does not match |
X | 1.14 | US | Exact AVS Match |
Y | 1.15 | US | Address (Street) and 5-digit ZIP match |
Z | 1.16 | US | 5-digit ZIP matches, Address (Street) does not match |
Visa, Maestro and Mastercard card brands can be used for all avs response codes except for 1.14, which only works with Maestro and Mastercard.
The AVS response does not depend on the status of the transaction.
Status Page
statuspage.io is a popular service allowing to track server status, infrastructure notifications, and others.
Note that you can sign up for emerchantpay’s status page.
It allows to sign up via email or SMS or both, and receive notifications for our payment services and any planned maintenance windows, upgrades, or similar in the future should the need arise.
Infrastructure and Uptime
Genesis is hosted in two data centers respectively in Berlin and Amsterdam, and features a state-of-the-art, active-active infrastructure setup. As such, it employs load balancing and failover on the DNS layer, and you should be using and requesting the API nodes and web apps only via their dedicated DNS names.
No hard-coding of IP addresses should be performed on the customers’ systems, as this will prevent the customer to take advantage of the failover in case one of the data centers has issues or throughout maintenance windows and current processing happens through one data center only, however rare this might be. In addition, load balancing of the customers’ volume is also impacted if IP addresses are hardcoded.
Finally, note that the DNS load balancing and failover layer has a TTL of 30 seconds, and will sense any issues returning the right IP addresses to use, for both API nodes and web apps alike, at all times.
As a highly available payment gateway platform, Genesis strives to achieve an uptime SLA of 99.99 percent on a yearly basis.
Penetration Testing Warning
It is important that merchants read and understand the activities that are explicitly prohibited when using the payment gateway services.
While merchants are encouraged to perform best practice security testing on their own websites and applications, merchants must ensure under all circumstances that scans exclude the payment gateway Web Payment Form (WPF), Processing API, and merchant console.
Action | prohibited? |
---|---|
Penetration testing of any gateway services | Prohibited |
Load testing | Prohibited. During integration testing, ensure minimum number of requests |
Exploiting common security vulnerabilities | Prohibited |
Injecting malicious data | Prohibited |
Bypassing validation and security checks | Prohibited |
Subverting ACLs and user permissions | Prohibited |
Port scanning and service discovery | Prohibited |
Usage of ping/traceroute | Acceptable for short term debugging purposes |
Note that merchants that do not abide by the above policy will be immediately blacklisted, resulting in terminating access to the WPF, Processing API, and merchant console.
AVS Status Codes
There are two cases for AVS codes, single and two-character codes.
Single character code
AVS code description is mentioned in the below table.
Code | Descriptive response | AVS Response text |
---|---|---|
A | Approved | Postcode and address matched |
B | Partial Approved | Postcode matched; address not checked |
C | Partial Approved | Postcode matched; address not matched |
D | Partial Approved | Address matched; postcode not checked |
E | Not Sent To Acquirer | Postcode and address not checked |
F | Partial Approved | Address matched; postcode not matched |
G | Partial Approved | Postcode not checked; address not matched |
H | Not Supplied By Shopper | Postcode and address not supplied by shopper/merchant |
I | Partial Approved | Address not checked; postcode not matched |
J | Failed | Postcode and address not matched |
Two-characters code
When sending a transaction for address verification or card verification, an AVS code will be returned.
The first character of the AVS code represents the entity that was responsible for generating that code. See below table for details.
Code | Description |
---|---|
2 | Response provided by Intermediate Processor |
5 | Response provided by Issuer Processor |
The second character of the AVS code description is mentioned in the below table.
Code | Summary | VISA | MasterCard |
---|---|---|---|
A | Partial Match | Street address matches, but 5-digit and 9-digit postal code do not match. | Address matches, ZIP does not. |
B | Partial Match (International Transaction) | Not applicable. | Street addresses match. Postal code not verified due to incompatible formats. (Acquirer sent both street address and postal code.) |
C | No Match (International Transaction) | Not applicable. | Street address and postal code not verified due to incompatible formats. (Acquirer sent both street address and postal code.) |
D | Full Match (International Transaction) | Not applicable. | Street addresses and postal codes match. |
F | Full Match (UK only) | Not applicable. | Street address and postal code match. Applies to U.K. only. |
G | Not Supported (International Transaction) | Not applicable. | Address information not verified for international transaction. |
I | No Match (International Transaction) | Not applicable. | Address information not verified. |
M | Full Match (International Transaction) | Not applicable. | Street address and postal code match. |
N | No Match | No match. Acquirer sent postal/ZIP code only, or street address only, or both postal/ZIP and street address. | Neither address nor postal code matches. |
P | Partial Match (International Transaction) | Not applicable. | Postal code match. Street address not verified because of incompatible formats. (Acquirer sent both street address and postal code.) |
R | System Unavailable | Retry: System unavailable or timed out. Issuer ordinarily performs address verification but was unavailable. | Retry, system unable to process. |
S | Not Supported | Not applicable. | AVS currently not supported. |
U | System Unavailable | Address not verified for domestic transaction. Address not verified for international transaction. Issuer is not an AVS participant, or AVS data was present in the request but issuer did not return an AVS result, or V.I.P. performed address verification on behalf of the issuer and there was no address record on file for this account. | No data from issuer/Authorization System. Information not available. |
W | Partial Match (US only) | Not applicable. | For U.S. addresses, nine-digit postal code matches, address does not; for address outside the U.S., postal code matches, address does not. |
X | Full Match | Not applicable. | For U.S. addresses, nine-digit postal code and address matches; for addresses outside the U.S., postal code and address match. |
Y | Full Match | Street address and postal/ZIP match. | For U.S. addresses, five-digit postal code and address matches. |
Z | Partial Match | Postal/ZIP match, street addresses do not match or street address not inclued in request. | For U.S. addresses, five-digit postal code matches, address does not. |
CVV Result Codes
Code | Summary |
---|---|
M | Match |
N | No match |
S | Should be on card |
P | Not processed |
U | Issuer does not participate |
Level 3 Travel Data
Level 3 travel data is supplied as optional data to the standard API request. If the supplied is valid travel data then the transaction will be processed as a travel transaction and will qualify for the travel Incentive rates. Otherwise the transaction will be processed normally as a regular transaction. Note that the travel data will be stored as part of the transaction in all cases.
Travel data is supported for Authorize, Authorize3D, Capture, Sale, Sale3D, Refund.
The following travel types are supported Airline Itinerary Data (AID), Car Rental, Hotel Rental, Ancillary Charges, Misc Charges.
Travel Types
Airline Itinerary Data (AID)
Airline Ticket transaction With Airline Itinerary Data (AID)
MasterCard
Contract Merchant Category Code must be 3000-3350, 4511, 4722, 4723 or 5962
Master Card
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Sale');
$request = $genesis->request();
$request
->set...('')
->setTravel('{"ticket"=>{"ticket_number"=>123456789012345, "passenger_name"=>"Test Example", "customer_code"=>1, "issuing_carrier"=>"AAAA", "total_fare"=>5000, "agency_name"=>"Agency", "agency_code"=>"AG001"}, "legs"=>[{"departure_date"=>"2018-02-05", "carrier_code"=>12, "service_class"=>1, "origin_city"=>"VAR", "destination_city"=>"FRA", "stopover_code"=>0, "fare_basis_code"=>1, "flight_number"=>"W6666", "departure_time"=>"11:37", "departure_time_segment"=>"A"}]}');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.SaleRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
SaleRequest request = new SaleRequest();
request.set...("");
request.setTravel("{"ticket"=>{"ticket_number"=>123456789012345, "passenger_name"=>"Test Example", "customer_code"=>1, "issuing_carrier"=>"AAAA", "total_fare"=>5000, "agency_name"=>"Agency", "agency_code"=>"AG001"}, "legs"=>[{"departure_date"=>"2018-02-05", "carrier_code"=>12, "service_class"=>1, "origin_city"=>"VAR", "destination_city"=>"FRA", "stopover_code"=>0, "fare_basis_code"=>1, "flight_number"=>"W6666", "departure_time"=>"11:37", "departure_time_segment"=>"A"}]}");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.sale(
{
"...": "",
"travel": {
"ticket": {
"ticket_number": 123456789012345,
"passenger_name": "Test Example",
"customer_code": 1,
"issuing_carrier": "AAAA",
"total_fare": 5000,
"agency_name": "Agency",
"agency_code": "AG001"
},
"legs": [
{
"departure_date": "2018-02-05",
"carrier_code": 12,
"service_class": 1,
"origin_city": "VAR",
"destination_city": "FRA",
"stopover_code": 0,
"fare_basis_code": 1,
"flight_number": "W6666",
"departure_time": "11:37",
"departure_time_segment": "A"
}
]
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<.../>
<travel>
<ticket>
<ticket_number>123456789012345</ticket_number>
<passenger_name>Test Example</passenger_name>
<customer_code>1</customer_code>
<issuing_carrier>AAAA</issuing_carrier>
<total_fare>5000</total_fare>
<agency_name>Agency</agency_name>
<agency_code>AG001</agency_code>
</ticket>
<legs>
<leg>
<departure_date>2018-02-05</departure_date>
<carrier_code>12</carrier_code>
<service_class>1</service_class>
<origin_city>VAR</origin_city>
<destination_city>FRA</destination_city>
<stopover_code>0</stopover_code>
<fare_basis_code>1</fare_basis_code>
<flight_number>W6666</flight_number>
<departure_time>11:37</departure_time>
<departure_time_segment>A</departure_time_segment>
</leg>
</legs>
</travel>
</payment_transaction>'
Master Card Multiple Legs
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Sale');
$request = $genesis->request();
$request
->set...('')
->setTravel('{"ticket"=>{"ticket_number"=>123456789012345, "passenger_name"=>"Test Example", "customer_code"=>1, "issuing_carrier"=>"AAAA", "total_fare"=>5000, "agency_name"=>"Agency", "agency_code"=>"AG001"}, "legs"=>[{"departure_date"=>"2018-02-05", "carrier_code"=>12, "service_class"=>1, "origin_city"=>"VAR", "destination_city"=>"FRA", "stopover_code"=>0, "fare_basis_code"=>1, "flight_number"=>"W6666", "departure_time"=>"11:37", "departure_time_segment"=>"A"}, {"departure_date"=>"2018-02-05", "carrier_code"=>12, "service_class"=>1, "origin_city"=>"VAR", "destination_city"=>"BER", "stopover_code"=>0, "fare_basis_code"=>1, "flight_number"=>"W6666", "departure_time"=>"11:37", "departure_time_segment"=>"A"}]}');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.SaleRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
SaleRequest request = new SaleRequest();
request.set...("");
request.setTravel("{"ticket"=>{"ticket_number"=>123456789012345, "passenger_name"=>"Test Example", "customer_code"=>1, "issuing_carrier"=>"AAAA", "total_fare"=>5000, "agency_name"=>"Agency", "agency_code"=>"AG001"}, "legs"=>[{"departure_date"=>"2018-02-05", "carrier_code"=>12, "service_class"=>1, "origin_city"=>"VAR", "destination_city"=>"FRA", "stopover_code"=>0, "fare_basis_code"=>1, "flight_number"=>"W6666", "departure_time"=>"11:37", "departure_time_segment"=>"A"}, {"departure_date"=>"2018-02-05", "carrier_code"=>12, "service_class"=>1, "origin_city"=>"VAR", "destination_city"=>"BER", "stopover_code"=>0, "fare_basis_code"=>1, "flight_number"=>"W6666", "departure_time"=>"11:37", "departure_time_segment"=>"A"}]}");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.sale(
{
"...": "",
"travel": {
"ticket": {
"ticket_number": 123456789012345,
"passenger_name": "Test Example",
"customer_code": 1,
"issuing_carrier": "AAAA",
"total_fare": 5000,
"agency_name": "Agency",
"agency_code": "AG001"
},
"legs": [
{
"departure_date": "2018-02-05",
"carrier_code": 12,
"service_class": 1,
"origin_city": "VAR",
"destination_city": "FRA",
"stopover_code": 0,
"fare_basis_code": 1,
"flight_number": "W6666",
"departure_time": "11:37",
"departure_time_segment": "A"
},
{
"departure_date": "2018-02-05",
"carrier_code": 12,
"service_class": 1,
"origin_city": "VAR",
"destination_city": "BER",
"stopover_code": 0,
"fare_basis_code": 1,
"flight_number": "W6666",
"departure_time": "11:37",
"departure_time_segment": "A"
}
]
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<.../>
<travel>
<ticket>
<ticket_number>123456789012345</ticket_number>
<passenger_name>Test Example</passenger_name>
<customer_code>1</customer_code>
<issuing_carrier>AAAA</issuing_carrier>
<total_fare>5000</total_fare>
<agency_name>Agency</agency_name>
<agency_code>AG001</agency_code>
</ticket>
<legs>
<leg>
<departure_date>2018-02-05</departure_date>
<carrier_code>12</carrier_code>
<service_class>1</service_class>
<origin_city>VAR</origin_city>
<destination_city>FRA</destination_city>
<stopover_code>0</stopover_code>
<fare_basis_code>1</fare_basis_code>
<flight_number>W6666</flight_number>
<departure_time>11:37</departure_time>
<departure_time_segment>A</departure_time_segment>
</leg>
<leg>
<departure_date>2018-02-05</departure_date>
<carrier_code>12</carrier_code>
<service_class>1</service_class>
<origin_city>VAR</origin_city>
<destination_city>BER</destination_city>
<stopover_code>0</stopover_code>
<fare_basis_code>1</fare_basis_code>
<flight_number>W6666</flight_number>
<departure_time>11:37</departure_time>
<departure_time_segment>A</departure_time_segment>
</leg>
</legs>
</travel>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
travel | required | ||
ticket | required* | ||
ticket_number | required* | String(15) | The number on the ticket. |
passenger_name | required* | String(29) | The name of the passenger. May be the cardholder name if the passenger name is unavailable. Must not be blank. |
customer_code | required* | String(17) | The customer code. Internal Reference. |
issuing_carrier | optional | String(4) | Contains the standard abbreviation for the airline or railway carrier issuing the ticket. |
total_fare | required* | Integer | Total amount of the ticket and should equal the amount of the transaction. |
agency_name | optional | String(30) | An entry should be supplied if a travel agency issued the ticket. |
agency_code | optional | String(8) | An entry should be supplied if a travel agency issued the ticket. |
confirmation_information | required* | String(474) | Confirmation Information |
date_of_issue | required* | String(10) | Date Of Issue |
legs | required* | Max legs 10 | |
leg | required* | ||
departure_date | required | String(10) | The departure date. Date can be in future. |
arrival_date | required* | String(10) | The arrival date. Date can be in future. |
carrier_code | required* | String(2) | Contains the standard abbreviation for the airline or railway carrier issuing the ticket. This should not contain all spaces or zeros. Code indicating name of carrier. |
service_class | required* | String(1) | The service type. i.e. Coach, First Class. Required for reduced interchange. |
origin_city | required* | String(3) | The originating airport name‘s standard abbreviation. This should not contain all spaces or zeroes. |
destination_city | required* | String(3) | The destination airport or railway name‘s standard abbreviation. |
stopover_code | required* | String(1) | A code indicating whether there was a direct or a non-direct flight or route on the same ticket number. Allowed values: 0, 1 |
fare_basis_code | optional | String(6) | A code that carriers assign to a particular ticket type, such as business class or discounted/ non-re fundable. |
flight_number | optional | String(5) | The number that the operating or marketing carrier assigned. |
departure_time | optional | String(5) | The time of departure provided by the airline or railway, per trip leg. |
departure_time_segment | optional | String(1) | Departure Time Segment. Allowed values: A, P |
taxes | optional | Max taxes 10 | |
tax | optional | ||
fee_amount | required* | Integer | Fee Amount |
fee_type | required* | String(8) | Fee Type |
required* = conditionally required
Visa
Contract Merchant Category Code must be 3000-3350, 4511, 4722, 4723 or 5962
Visa
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Sale');
$request = $genesis->request();
$request
->set...('')
->setTravel('{"ticket"=>{"ticket_number"=>12345, "passenger_name"=>"Emil Example", "customer_code"=>1, "restricted_ticket_indicator"=>1, "agency_name"=>"Agency", "agency_code"=>"AG001", "confirmation_information"=>"Confirmation", "date_of_issue"=>"2018-02-01"}, "legs"=>[{"departure_date"=>"2018-02-01", "carrier_code"=>2, "service_class"=>3, "origin_city"=>"SOF", "destination_city"=>"VAR", "stopover_code"=>0, "fare_basis_code"=>1, "flight_number"=>"W6666"}], "taxes"=>[{"fee_amount"=>1000, "fee_type"=>"Airport tax"}]}');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.SaleRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
SaleRequest request = new SaleRequest();
request.set...("");
request.setTravel("{"ticket"=>{"ticket_number"=>12345, "passenger_name"=>"Emil Example", "customer_code"=>1, "restricted_ticket_indicator"=>1, "agency_name"=>"Agency", "agency_code"=>"AG001", "confirmation_information"=>"Confirmation", "date_of_issue"=>"2018-02-01"}, "legs"=>[{"departure_date"=>"2018-02-01", "carrier_code"=>2, "service_class"=>3, "origin_city"=>"SOF", "destination_city"=>"VAR", "stopover_code"=>0, "fare_basis_code"=>1, "flight_number"=>"W6666"}], "taxes"=>[{"fee_amount"=>1000, "fee_type"=>"Airport tax"}]}");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.sale(
{
"...": "",
"travel": {
"ticket": {
"ticket_number": 12345,
"passenger_name": "Emil Example",
"customer_code": 1,
"restricted_ticket_indicator": 1,
"agency_name": "Agency",
"agency_code": "AG001",
"confirmation_information": "Confirmation",
"date_of_issue": "2018-02-01"
},
"legs": [
{
"departure_date": "2018-02-01",
"carrier_code": 2,
"service_class": 3,
"origin_city": "SOF",
"destination_city": "VAR",
"stopover_code": 0,
"fare_basis_code": 1,
"flight_number": "W6666"
}
],
"taxes": [
{
"fee_amount": 1000,
"fee_type": "Airport tax"
}
]
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<.../>
<travel>
<ticket>
<ticket_number>12345</ticket_number>
<passenger_name>Emil Example</passenger_name>
<customer_code>1</customer_code>
<restricted_ticket_indicator>1</restricted_ticket_indicator>
<agency_name>Agency</agency_name>
<agency_code>AG001</agency_code>
<confirmation_information>Confirmation</confirmation_information>
<date_of_issue>2018-02-01</date_of_issue>
</ticket>
<legs>
<leg>
<departure_date>2018-02-01</departure_date>
<carrier_code>2</carrier_code>
<service_class>3</service_class>
<origin_city>SOF</origin_city>
<destination_city>VAR</destination_city>
<stopover_code>0</stopover_code>
<fare_basis_code>1</fare_basis_code>
<flight_number>W6666</flight_number>
</leg>
</legs>
<taxes>
<taxe>
<fee_amount>1000</fee_amount>
<fee_type>Airport tax</fee_type>
</taxe>
</taxes>
</travel>
</payment_transaction>'
Visa Multiple Legs
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Sale');
$request = $genesis->request();
$request
->set...('')
->setTravel('{"ticket"=>{"ticket_number"=>123456789012345, "passenger_name"=>"Test Example", "customer_code"=>1, "restricted_ticket_indicator"=>1, "agency_name"=>"Agency", "agency_code"=>"AG001"}, "legs"=>[{"departure_date"=>"2018-02-01", "carrier_code"=>2, "service_class"=>3, "origin_city"=>"SOF", "destination_city"=>"VAR", "stopover_code"=>0, "fare_basis_code"=>1, "flight_number"=>"W6666"}, {"departure_date"=>"2018-02-01", "carrier_code"=>2, "service_class"=>3, "origin_city"=>"VAR", "destination_city"=>"FRA", "stopover_code"=>0, "fare_basis_code"=>1, "flight_number"=>"W6366"}]}');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.SaleRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
SaleRequest request = new SaleRequest();
request.set...("");
request.setTravel("{"ticket"=>{"ticket_number"=>123456789012345, "passenger_name"=>"Test Example", "customer_code"=>1, "restricted_ticket_indicator"=>1, "agency_name"=>"Agency", "agency_code"=>"AG001"}, "legs"=>[{"departure_date"=>"2018-02-01", "carrier_code"=>2, "service_class"=>3, "origin_city"=>"SOF", "destination_city"=>"VAR", "stopover_code"=>0, "fare_basis_code"=>1, "flight_number"=>"W6666"}, {"departure_date"=>"2018-02-01", "carrier_code"=>2, "service_class"=>3, "origin_city"=>"VAR", "destination_city"=>"FRA", "stopover_code"=>0, "fare_basis_code"=>1, "flight_number"=>"W6366"}]}");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.sale(
{
"...": "",
"travel": {
"ticket": {
"ticket_number": 123456789012345,
"passenger_name": "Test Example",
"customer_code": 1,
"restricted_ticket_indicator": 1,
"agency_name": "Agency",
"agency_code": "AG001"
},
"legs": [
{
"departure_date": "2018-02-01",
"carrier_code": 2,
"service_class": 3,
"origin_city": "SOF",
"destination_city": "VAR",
"stopover_code": 0,
"fare_basis_code": 1,
"flight_number": "W6666"
},
{
"departure_date": "2018-02-01",
"carrier_code": 2,
"service_class": 3,
"origin_city": "VAR",
"destination_city": "FRA",
"stopover_code": 0,
"fare_basis_code": 1,
"flight_number": "W6366"
}
]
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<.../>
<travel>
<ticket>
<ticket_number>123456789012345</ticket_number>
<passenger_name>Test Example</passenger_name>
<customer_code>1</customer_code>
<restricted_ticket_indicator>1</restricted_ticket_indicator>
<agency_name>Agency</agency_name>
<agency_code>AG001</agency_code>
</ticket>
<legs>
<leg>
<departure_date>2018-02-01</departure_date>
<carrier_code>2</carrier_code>
<service_class>3</service_class>
<origin_city>SOF</origin_city>
<destination_city>VAR</destination_city>
<stopover_code>0</stopover_code>
<fare_basis_code>1</fare_basis_code>
<flight_number>W6666</flight_number>
</leg>
<leg>
<departure_date>2018-02-01</departure_date>
<carrier_code>2</carrier_code>
<service_class>3</service_class>
<origin_city>VAR</origin_city>
<destination_city>FRA</destination_city>
<stopover_code>0</stopover_code>
<fare_basis_code>1</fare_basis_code>
<flight_number>W6366</flight_number>
</leg>
</legs>
</travel>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
travel | required | ||
ticket | required* | ||
ticket_number | required* | String(15) | The number on the ticket. |
passenger_name | required* | String(29) | The name of the passenger. May be the cardholder name if the passenger name is unavailable. Must not be blank. |
customer_code | required* | String(17) | The customer code. Internal Reference. |
confirmation_information | required* | String(474) | Confirmation Information |
date_of_issue | required* | String(10) | Date Of Issue |
restricted_ticket_indicator | optional | String(1) | Space or 0 = No restriction, 1 = Restriction; Allowed values: Empty String, 0, 1 |
agency_name | optional | String(30) | An entry should be supplied if a travel agency issued the ticket. |
agency_code | optional | String(8) | An entry should be supplied if a travel agency issued the ticket. |
legs | required* | Max legs 10 | |
leg | required* | ||
departure_date | required | String(10) | The departure date. Date can be in future. |
arrival_date | required* | String(10) | The arrival date. Date can be in future. |
origin_city | required* | String(3) | The originating airport name‘s standard abbreviation. This should not contain all spaces or zeroes. |
carrier_code | required* | String(2) | Contains the standard abbreviation for the airline or railway carrier issuing the ticket. This should not contain all spaces or zeros. Code indicating name of carrier. |
service_class | required* | String(1) | The service type. i.e. Coach, First Class. Required for reduced interchange. |
stopover_code | required* | String(1) | A code indicating whether there was a direct or a non-direct flight or route on the same ticket number. Allowed values: 0, 1 |
destination_city | required* | String(3) | The destination airport or railway name‘s standard abbreviation. |
fare_basis_code | optional | String(6) | A code that carriers assign to a particular ticket type, such as business class or discounted/ non-re fundable. |
flight_number | optional | String(5) | The number that the operating or marketing carrier assigned. |
taxes | optional | Max taxes 10 | |
tax | optional | ||
fee_amount | required* | Integer | Fee Amount |
fee_type | required* | String(8) | Fee Type |
required* = conditionally required
Car Rental
MasterCard
Contract Merchant Category Code must be 3351-3500, 4722, 4723, 5962, 7512, 7513, 7519
Master Card
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Sale');
$request = $genesis->request();
$request
->set...('')
->setTravel('{"rentals"=>{"car_rental"=>{"purchase_identifier"=>12478, "class_id"=>3, "pickup_date"=>"2018-02-05", "renter_name"=>"Emil Example", "return_city"=>"Varna", "return_state"=>"VAR", "return_country"=>"BGR", "return_date"=>"2018-02-06", "renter_return_location_id"=>12478, "customer_code"=>1}}}');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.SaleRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
SaleRequest request = new SaleRequest();
request.set...("");
request.setTravel("{"rentals"=>{"car_rental"=>{"purchase_identifier"=>12478, "class_id"=>3, "pickup_date"=>"2018-02-05", "renter_name"=>"Emil Example", "return_city"=>"Varna", "return_state"=>"VAR", "return_country"=>"BGR", "return_date"=>"2018-02-06", "renter_return_location_id"=>12478, "customer_code"=>1}}}");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.sale(
{
"...": "",
"travel": {
"rentals": {
"car_rental": {
"purchase_identifier": 12478,
"class_id": 3,
"pickup_date": "2018-02-05",
"renter_name": "Emil Example",
"return_city": "Varna",
"return_state": "VAR",
"return_country": "BGR",
"return_date": "2018-02-06",
"renter_return_location_id": 12478,
"customer_code": 1
}
}
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<.../>
<travel>
<rentals>
<car_rental>
<purchase_identifier>12478</purchase_identifier>
<class_id>3</class_id>
<pickup_date>2018-02-05</pickup_date>
<renter_name>Emil Example</renter_name>
<return_city>Varna</return_city>
<return_state>VAR</return_state>
<return_country>BGR</return_country>
<return_date>2018-02-06</return_date>
<renter_return_location_id>12478</renter_return_location_id>
<customer_code>1</customer_code>
</car_rental>
</rentals>
</travel>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
travel | required | ||
rentals | required | ||
car_rental | required | ||
purchase_identifier | required* | String(9) | Rental Agreement Number / Hotel Folio Number. |
class_id | required* | String(4) | The car rental classification. Allowed values: 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 9999 |
pickup_date | required | String(10) | Car rental Pick-up date. |
renter_name | required* | String(20) | The Renter Name |
return_city | required* | String(18) | The Rental Return City |
return_state | required* | String(3) | The Rental Return State |
return_country | required* | String(3) | The Rental Return Country |
return_date | required | String(10) | Car Rental return date |
renter_return_location_id | required* | String(10) | Expenses or Car Rental code, Address, phone number, etc. Identifying Rental Return Location. |
customer_code | required* | String(17) | The customer code. Internal Reference. |
required* = conditionally required
Visa
Contract Merchant Category Code must be 3351-3500, 4722, 4723, 5962, 7512, 7513, 7519
Visa
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Sale');
$request = $genesis->request();
$request
->set...('')
->setTravel('{"rentals"=>{"car_rental"=>{"purchase_identifier"=>12478, "class_id"=>3, "pickup_date"=>"2018-02-05", "renter_name"=>"Emil Example", "return_city"=>"Varna", "return_state"=>"VAR", "return_country"=>"BGR", "return_date"=>"2018-02-06", "renter_return_location_id"=>12478, "customer_code"=>1}}}');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.SaleRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
SaleRequest request = new SaleRequest();
request.set...("");
request.setTravel("{"rentals"=>{"car_rental"=>{"purchase_identifier"=>12478, "class_id"=>3, "pickup_date"=>"2018-02-05", "renter_name"=>"Emil Example", "return_city"=>"Varna", "return_state"=>"VAR", "return_country"=>"BGR", "return_date"=>"2018-02-06", "renter_return_location_id"=>12478, "customer_code"=>1}}}");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.sale(
{
"...": "",
"travel": {
"rentals": {
"car_rental": {
"purchase_identifier": 12478,
"class_id": 3,
"pickup_date": "2018-02-05",
"renter_name": "Emil Example",
"return_city": "Varna",
"return_state": "VAR",
"return_country": "BGR",
"return_date": "2018-02-06",
"renter_return_location_id": 12478,
"customer_code": 1
}
}
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<.../>
<travel>
<rentals>
<car_rental>
<purchase_identifier>12478</purchase_identifier>
<class_id>3</class_id>
<pickup_date>2018-02-05</pickup_date>
<renter_name>Emil Example</renter_name>
<return_city>Varna</return_city>
<return_state>VAR</return_state>
<return_country>BGR</return_country>
<return_date>2018-02-06</return_date>
<renter_return_location_id>12478</renter_return_location_id>
<customer_code>1</customer_code>
</car_rental>
</rentals>
</travel>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
travel | required | ||
rentals | required | ||
car_rental | required | ||
purchase_identifier | optional | String(25) | Rental Agreement Number / Hotel Folio Number |
pickup_date | required* | String(10) | Car rental Pick-up date. |
return_date | required* | String(10) | Car rental Return date. |
extra_charges | optional | Array(6) | Additional charges added to customer bill after check-out. Each position can be used to indicate a type of charge; Allowed values: 1, 2, 3, 4, 5 |
no_show_indicator | optional | String(1) | No show indicator; Allowed values: 0, 1 |
required* = conditionally required
Hotel Rental
MasterCard
Contract Merchant Category Code must be 3501-3999, 4722, 4723, 5962, 7011
Master Card
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Sale');
$request = $genesis->request();
$request
->set...('')
->setTravel('{"rentals"=>{"hotel_rental"=>{"purchase_identifier"=>12478, "arrival_date"=>3, "departure_date"=>"2018-02-05", "customer_code"=>1}}}');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.SaleRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
SaleRequest request = new SaleRequest();
request.set...("");
request.setTravel("{"rentals"=>{"hotel_rental"=>{"purchase_identifier"=>12478, "arrival_date"=>3, "departure_date"=>"2018-02-05", "customer_code"=>1}}}");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.sale(
{
"...": "",
"travel": {
"rentals": {
"hotel_rental": {
"purchase_identifier": 12478,
"arrival_date": 3,
"departure_date": "2018-02-05",
"customer_code": 1
}
}
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<.../>
<travel>
<rentals>
<hotel_rental>
<purchase_identifier>12478</purchase_identifier>
<arrival_date>3</arrival_date>
<departure_date>2018-02-05</departure_date>
<customer_code>1</customer_code>
</hotel_rental>
</rentals>
</travel>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
travel | required | ||
rentals | required | ||
hotel_rental | required | ||
purchase_identifier | required* | String(10) | Rental Agreement Number / Hotel Folio Number. |
arrival_date | required | String(10) | Hotel check-in date. |
departure_date | required | String(10) | The departure date. Date can be in future. |
customer_code | required* | String(17) | The customer code. Internal Reference. |
required* = conditionally required
Visa
Contract Merchant Category Code must be 3501-3999, 4722, 4723, 5962, 7011
Visa
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Sale');
$request = $genesis->request();
$request
->set...('')
->setTravel('{"rentals"=>{"hotel_rental"=>{"purchase_identifier"=>2, "arrival_date"=>"2018-02-01", "extra_charges"=>467, "no_show_indicator"=>1}}}');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.SaleRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
SaleRequest request = new SaleRequest();
request.set...("");
request.setTravel("{"rentals"=>{"hotel_rental"=>{"purchase_identifier"=>2, "arrival_date"=>"2018-02-01", "extra_charges"=>467, "no_show_indicator"=>1}}}");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.sale(
{
"...": "",
"travel": {
"rentals": {
"hotel_rental": {
"purchase_identifier": 2,
"arrival_date": "2018-02-01",
"extra_charges": 467,
"no_show_indicator": 1
}
}
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<.../>
<travel>
<rentals>
<hotel_rental>
<purchase_identifier>2</purchase_identifier>
<arrival_date>2018-02-01</arrival_date>
<extra_charges>467</extra_charges>
<no_show_indicator>1</no_show_indicator>
</hotel_rental>
</rentals>
</travel>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
travel | required | ||
rentals | required | ||
hotel_rental | required | ||
purchase_identifier | optional | String(25) | Rental Agreement Number / Hotel Folio Number |
arrival_date | required* | String(10) | Hotel rental Pick-up date. |
departure_date | required* | String(10) | Hotel rental Departure date. |
extra_charges | optional | Array(6) | Additional charges added to customer bill after check-out. Each position can be used to indicate a type of charge. Allowed values: 2, 3, 4, 5, 6, 7 |
no_show_indicator | optional | String(1) | No show indicator; Allowed values: 0, 1 |
required* = conditionally required
Ancillary Charges
Ancillary Charges
Charges/fees related to the ticket. These transactions are processed on a separate transaction, referenced to Airline transaction with AID.
MasterCard
Used to identify only Baggage Charges.
Contract Merchant Category Code must be 3000-3350, 4511, 4722, 4723 or 5962
Master Card
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Sale');
$request = $genesis->request();
$request
->set...('')
->setTravel('{"ticket"=>{"ticket_reference_id"=>"8b7e3575e5605ea7e1895707a3e92837"}, "charges"=>{"charge"=>{"type"=>"BG"}}}');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.SaleRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
SaleRequest request = new SaleRequest();
request.set...("");
request.setTravel("{"ticket"=>{"ticket_reference_id"=>"8b7e3575e5605ea7e1895707a3e92837"}, "charges"=>{"charge"=>{"type"=>"BG"}}}");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.sale(
{
"...": "",
"travel": {
"ticket": {
"ticket_reference_id": "8b7e3575e5605ea7e1895707a3e92837"
},
"charges": {
"charge": {
"type": "BG"
}
}
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<.../>
<travel>
<ticket>
<ticket_reference_id>8b7e3575e5605ea7e1895707a3e92837</ticket_reference_id>
</ticket>
<charges>
<charge>
<type>BG</type>
</charge>
</charges>
</travel>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
travel | required | ||
ticket | required | ||
ticket_reference_id | required | String(32) | Unique id of the ticket transaction |
charges | required | ||
charge | required | ||
type | required | String(2) | This field will contain the Service Category Code for the primary type of service that has been provided. Allowed values: BG |
required* = conditionally required
Visa
Used to identify charges for a number of ancillary services such as ticket upgrades, baggage fee, food & beverage purchases which are not purchased as part of the original ticket. Also used for charges/fees related to partial airline ticket refunds or ticket cancellations.
Contract Merchant Category Code must be 3000-3350, 4511, 4722, 4723 or 5962
Visa
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Sale');
$request = $genesis->request();
$request
->set...('')
->setTravel('{"ticket"=>{"ticket_reference_id"=>"8b7e3575e5605ea7e1895707a3e92837", "ticket_document_number"=>1111, "issued_with_ticket_number"=>12321}, "charges"=>{"charge"=>{"type"=>"BF", "sub_type"=>"BG"}}}');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.SaleRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
SaleRequest request = new SaleRequest();
request.set...("");
request.setTravel("{"ticket"=>{"ticket_reference_id"=>"8b7e3575e5605ea7e1895707a3e92837", "ticket_document_number"=>1111, "issued_with_ticket_number"=>12321}, "charges"=>{"charge"=>{"type"=>"BF", "sub_type"=>"BG"}}}");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.sale(
{
"...": "",
"travel": {
"ticket": {
"ticket_reference_id": "8b7e3575e5605ea7e1895707a3e92837",
"ticket_document_number": 1111,
"issued_with_ticket_number": 12321
},
"charges": {
"charge": {
"type": "BF",
"sub_type": "BG"
}
}
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<.../>
<travel>
<ticket>
<ticket_reference_id>8b7e3575e5605ea7e1895707a3e92837</ticket_reference_id>
<ticket_document_number>1111</ticket_document_number>
<issued_with_ticket_number>12321</issued_with_ticket_number>
</ticket>
<charges>
<charge>
<type>BF</type>
<sub_type>BG</sub_type>
</charge>
</charges>
</travel>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
travel | required | ||
ticket | required | ||
ticket_reference_id | required | String(32) | Unique id of the ticket transaction |
ticket_document_number | required | String(15) | This field will contain the form number assigned by the carrier for the transaction. |
issued_with_ticket_number | required | String(15) | If this purchase has a connection or relationship to another purchase, such as baggage fee for a passenger transport ticket, this field must contain the document number for the other purchase. |
charges | required | ||
charge | required | ||
type | required | String(2) | This field will contain the Service Category Code for the primary type of service that has been provided. Allowed values: BF, BG, CF, CG, CO, FF, GF, GT, IE, LG, MD, ML, OT, PA, PT, SA, SB, SF, ST, TS, UN, UP, WI |
sub_type | required | String(2) | This field will contain the Service Category Code for the secondary type of service that has been provided Allowed values: BF, BG, CF, CG, CO, FF, GF, GT, IE, LG, MD, ML, OT, PA, PT, SA, SB, SF, ST, TS, UN, UP, WI |
required* = conditionally required
Miscellaneous Charges
Miscellaneous charges related to the travel, but not related to the ticket.
MasterCard
Contract Merchant Category Code must be 3000-3350, 4511, 4722, 4723 or 5962
Master Card
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Sale');
$request = $genesis->request();
$request
->set...('')
->setTravel('{"ticket"=>{"ticket_reference_id"=>"8b7e3575e5605ea7e1895707a3e92837"}, "charges"=>{"charge"=>{"type"=>"MISC"}}}');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.SaleRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
SaleRequest request = new SaleRequest();
request.set...("");
request.setTravel("{"ticket"=>{"ticket_reference_id"=>"8b7e3575e5605ea7e1895707a3e92837"}, "charges"=>{"charge"=>{"type"=>"MISC"}}}");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.sale(
{
"...": "",
"travel": {
"ticket": {
"ticket_reference_id": "8b7e3575e5605ea7e1895707a3e92837"
},
"charges": {
"charge": {
"type": "MISC"
}
}
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<.../>
<travel>
<ticket>
<ticket_reference_id>8b7e3575e5605ea7e1895707a3e92837</ticket_reference_id>
</ticket>
<charges>
<charge>
<type>MISC</type>
</charge>
</charges>
</travel>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
travel | required | ||
ticket | required | ||
ticket_reference_id | required | String(32) | Unique id of the ticket transaction |
charges | required | ||
charge | required | ||
type | required | String(4) | This field will contain the Service Category Code for the primary type of service that has been provided. Allowed values: MISC |
required* = conditionally required
Visa
Contract Merchant Category Code must be 3000-3350, 4511, 4722, 4723 or 5962
Visa
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Sale');
$request = $genesis->request();
$request
->set...('')
->setTravel('{"ticket"=>{"ticket_reference_id"=>"8b7e3575e5605ea7e1895707a3e92837"}, "charges"=>{"charge"=>{"type"=>"MISC"}}}');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.SaleRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
SaleRequest request = new SaleRequest();
request.set...("");
request.setTravel("{"ticket"=>{"ticket_reference_id"=>"8b7e3575e5605ea7e1895707a3e92837"}, "charges"=>{"charge"=>{"type"=>"MISC"}}}");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.sale(
{
"...": "",
"travel": {
"ticket": {
"ticket_reference_id": "8b7e3575e5605ea7e1895707a3e92837"
},
"charges": {
"charge": {
"type": "MISC"
}
}
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<.../>
<travel>
<ticket>
<ticket_reference_id>8b7e3575e5605ea7e1895707a3e92837</ticket_reference_id>
</ticket>
<charges>
<charge>
<type>MISC</type>
</charge>
</charges>
</travel>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
travel | required | ||
ticket | required | ||
ticket_reference_id | required | String(32) | Unique id of the ticket transaction |
charges | required | ||
charge | required | ||
type | required | String(4) | This field will contain the Service Category Code for the primary type of service that has been provided. Allowed values: MISC |
required* = conditionally required
Special Cases
Travel Authorize (3D) and Capture
The Capture travel data is always merged with the Authorize travel data and overrides the Authorization fields (where they are present in both transactions) before validating. This makes the required travel data for Authorizations optional. This logic is applied for all Travel Types. Because of this, there are 4 scenarios for submitting travel Authorization and Capture.
Travel Authorize (3D) and Travel Capture
In this scenario the Authorize and Capture transaction requests are submitted with valid travel data. The travel data that will be used for the transaction processing is the data submitted with the Capture.
Example Travel Authorize
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Authorize');
$request = $genesis->request();
$request
->setTransactionId('1915c52b28ff29edb12bc617ac102a03')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('4200000000000000')
->setCvv('834')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setTravel('{"ticket"=>{"ticket_number"=>12345678123456, "passenger_name"=>"Passenger 01", "customer_code"=>123, "restricted_ticket_indicator"=>0, "agency_name"=>"Agency", "agency_code"=>"AG001"}, "legs"=>[{"departure_date"=>"2017-03-10", "carrier_code"=>"VX", "service_class"=>"J", "origin_city"=>"DUB", "destination_city"=>"ATL", "stopover_code"=>1, "fare_basis_code"=>0, "flight_number"=>""}]}');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.AuthorizeRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
AuthorizeRequest request = new AuthorizeRequest();
request.setTransactionId("1915c52b28ff29edb12bc617ac102a03");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4200000000000000");
request.setCvv("834");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setTravel("{"ticket"=>{"ticket_number"=>12345678123456, "passenger_name"=>"Passenger 01", "customer_code"=>123, "restricted_ticket_indicator"=>0, "agency_name"=>"Agency", "agency_code"=>"AG001"}, "legs"=>[{"departure_date"=>"2017-03-10", "carrier_code"=>"VX", "service_class"=>"J", "origin_city"=>"DUB", "destination_city"=>"ATL", "stopover_code"=>1, "fare_basis_code"=>0, "flight_number"=>""}]}");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.authorize(
{
"transaction_id": "1915c52b28ff29edb12bc617ac102a03",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "4200000000000000",
"cvv": "834",
"expiration_month": "12",
"expiration_year": 2026,
"travel": {
"ticket": {
"ticket_number": 12345678123456,
"passenger_name": "Passenger 01",
"customer_code": 123,
"restricted_ticket_indicator": 0,
"agency_name": "Agency",
"agency_code": "AG001"
},
"legs": [
{
"departure_date": "2017-03-10",
"carrier_code": "VX",
"service_class": "J",
"origin_city": "DUB",
"destination_city": "ATL",
"stopover_code": 1,
"fare_basis_code": 0,
"flight_number": ""
}
]
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>authorize</transaction_type>
<transaction_id>1915c52b28ff29edb12bc617ac102a03</transaction_id>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4200000000000000</card_number>
<cvv>834</cvv>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<travel>
<ticket>
<ticket_number>12345678123456</ticket_number>
<passenger_name>Passenger 01</passenger_name>
<customer_code>123</customer_code>
<restricted_ticket_indicator>0</restricted_ticket_indicator>
<agency_name>Agency</agency_name>
<agency_code>AG001</agency_code>
</ticket>
<legs>
<leg>
<departure_date>2017-03-10</departure_date>
<carrier_code>VX</carrier_code>
<service_class>J</service_class>
<origin_city>DUB</origin_city>
<destination_city>ATL</destination_city>
<stopover_code>1</stopover_code>
<fare_basis_code>0</fare_basis_code>
<flight_number/>
</leg>
</legs>
</travel>
</payment_transaction>'
Example Travel Capture
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Capture');
$request = $genesis->request();
$request
->setTransactionId('7fcc6097153beeec1dd1e71f643198d8')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setReferenceId('1f2ee425e7c3159c60743098071771eb')
->setTravel('{"ticket"=>{"ticket_number"=>12345678123456, "passenger_name"=>"Passenger 01", "customer_code"=>"", "restricted_ticket_indicator"=>0, "agency_name"=>"New Agency", "agency_code"=>"AGN001"}, "legs"=>[{"departure_date"=>"2017-03-10", "carrier_code"=>"VX", "service_class"=>"J", "origin_city"=>"DUB", "destination_city"=>"ATL", "stopover_code"=>1, "fare_basis_code"=>0, "flight_number"=>""}]}');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.CaptureRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
CaptureRequest request = new CaptureRequest();
request.setTransactionId("7fcc6097153beeec1dd1e71f643198d8");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setReferenceId("1f2ee425e7c3159c60743098071771eb");
request.setTravel("{"ticket"=>{"ticket_number"=>12345678123456, "passenger_name"=>"Passenger 01", "customer_code"=>"", "restricted_ticket_indicator"=>0, "agency_name"=>"New Agency", "agency_code"=>"AGN001"}, "legs"=>[{"departure_date"=>"2017-03-10", "carrier_code"=>"VX", "service_class"=>"J", "origin_city"=>"DUB", "destination_city"=>"ATL", "stopover_code"=>1, "fare_basis_code"=>0, "flight_number"=>""}]}");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.capture(
{
"transaction_id": "7fcc6097153beeec1dd1e71f643198d8",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"reference_id": "1f2ee425e7c3159c60743098071771eb",
"travel": {
"ticket": {
"ticket_number": 12345678123456,
"passenger_name": "Passenger 01",
"customer_code": "",
"restricted_ticket_indicator": 0,
"agency_name": "New Agency",
"agency_code": "AGN001"
},
"legs": [
{
"departure_date": "2017-03-10",
"carrier_code": "VX",
"service_class": "J",
"origin_city": "DUB",
"destination_city": "ATL",
"stopover_code": 1,
"fare_basis_code": 0,
"flight_number": ""
}
]
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>capture</transaction_type>
<transaction_id>7fcc6097153beeec1dd1e71f643198d8</transaction_id>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<reference_id>1f2ee425e7c3159c60743098071771eb</reference_id>
<travel>
<ticket>
<ticket_number>12345678123456</ticket_number>
<passenger_name>Passenger 01</passenger_name>
<customer_code/>
<restricted_ticket_indicator>0</restricted_ticket_indicator>
<agency_name>New Agency</agency_name>
<agency_code>AGN001</agency_code>
</ticket>
<legs>
<leg>
<departure_date>2017-03-10</departure_date>
<carrier_code>VX</carrier_code>
<service_class>J</service_class>
<origin_city>DUB</origin_city>
<destination_city>ATL</destination_city>
<stopover_code>1</stopover_code>
<fare_basis_code>0</fare_basis_code>
<flight_number/>
</leg>
</legs>
</travel>
</payment_transaction>'
Non Travel Authorize (3D) and Travel Capture
In this scenario the Authorize request doesn’t contain the travel data. Valid travel data is submitted in the Capture transaction request. The travel data that will be used for the transaction processing is the data submitted with the Capture.
Example Non Travel Authorize
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Authorize');
$request = $genesis->request();
$request
->setTransactionId('1915c52b28ff29edb12bc617ac102a03')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('4200000000000000')
->setCvv('834')
->setExpirationMonth('12')
->setExpirationYear('2026');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.AuthorizeRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
AuthorizeRequest request = new AuthorizeRequest();
request.setTransactionId("1915c52b28ff29edb12bc617ac102a03");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4200000000000000");
request.setCvv("834");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.authorize(
{
"transaction_id": "1915c52b28ff29edb12bc617ac102a03",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "4200000000000000",
"cvv": "834",
"expiration_month": "12",
"expiration_year": 2026
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>authorize</transaction_type>
<transaction_id>1915c52b28ff29edb12bc617ac102a03</transaction_id>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4200000000000000</card_number>
<cvv>834</cvv>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
</payment_transaction>'
Example Travel Capture
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Capture');
$request = $genesis->request();
$request
->setTransactionId('7fcc6097153beeec1dd1e71f643198d8')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setReferenceId('1f2ee425e7c3159c60743098071771eb')
->setTravel('{"ticket"=>{"ticket_number"=>12345678123456, "passenger_name"=>"Passenger 01", "customer_code"=>"", "restricted_ticket_indicator"=>0, "agency_name"=>"New Agency", "agency_code"=>"AGN001"}, "legs"=>[{"departure_date"=>"2017-03-10", "carrier_code"=>"VX", "service_class"=>"J", "origin_city"=>"DUB", "destination_city"=>"ATL", "stopover_code"=>1, "fare_basis_code"=>0, "flight_number"=>""}]}');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.CaptureRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
CaptureRequest request = new CaptureRequest();
request.setTransactionId("7fcc6097153beeec1dd1e71f643198d8");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setReferenceId("1f2ee425e7c3159c60743098071771eb");
request.setTravel("{"ticket"=>{"ticket_number"=>12345678123456, "passenger_name"=>"Passenger 01", "customer_code"=>"", "restricted_ticket_indicator"=>0, "agency_name"=>"New Agency", "agency_code"=>"AGN001"}, "legs"=>[{"departure_date"=>"2017-03-10", "carrier_code"=>"VX", "service_class"=>"J", "origin_city"=>"DUB", "destination_city"=>"ATL", "stopover_code"=>1, "fare_basis_code"=>0, "flight_number"=>""}]}");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.capture(
{
"transaction_id": "7fcc6097153beeec1dd1e71f643198d8",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"reference_id": "1f2ee425e7c3159c60743098071771eb",
"travel": {
"ticket": {
"ticket_number": 12345678123456,
"passenger_name": "Passenger 01",
"customer_code": "",
"restricted_ticket_indicator": 0,
"agency_name": "New Agency",
"agency_code": "AGN001"
},
"legs": [
{
"departure_date": "2017-03-10",
"carrier_code": "VX",
"service_class": "J",
"origin_city": "DUB",
"destination_city": "ATL",
"stopover_code": 1,
"fare_basis_code": 0,
"flight_number": ""
}
]
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>capture</transaction_type>
<transaction_id>7fcc6097153beeec1dd1e71f643198d8</transaction_id>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<reference_id>1f2ee425e7c3159c60743098071771eb</reference_id>
<travel>
<ticket>
<ticket_number>12345678123456</ticket_number>
<passenger_name>Passenger 01</passenger_name>
<customer_code/>
<restricted_ticket_indicator>0</restricted_ticket_indicator>
<agency_name>New Agency</agency_name>
<agency_code>AGN001</agency_code>
</ticket>
<legs>
<leg>
<departure_date>2017-03-10</departure_date>
<carrier_code>VX</carrier_code>
<service_class>J</service_class>
<origin_city>DUB</origin_city>
<destination_city>ATL</destination_city>
<stopover_code>1</stopover_code>
<fare_basis_code>0</fare_basis_code>
<flight_number/>
</leg>
</legs>
</travel>
</payment_transaction>'
Travel Authorize (3D) and Non Travel Capture
In this scenario the Authorize request contains valid travel data. Travel data isn’t submitted in the Capture transaction request. In this case the Capture transaction will inherit the travel data from the Authorize transaction. The travel data that will be used for the transaction processing is the data submitted with the Authorize.
Example Travel Authorize
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Authorize');
$request = $genesis->request();
$request
->setTransactionId('1915c52b28ff29edb12bc617ac102a03')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('4200000000000000')
->setCvv('834')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setTravel('{"ticket"=>{"ticket_number"=>12345678123456, "passenger_name"=>"Passenger 01", "customer_code"=>123, "restricted_ticket_indicator"=>0, "agency_name"=>"Agency", "agency_code"=>"AG001"}, "legs"=>[{"departure_date"=>"2017-03-10", "carrier_code"=>"VX", "service_class"=>"J", "origin_city"=>"DUB", "destination_city"=>"ATL", "stopover_code"=>1, "fare_basis_code"=>0, "flight_number"=>""}]}');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.AuthorizeRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
AuthorizeRequest request = new AuthorizeRequest();
request.setTransactionId("1915c52b28ff29edb12bc617ac102a03");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4200000000000000");
request.setCvv("834");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setTravel("{"ticket"=>{"ticket_number"=>12345678123456, "passenger_name"=>"Passenger 01", "customer_code"=>123, "restricted_ticket_indicator"=>0, "agency_name"=>"Agency", "agency_code"=>"AG001"}, "legs"=>[{"departure_date"=>"2017-03-10", "carrier_code"=>"VX", "service_class"=>"J", "origin_city"=>"DUB", "destination_city"=>"ATL", "stopover_code"=>1, "fare_basis_code"=>0, "flight_number"=>""}]}");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.authorize(
{
"transaction_id": "1915c52b28ff29edb12bc617ac102a03",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "4200000000000000",
"cvv": "834",
"expiration_month": "12",
"expiration_year": 2026,
"travel": {
"ticket": {
"ticket_number": 12345678123456,
"passenger_name": "Passenger 01",
"customer_code": 123,
"restricted_ticket_indicator": 0,
"agency_name": "Agency",
"agency_code": "AG001"
},
"legs": [
{
"departure_date": "2017-03-10",
"carrier_code": "VX",
"service_class": "J",
"origin_city": "DUB",
"destination_city": "ATL",
"stopover_code": 1,
"fare_basis_code": 0,
"flight_number": ""
}
]
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>authorize</transaction_type>
<transaction_id>1915c52b28ff29edb12bc617ac102a03</transaction_id>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4200000000000000</card_number>
<cvv>834</cvv>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<travel>
<ticket>
<ticket_number>12345678123456</ticket_number>
<passenger_name>Passenger 01</passenger_name>
<customer_code>123</customer_code>
<restricted_ticket_indicator>0</restricted_ticket_indicator>
<agency_name>Agency</agency_name>
<agency_code>AG001</agency_code>
</ticket>
<legs>
<leg>
<departure_date>2017-03-10</departure_date>
<carrier_code>VX</carrier_code>
<service_class>J</service_class>
<origin_city>DUB</origin_city>
<destination_city>ATL</destination_city>
<stopover_code>1</stopover_code>
<fare_basis_code>0</fare_basis_code>
<flight_number/>
</leg>
</legs>
</travel>
</payment_transaction>'
Example Non Travel Capture
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Capture');
$request = $genesis->request();
$request
->setTransactionId('7fcc6097153beeec1dd1e71f643198d8')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setReferenceId('1f2ee425e7c3159c60743098071771eb');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.CaptureRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
CaptureRequest request = new CaptureRequest();
request.setTransactionId("7fcc6097153beeec1dd1e71f643198d8");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setReferenceId("1f2ee425e7c3159c60743098071771eb");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.capture(
{
"transaction_id": "7fcc6097153beeec1dd1e71f643198d8",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"reference_id": "1f2ee425e7c3159c60743098071771eb"
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>capture</transaction_type>
<transaction_id>7fcc6097153beeec1dd1e71f643198d8</transaction_id>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<reference_id>1f2ee425e7c3159c60743098071771eb</reference_id>
</payment_transaction>'
Partial Travel Authorize (3D) and Partial Travel Capture
In this scenario the Authorize request contains only part of the travel data. The Capture transaction request contains also part of the travel data. The travel data from the Authorize will be merged with the Capture travel data. The Capture travel data will complete/override the travel fields in the Authorize. This merged data will be stored as Capture travel data. If the merged data is valid travel data then the transaction will be processed as travel using the travel data stored in the Capture. Otherwise the transaction will be processed as a regular Capture transaction.
Example Partial Authorize
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Authorize');
$request = $genesis->request();
$request
->setTransactionId('1915c52b28ff29edb12bc617ac102a03')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setCardHolder('Travis Pastrana')
->setCardNumber('4200000000000000')
->setCvv('834')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setTravel('{"ticket"=>{}, "legs"=>[{"departure_date"=>"2017-03-10", "carrier_code"=>"VX", "service_class"=>"J", "origin_city"=>"DUB", "destination_city"=>"ATL", "stopover_code"=>1, "fare_basis_code"=>0, "flight_number"=>""}]}');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.AuthorizeRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
AuthorizeRequest request = new AuthorizeRequest();
request.setTransactionId("1915c52b28ff29edb12bc617ac102a03");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setCardHolder("Travis Pastrana");
request.setCardNumber("4200000000000000");
request.setCvv("834");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setTravel("{"ticket"=>{}, "legs"=>[{"departure_date"=>"2017-03-10", "carrier_code"=>"VX", "service_class"=>"J", "origin_city"=>"DUB", "destination_city"=>"ATL", "stopover_code"=>1, "fare_basis_code"=>0, "flight_number"=>""}]}");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.authorize(
{
"transaction_id": "1915c52b28ff29edb12bc617ac102a03",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"card_holder": "Travis Pastrana",
"card_number": "4200000000000000",
"cvv": "834",
"expiration_month": "12",
"expiration_year": 2026,
"travel": {
"ticket": {
},
"legs": [
{
"departure_date": "2017-03-10",
"carrier_code": "VX",
"service_class": "J",
"origin_city": "DUB",
"destination_city": "ATL",
"stopover_code": 1,
"fare_basis_code": 0,
"flight_number": ""
}
]
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>authorize</transaction_type>
<transaction_id>1915c52b28ff29edb12bc617ac102a03</transaction_id>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<card_holder>Travis Pastrana</card_holder>
<card_number>4200000000000000</card_number>
<cvv>834</cvv>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<travel>
<ticket/>
<legs>
<leg>
<departure_date>2017-03-10</departure_date>
<carrier_code>VX</carrier_code>
<service_class>J</service_class>
<origin_city>DUB</origin_city>
<destination_city>ATL</destination_city>
<stopover_code>1</stopover_code>
<fare_basis_code>0</fare_basis_code>
<flight_number/>
</leg>
</legs>
</travel>
</payment_transaction>'
Example Partial Capture
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Capture');
$request = $genesis->request();
$request
->setTransactionId('7fcc6097153beeec1dd1e71f643198d8')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setReferenceId('1f2ee425e7c3159c60743098071771eb')
->setTravel('{"ticket"=>{"ticket_number"=>12345678123456, "passenger_name"=>"Passenger 01", "customer_code"=>"", "restricted_ticket_indicator"=>0, "agency_name"=>"New Agency", "agency_code"=>"AGN001"}, "legs"=>[]}');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.CaptureRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
CaptureRequest request = new CaptureRequest();
request.setTransactionId("7fcc6097153beeec1dd1e71f643198d8");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setReferenceId("1f2ee425e7c3159c60743098071771eb");
request.setTravel("{"ticket"=>{"ticket_number"=>12345678123456, "passenger_name"=>"Passenger 01", "customer_code"=>"", "restricted_ticket_indicator"=>0, "agency_name"=>"New Agency", "agency_code"=>"AGN001"}, "legs"=>[]}");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.capture(
{
"transaction_id": "7fcc6097153beeec1dd1e71f643198d8",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"reference_id": "1f2ee425e7c3159c60743098071771eb",
"travel": {
"ticket": {
"ticket_number": 12345678123456,
"passenger_name": "Passenger 01",
"customer_code": "",
"restricted_ticket_indicator": 0,
"agency_name": "New Agency",
"agency_code": "AGN001"
},
"legs": [
]
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_type>capture</transaction_type>
<transaction_id>7fcc6097153beeec1dd1e71f643198d8</transaction_id>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<reference_id>1f2ee425e7c3159c60743098071771eb</reference_id>
<travel>
<ticket>
<ticket_number>12345678123456</ticket_number>
<passenger_name>Passenger 01</passenger_name>
<customer_code/>
<restricted_ticket_indicator>0</restricted_ticket_indicator>
<agency_name>New Agency</agency_name>
<agency_code>AGN001</agency_code>
</ticket>
<legs/>
</travel>
</payment_transaction>'
Visa Refund
Visa Refund
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Refund');
$request = $genesis->request();
$request
->set...('')
->setTravel('{"ticket"=>{"credit_reason_indicator_1"=>"C", "credit_reason_indicator_2"=>"A", "ticket_change_indicator"=>"B"}}');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.RefundRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
RefundRequest request = new RefundRequest();
request.set...("");
request.setTravel("{"ticket"=>{"credit_reason_indicator_1"=>"C", "credit_reason_indicator_2"=>"A", "ticket_change_indicator"=>"B"}}");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.refund(
{
"...": "",
"travel": {
"ticket": {
"credit_reason_indicator_1": "C",
"credit_reason_indicator_2": "A",
"ticket_change_indicator": "B"
}
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<.../>
<travel>
<ticket>
<credit_reason_indicator_1>C</credit_reason_indicator_1>
<credit_reason_indicator_2>A</credit_reason_indicator_2>
<ticket_change_indicator>B</ticket_change_indicator>
</ticket>
</travel>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
travel | optional | ||
ticket | optional | ||
credit_reason_indicator_1 | optional | String(1) | This field indicates the reason for a credit to the cardholder. Allowed values: A, B, P, O |
credit_reason_indicator_2 | optional | String(1) | This field indicates the reason for a credit to the cardholder. Allowed values: A, B, P, O |
ticket_change_indicator | optional | String(1) | This field will contain either a space or a code to indicate why a ticket was changed. Allowed values: C, N |
required* = conditionally required
Allowed Values
Car Rental Classes
Value | Description |
---|---|
1 | Mini |
2 | Subcompact |
3 | Economy |
4 | Compact |
5 | Midsize |
6 | Intermediate |
7 | Standard |
8 | Full size |
9 | Luxury |
10 | Premium |
11 | Minivan |
12 | 12 passenger van |
13 | Moving van |
14 | 15 passenger van |
15 | Cargo van |
16 | 12 foot truck |
17 | 20 foot truck |
18 | 24 foot truck |
19 | 26 foot truck |
20 | Moped |
21 | Stretch limousine |
22 | Regular limousine |
23 | Unique limousine |
24 | Exotic limousine |
25 | Small/medium truck |
26 | Large truck |
27 | Small SUV |
28 | Medium SUV |
29 | Large SUV |
30 | Exotic SUV |
9999 | Miscellaneous |
Charge Types
Value | Description |
---|---|
BF | Bundled Service |
BG | Baggage Fee |
CF | Change Fee |
CG | Cargo |
CO | Carbon Offset |
FF | Frequent Flyer |
GF | Gift Card |
GT | Ground Transport |
IE | In-flight Entertainment |
LG | Lounge |
MD | Medical |
ML | Meal / Beverage |
OT | Other |
PA | Passenger Assist Fee |
PT | Pets |
SA | Seat Fees |
SB | Standby |
SF | Service Fee |
ST | Store |
TS | Travel Service |
UN | Unaccompanied Travel |
UP | Upgrades |
WI | Wi-Fi |
MISC | Miscellaneous Airline Charges |
Car Rental Extra Charges
Value | Description |
---|---|
1 | Gas |
2 | Extra Mileage |
3 | Late Return |
4 | 1 Way Ser Fee |
5 | Parking Violation |
Hotel Rental Extra Charges
Value | Description |
---|---|
2 | Restaurant |
3 | Gift Shop |
4 | Mini Bar |
5 | Telephone |
6 | Laundry |
7 | Other |
Ticket Change Indicators
Value | Description |
---|---|
C | Change to existing Ticket |
N | New ticket |
Credit Reason Indicators
Value | Description |
---|---|
A | Passenger Transport Ancillary Cancellation |
B | Travel Ticket and Passenger Transport |
P | Partial Refund of Travel Ticket |
O | Other |
Genesis SCA Services
General Info
Genesis SCA(Strong Customer Authentication) Services provides the ability to check if a transaction is in the scope of SCA. The API is synchronous
and is based on RESTFul practices. Be sure to set Content-type: application/json
in your headers.
To interact with the SCA API, you need to provide login credentials using standard HTTP Basic Authentication. (Credentials can be found in your Admin interface.)
SCA Checker
This call is used to check if SCA is required
POST /v1/sca/checker/:terminal_token
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/v1/sca/checker/:terminal_token \
-X POST \
-H "Content-Type: application/json" \
-d '
{
"card_number": "4200000000000000",
"moto": false,
"mit": false,
"recurring": false,
"transaction_amount": 350000,
"transaction_currency": "EUR",
"transaction_exemption": ""
}'
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
[
{
"sca_required": "no",
"sca_result_reason": "Issuer out of the EEA",
"exemption": null
}
]
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
card_number | required | string(16) | Full card number or first 6 digits. |
transaction_amount | required | number | Amount of transaction in minor currency unit. |
transaction_currency | required | string(3) | Transaction currency |
moto | optional | boolean | Signifies whether a MOTO (mail order telephone order) transaction is performed. |
mit | optional | boolean | Signifies whether a MIT (merchant initiated transaction) is performed. |
recurring | optional | boolean | Signifies whether subsequent recurring transaction is performed. NOTE: field is DEPRECATED |
recurring_type | optional | string(255) | Specifies recurring type of the transaction: initial or subsequent. |
transaction_exemption | optional | string(30) | Exemption |
required* = conditionally required
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
sca_required | string | Sca Required. Possible values are yes , possible_exemption or no |
sca_result_reason | string | The reason for the returned SCA required |
exemption | string | Detected exemption. Check SCA exemption values. |
SCA Exemption Values
Value |
---|
low_value |
low_risk |
trusted_merchant |
corporate_payment |
delegated_authentication |
auth_network_outage |
SCA Reason For Not Honoring Exemption Values
Value | Translation |
---|---|
8901 | Merchant not participating in Visa trusted listing |
8902 | Issuer not participating in trusted listing program |
8903 | Cardholder has not trusted the merchant |
8904 | Response from issuer is indeterminate |
8905 | No entry for VMID was found in supplementary database |
8906 | TRA risk analysis did not meet exemption criteria |
8473 | Cardholder has not trusted the merchant (issuer supplied) |
8474 | Did not meet the exemption criteria (issuer supplied) trusted listing |
8A01 | Merchant not participating in delegated authentication |
8A02 | Issuer not participating in delegated authentication |
8A04 | Indeterminate or invalid issuer response |
8A06 | Did not meet exemption criteria |
8A07 | VMID invalid for service |
8A08 | CAVV Invalid value |
8A76 | Did not meet exemption criteria |
SCA Exemption Result Values
Value | Translation |
---|---|
13 | Low value exemption not honoured |
22 | TRA exemption honoured |
23 | TRA exemption not honoured |
32 | Trusted merchant exemption honoured |
33 | Trusted merchant exemption not honoured |
42 | Secure corporate payment exemption honoured |
43 | Secure corporate payment exemption not honoured |
52 | Delegated authentication honoured |
53 | Delegated authentication not honoured |
Funding Transactions
General Info
Funding transactions are special types of transactions and they require identifier type and receiver related details including receiver name, country, account number and account type. See the below tables for available identifier types and receiver account types.
Funding Transaction identifier types
Value | Required MCCs |
---|---|
general_person_to_person | 4829, 6538, 6540 |
person_to_person_card_account | 4829 |
own_account | 4829, 6051, 6211, 6538, 6540, 7800, 7801, 7802, 7994, 7995, 9406 |
own_credit_card_bill | 4829, 6538 |
business_disbursement | any |
government_or_non_profit_disbursement | any |
rapid_merchant_settlement | any |
general_business_to_business | any |
own_staged_digital_wallet_account | any |
own_debit_or_prepaid_card_account | any |
Funding Transaction Business Application Identifier Types
Value |
---|
funds_disbursement |
pension_disbursement |
account_to_account |
bank_initiated |
fund_transfer |
person_to_person |
prepaid_card_load |
wallet_transfer |
liquid_assets |
Funding Transaction Receiver Account types
Value | Description |
---|---|
rtn_and_bank_account_number | Routing Transit Number and Bank Account Number |
iban | International Bank Account Number |
card_account | Card Account |
Electronic Mail | |
phone_number | Phone Number |
bank_account_number_and_bic | Bank Account Number and Business Identifier Code |
wallet_id | Wallet ID |
social_network_id | Unique Identifier for Social Network Application |
other | Any other type |
Account Name Inquiry
Introduction
Account Name Inquiry is a functionality that enables an account cardholder's name to be checked against the name held by their issuing bank. The check is carried out in advance of a transaction at time of customer onboarding, just before a transaction, periodically, or on an ad-hoc basis.
The name match result is returned to the requester, or originator, consisting of match results (match/partial/no) for each name sent (first/middle/last), as well as an overall match result for the complete name set.
How to use account name inquiry parameters
Requests
Merchants can send account name inquiry params in the request when creating Authorize, Authorize3d, Sale, Sale3d, InitRecurringSale, InitRecurringSale3d, AccountVerification, Payout or Credit transactions via the Processing API and/or WPF API.
Account Name Inquiry
<?php
// Load the pre-configured ini file...
\Genesis\Config::loadSettings('/path/to/config.ini');
try {
$genesis = new Genesis('Financial\Cards\Sale');
$request = $genesis->request();
$request
->setTransactionId('119643250547501c79d8295')
->setUsage('40208 concert tickets')
->setRemoteIp('245.253.2.12')
->setAmount('100')
->setCurrency('USD')
->setToken('ee946db8-d7db-4bb7-b608-b65b153e127d')
->setCardHolder('Travis Pastrana')
->setCvv('834')
->setExpirationMonth('12')
->setExpirationYear('2026')
->setCustomerEmail('travis@example.com')
->setCustomerPhone('+1987987987987')
// Account Owner
->setAccountFirstName('Travis')
->setAccountMiddleName('Joe')
->setAccountLastName('Pastrana');
$genesis->execute();
$response = $genesis->response()->getResponseObject();
} catch (\Genesis\Exceptions\ErrorAPI $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\InvalidArgument $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\ErrorParameter $e) {
$response = $e->getMessage();
} catch (\Genesis\Exceptions\Exception $e) {
$response = $e->getMessage();
}
import com.emerchantpay.gateway.GenesisClient;
import com.emerchantpay.gateway.api.TransactionResult;
import com.emerchantpay.gateway.api.constants.Endpoints;
import com.emerchantpay.gateway.api.constants.Environments;
import com.emerchantpay.gateway.api.requests.financial.card.SaleRequest;
import com.emerchantpay.gateway.model.Transaction;
import com.emerchantpay.gateway.util.Configuration;
import com.emerchantpay.gateway.util.Country;
import com.emerchantpay.gateway.util.Currency;
import java.math.BigDecimal;
public class GenesisExample {
public static void main() {
// Create configuration
Configuration configuration = new Configuration(Environments.STAGING, Endpoints.EMERCHANTPAY);
configuration.setUsername("SET_YOUR_USERNAME");
configuration.setPassword("SET_YOUR_PASSWORD");
configuration.setToken("SET_YOUR_TOKEN");
SaleRequest request = new SaleRequest();
request.setTransactionId("119643250547501c79d8295");
request.setUsage("40208 concert tickets");
request.setRemoteIp("245.253.2.12");
request.setAmount(new BigDecimal(100));
request.setCurrency("USD");
request.setToken("ee946db8-d7db-4bb7-b608-b65b153e127d");
request.setCardHolder("Travis Pastrana");
request.setCvv("834");
request.setExpirationMonth("12");
request.setExpirationYear("2026");
request.setCustomerEmail("travis@example.com");
request.setCustomerPhone("+1987987987987");
// Account Owner
request.setAccountFirstname("Travis");
request.setAccountMiddlename("Joe");
request.setAccountLastname("Pastrana");
GenesisClient client = new GenesisClient(configuration, request);
client.execute();
// Parse Payment result
System.out.println(client.getResponse());
}
}
var genesis = require('genesis.js/lib/genesis.js');
var transaction = new genesis.transaction();
var failure = function(reason) {
return console.log(reason);
};
var success = function(data) {
return console.log(data);
};
transaction.sale(
{
"transaction_id": "119643250547501c79d8295",
"usage": "40208 concert tickets",
"remote_ip": "245.253.2.12",
"amount": "100",
"currency": "USD",
"token": "ee946db8-d7db-4bb7-b608-b65b153e127d",
"card_holder": "Travis Pastrana",
"cvv": "834",
"expiration_month": "12",
"expiration_year": 2026,
"customer_email": "travis@example.com",
"customer_phone": "+1987987987987",
"account_owner": {
"first_name": "Travis",
"middle_name": "Joe",
"last_name": "Pastrana"
}
}
).send()
.then(success)
.catch(failure);
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/process/TERMINAL-TOKEN \
-X POST \
-H "Content-Type: text/xml" \
-d '
<?xml version="1.0" encoding="UTF-8"?>
<payment_transaction>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<token>ee946db8-d7db-4bb7-b608-b65b153e127d</token>
<card_holder>Travis Pastrana</card_holder>
<cvv>834</cvv>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<account_owner>
<first_name>Travis</first_name>
<middle_name>Joe</middle_name>
<last_name>Pastrana</last_name>
</account_owner>
</payment_transaction>'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
account_owner | optional | Account owner parameters related to account owner inquiry requests | |
first_name | optional | String(35) | Account owner's first name. |
middle_name | optional | String(35) | Account owner's middle name. |
last_name | optional | String(35) | Account owner's last name. |
required* = conditionally required
Responses
Expected response values for the *_name
attributes are M - Match, P - Partial match or N - No match
Expected response values for the type
attribute are P - primary or S - secondary.
The matched text will be returned in the response if there is a response code match returned by the cardholder's issuing bank.
Successful Response
This request is not implemented yet
This request is not implemented yet
This request is not implemented yet
Response
<?xml version="1.0" encoding="UTF-8"?>
<payment_response>
<transaction_id>119643250547501c79d8295</transaction_id>
<usage>40208 concert tickets</usage>
<remote_ip>245.253.2.12</remote_ip>
<amount>100</amount>
<currency>USD</currency>
<token>ee946db8-d7db-4bb7-b608-b65b153e127d</token>
<card_holder>Travis Pastrana</card_holder>
<cvv>834</cvv>
<expiration_month>12</expiration_month>
<expiration_year>2026</expiration_year>
<customer_email>travis@example.com</customer_email>
<customer_phone>+1987987987987</customer_phone>
<account_owner>
<first_name>Travis</first_name>
<middle_name>Joe</middle_name>
<last_name>Pastrana</last_name>
<full_name_match>Partial match</full_name_match>
<first_name_match>Match</first_name_match>
<middle_name_match>No match</middle_name_match>
<last_name_match>Match</last_name_match>
<type>personal</type>
</account_owner>
</payment_response>
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
account_owner | ||
first_name | string | Account owner's first name |
middle_name | string | Account owner's middle name |
last_name | string | Account owner's last name |
full_name_match | string | Full name account match decision |
last_name_match | string | Last name account match decision |
middle_name_match | string | Middle name account match decision |
first_name_match | string | First name account match decision |
type | string | Account owner type |
Smart Routing
Introduction
The Smart Routing API is a higher-level abstraction that allows for simpler and more efficient gateway Processing API integration. It does not require the terminal token as part of the URL when creating transactions by providing an automatic routing capability. This by itself minimizes the need for complex customer-level manual routing to terminals set up on the gateway platform configuration layer.
The Smart Routing API requires the same merchant credentials and performs analogous HTTP BASIC authentication as described under the Authentication section, thus should not add any overhead for managing additional credentials.
How Smart Routing works
The Smart Routing algorithm analyzes the submitted API request and its data and matches with various parameters and enabled settings to be able to route the transaction to the right terminal under the hood.
Description of the algorithm
First it's validating that the merchant is allowed to use the Smart Routing capability. After that, an initial selection of terminals and MIDs based on the merchant and the requested currency is made. Once the selection is done, additional filtrations are performed in the following order:
- Based on the transaction type and the MID as well as the terminal-supported transaction types
- Based on the supported features of the terminal
- Based on the supported features of the MID
- Based on the required params of the terminal
- Based on whether the same MID as the reference transaction should be used
- Based on the card brand, only if the card number is present, and if the card brand is supported by the MID
Additionally:
- If exactly one matching gateway configuration is found after each filtration, the only suitable terminal will be used to process the transaction and no further filtrations on the gateway configuration will be executed.
- If, after all filtrations were applied, more than one matching gateway configuration exists, the first terminal from the list will be considered suitable and it will be used to process the transaction.
- If no matching gateway configuration is found (resulting in no suitable terminals to be routed to), a descriptive error will be returned as described in Errors section and the transaction will not be processed successfully.
How to use Smart Routing
In order to effectively use the Smart Routing API functionality, first it should be enabled through the merchant configuration, thus please open a ticket to Tech Support in case this functionality needs to be tested and/or used. The Smart Routing API is designed to be 100% backward-compatible and the payload sent to the Smart Routing API endpoint should be the same as with the current Processing API endpoints described under the Transactions section.
There are 2 notable differences:
- The new Smart Routing endpoint URL is expectedly different.
- The
Accept
header signifying accepted content types should be submitted, with values of eitherAccept: text\xml
orAccept: application\xml
.
Installments
Installments-related data is supplied as optional data to the standard API request. If a valid installment is supplied, then the transaction will be processed. Otherwise, the transaction will NOT be processed successfully and will return proper error code and messages.
Installments are supported for Authorize, Authorize3D, Capture, Sale, Sale3D, Refund.
Fetch Applicable Installments
Fetch the applicable installments for a given amount, currency and card brand.
POST /v1/installments
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/v1/installments \
-X POST \
-H "Content-Type: application/json" \
-d '
{
"amount": "8000",
"currency": "GBP",
"card_number": "4005522731304879"
}'
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
amount | required | integer > 0 | Amount of transaction in minor currency unit, see Currency and Amount Handling for details |
currency | required | string(3) | Currency code in ISO 4217 |
card_number | required | 13 to 16 digits | Complete cc number of customer |
required* = conditionally required
Successful Response
{
"plans": [
{
"id": "ZXlKaGJHY2lPaUpJVXpJMU5pSjkuZXlKcmJHRnpjeUk2SWtkbGJtVnphWE5KYm5OMFlXeHNiV1Z1ZEhNNk9sWnBjMkU2T2tsdWMzUmhiR3h0Wlc1MFVHeGhiaUlzSW1sa0lqbzNmUS5WU3pybXBXNldSNlRQODNSOGVGWjR3TzNHcVYwVWJicEN4Z3Rqc1p2YzRZ",
"frequency": "MONTHLY",
"installments": 12,
"cost_info": {
"annualPercentageRate": 0,
"feeInfo": [
{
"type": "CONSUMER",
"ratePercentage": 400,
"flatFee": 0,
"monthlyRatePercentage": 33.33
},
{
"type": "MERCHANT_FUNDING",
"ratePercentage": 0,
"flatFee": 0
},
{
"type": "MERCHANT_SERVICE",
"ratePercentage": 20
}
],
"totalPlanCost": 84240,
"totalFees": 3240,
"totalUpfrontFees": 0,
"totalRecurringFees": 3240,
"firstInstallment": {
"upfrontFee": 0,
"installmentFee": 270,
"amount": 6750,
"totalAmount": 7020,
"totalAmountExcludingUpfrontFee": 7020
},
"lastInstallment": {
"installmentFee": 270,
"amount": 6750,
"totalAmount": 7020
},
"currency": "GBP"
},
"data": {
"name": "UK12M0400",
"type": "ISSUER_DEFAULT",
"termsAndConditions": [
{
"url": "https://www.hsbc.co.uk/help/card-support/instalments",
"version": 3,
"text": "Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nulla viverra sapien sit amet risus placerat, nec molestie velit cursus. Aliquam bibendum sem eu quam finibus, in vestibulum odio lobortis. Ut at quam eget enim dapibus elementum vitae id enim. Ut nec congue sem. Fusce molestie felis lorem, vel molestie nisi tincidunt non. Curabitur mattis justo est, at congue libero auctor eget. Vivamus elementum orci eu tincidunt congue. Donec blandit nunc quis porttitor ornare. Integer blandit accumsan.",
"languageCode": "eng"
}
],
"promotionInfo": {
"promotionCode": "P2",
"promotionID": "PR12"
},
"fundedBy": [
"CONSUMER"
]
},
"created_at": "2024-10-04T10:55:38.121Z",
"updated_at": "2024-10-04T10:55:38.121Z",
"grouping_id": "ZXlKaGJHY2lPaUpJVXpJMU5pSjkuZXlKcmJHRnpjeUk2SWtkbGJtVnphWE5KYm5OMFlXeHNiV1Z1ZEhNNk9sWnBjMkU2T2tsdWMzUmhiR3h0Wlc1MFVHeGhia2R5YjNWd2FXNW5JaXdpYVdRaU9qVXpmUS5uTnd4eG9uZmVGUVlxOHA1UWFCUFFobnpHRGNjT0w5ekg1LUo3blZtd25B"
}
],
"applicable_terminal_tokens": [
"TERMINAL-TOKEN1",
"TERMINAL-TOKEN2"
]
}
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
plans | ||
id | string | The unique identifier of the installment that will be used for the processing |
frequency | string | The frequency of the installment. Can be WEEKLY , BIWEEKLY , MONTHLY , and BIMONTHLY . |
installments | integer | The count of installments. |
cost_info | object | Contains all cost related information like rates, fees, total cost, currency, first and last installments. |
data | object | Contains various additional data, including the terms and conditions of the installment. |
created_at | yyyy-mm-dd hh:mm:ss | Represents the creation date time of the installment. |
updated_at | yyyy-mm-dd hh:mm:ss | Represents the last update date time of the installment. |
grouping_id | string | Identifier of the installment group that the current installment is part of. |
applicable_terminal_tokens | array | List of terminal tokens that can be used to process transaction with any of the returned installment plans |
Show Installment Details
Retrieves details about a specific installment based on its ID.
GET /v1/installments/<INSTALLMENT_ID>
Request
curl https://username:a54a1e349b9784bb01126fdefc244b3ede19e84d@staging.gate.emerchantpay.net/v1/installments/<INSTALLMENT_ID> \
-X POST \
Successful Response
{
"installment_plan": {
"id": "ZXlKaGJHY2lPaUpJVXpJMU5pSjkuZXlKcmJHRnpjeUk2SWtkbGJtVnphWE5KYm5OMFlXeHNiV1Z1ZEhNNk9sWnBjMkU2T2tsdWMzUmhiR3h0Wlc1MFVHeGhiaUlzSW1sa0lqbzNmUS5WU3pybXBXNldSNlRQODNSOGVGWjR3TzNHcVYwVWJicEN4Z3Rqc1p2YzRZ",
"frequency": "MONTHLY",
"installments": 12,
"cost_info": {
"annualPercentageRate": 0,
"feeInfo": [
{
"type": "CONSUMER",
"ratePercentage": 400,
"flatFee": 0,
"monthlyRatePercentage": 33.33
},
{
"type": "MERCHANT_FUNDING",
"ratePercentage": 0,
"flatFee": 0
},
{
"type": "MERCHANT_SERVICE",
"ratePercentage": 20
}
],
"totalPlanCost": 84240,
"totalFees": 3240,
"totalUpfrontFees": 0,
"totalRecurringFees": 3240,
"firstInstallment": {
"upfrontFee": 0,
"installmentFee": 270,
"amount": 6750,
"totalAmount": 7020,
"totalAmountExcludingUpfrontFee": 7020
},
"lastInstallment": {
"installmentFee": 270,
"amount": 6750,
"totalAmount": 7020
},
"currency": "GBP"
},
"data": {
"name": "UK12M0400",
"type": "ISSUER_DEFAULT",
"termsAndConditions": [
{
"url": "https://www.hsbc.co.uk/help/card-support/instalments",
"version": 3,
"text": "Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nulla viverra sapien sit amet risus placerat, nec molestie velit cursus. Aliquam bibendum sem eu quam finibus, in vestibulum odio lobortis. Ut at quam eget enim dapibus elementum vitae id enim. Ut nec congue sem. Fusce molestie felis lorem, vel molestie nisi tincidunt non. Curabitur mattis justo est, at congue libero auctor eget. Vivamus elementum orci eu tincidunt congue. Donec blandit nunc quis porttitor ornare. Integer blandit accumsan.",
"languageCode": "eng"
}
],
"promotionInfo": {
"promotionCode": "P2",
"promotionID": "PR12"
},
"fundedBy": [
"CONSUMER"
]
},
"created_at": "2024-10-04T10:55:38.121Z",
"updated_at": "2024-10-04T10:55:38.121Z",
"grouping_id": "ZXlKaGJHY2lPaUpJVXpJMU5pSjkuZXlKcmJHRnpjeUk2SWtkbGJtVnphWE5KYm5OMFlXeHNiV1Z1ZEhNNk9sWnBjMkU2T2tsdWMzUmhiR3h0Wlc1MFVHeGhia2R5YjNWd2FXNW5JaXdpYVdRaU9qVXpmUS5uTnd4eG9uZmVGUVlxOHA1UWFCUFFobnpHRGNjT0w5ekg1LUo3blZtd25B"
}
}
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
installment_plan | ||
id | string | The unique identifier of the installment that will be used for the processing |
frequency | string | The frequency of the installment. Can be WEEKLY , BIWEEKLY , MONTHLY , and BIMONTHLY . |
installments | integer | The count of installments. |
cost_info | object | Contains all cost related information like rates, fees, total cost, currency, first and last installments. |
data | object | Contains various additional data, including the terms and conditions of the installment. |
created_at | yyyy-mm-dd hh:mm:ss | Represents the creation date time of the installment. |
updated_at | yyyy-mm-dd hh:mm:ss | Represents the last update date time of the installment. |
grouping_id | string | Identifier of the installment group that the current installment is part of. |
Billing Transactions API
General Info
POST /billing_transactions/v1/graphql
Billing Transactions API allows to programmatically retrieve information about billing transactions using given filters, pagination, and sort parameters.
It allows to filter billing transactions by transaction unique identifier, billing statement identifiers, and date range.
It supports pagination by page number and allows to set number of entries per page.
It supports sorting by field and direction.
Billing Transactions API is GraphQL-based and is following GraphQL standards/conventions.
It expects GraphQL query as a request body and corresponding application/graphql
or application/json
Content-type header to be set.
It has a single endpoint and uses POST method for data retrieval. It allows to retrieve only requested fields and by limiting retrieved fields in response, performance and thus API response time can be improved.
It returns detailed error descriptions in GraphQL-specific error format.
Billing Transactions API has authorization layer, which returns authorization specific error status codes in case of access failure, like: 401/403.
Additionally to given documentation, GraphQL schema can be fetched using a special GraphQL introspection feature.
Schema and introspection
The Billing Transactions API support a GraphQL's introspection feature, which allows to fetch GraphQL schema.
GraphQL schema is the most comprehensive and native way to describe GraphQL-based APIs.
It contains description of all types, queries and their hierachy/relationships available for given API.
API platform tools, like Postman or Insomnia support automatic GraphQL schema fetching using API introspection feature and GraphQL query autocompletion based on downloaded schema, so it is recommended to use one of those tools or anything similar for analyzing and testing the Billing Transactions API. Please note that introspection feature also requires authorization.
More information about GraphQL schema and introspection can be found on GraphQL's official website:
https://graphql.org/learn/schema/
https://graphql.org/learn/introspection/
Authorization
API requires authorization with a token issued per merchant.
In order to pass authorization, the merchant must do request with populated Authorization
header.
Following Authorization
header value formats are allowed:
- Bearer "billing_api_token"
- Bearer billing_api_token
- Bearer token="billing_api_token"
- Bearer token=billing_api_token
- Token token="billing_api_token"
- Token token=billing_api_token
- Token "billing_api_token"
- Token billing_api_token
billing_api_token
is a token obtained from tech-support@emerchantpay.com, which is issued individually per merchant entity.
Authorization error response status codes
If the request did not pass authorization, following response status codes might be returned:
Status Code | Summary |
---|---|
401 | Unauthorized. Either Authorization header is not provided or service could not identify merchant with provided token. |
403 | Access Denied. Service identified the merchant, but merchant does not have enough permissions to access target API. |
500 | Internal Service Error. Unknown system error. Please contact support. |
If one of the following status codes is returned despite issued token being provided in correct header and in correct format,
merchant should contact tech-support@emerchantpay.com.
If for previously working billing transactions API token, status code 403 started to be returned, then it expired, and new one should be issued.
Billing transactions retrieval
Filter By Billing Transaction Unique I Ds
Request
curl https://staging.api.emerchantpay.net/billing_transactions/v1/graphql \
-X POST \
-H "Accept: application/json" \
-H "Content-Type: application/graphql" \
-d '
query {
billingTransactions(filter: { uniqueId: ["abc123"] })
{
items
{
billingStatementId
uniqueId
transactionType
billingAmount
billingCurrency
transactionDate
merchantTransactionId
paymentType
}
}
}'
Successful Response
{
"data": {
"billingTransactions": {
"items": [
{
"billingStatementId": "A123",
"uniqueId": "abc123",
"transactionType": "Sale Approved",
"billingAmount": 24.25,
"billingCurrency": "EUR",
"transactionDate": "2023-10-01 18:00:14",
"merchantTransactionId": "some_id",
"paymentType": "Sale"
}
]
}
}
}
Filter By Billing Statement I Ds
Request
curl https://staging.api.emerchantpay.net/billing_transactions/v1/graphql \
-X POST \
-H "Accept: application/json" \
-H "Content-Type: application/graphql" \
-d '
query {
billingTransactions(filter: { billingStatementId: ["A123", "B456"] })
{
items
{
billingStatementId
uniqueId
transactionType
billingAmount
billingCurrency
transactionDate
merchantTransactionId
paymentType
}
}
}'
Successful Response
{
"data": {
"billingTransactions": {
"items": [
{
"billingStatementId": "A123",
"uniqueId": "abc123",
"transactionType": "Sale Approved",
"billingAmount": 24.25,
"billingCurrency": "EUR",
"transactionDate": "2023-10-01 18:00:14",
"merchantTransactionId": "some_id_1",
"paymentType": "Sale"
},
{
"billingStatementId": "A123",
"uniqueId": "def456",
"transactionType": "Chargeback",
"billingAmount": 10.0,
"billingCurrency": "EUR",
"transactionDate": "2023-10-01 11:50:21",
"merchantTransactionId": "some_id_2",
"paymentType": "Sale 3D"
},
{
"billingStatementId": "B456",
"uniqueId": "g7h8i9",
"transactionType": "Settlement Approved",
"billingAmount": 9.99,
"billingCurrency": "USD",
"transactionDate": "2023-10-03 00:23:55",
"merchantTransactionId": "some_id_3",
"paymentType": "Cash"
}
]
}
}
}
Filter By Transaction Type
Request
curl https://staging.api.emerchantpay.net/billing_transactions/v1/graphql \
-X POST \
-H "Accept: application/json" \
-H "Content-Type: application/graphql" \
-d '
query {
billingTransactions(filter: { transactionType: Settlement Approved })
{
items
{
billingStatementId
uniqueId
transactionType
billingAmount
billingCurrency
transactionDate
merchantTransactionId
paymentType
}
}
}'
Successful Response
{
"data": {
"billingTransactions": {
"items": [
{
"billingStatementId": "B456",
"uniqueId": "g7h8i9",
"transactionType": "Settlement Approved",
"billingAmount": 9.99,
"billingCurrency": "USD",
"transactionDate": "2023-10-03 00:23:55",
"merchantTransactionId": "some_id",
"paymentType": "Sale 3D"
}
]
}
}
}
Use Json Content Type
Request
curl https://staging.api.emerchantpay.net/billing_transactions/v1/graphql \
-X POST \
-H "Accept: application/json" \
-H "Content-Type: application/json" \
-d '
{
"query": "query { billingTransactions(filter: { uniqueId: \"abc123\" }) { items { billingStatementId uniqueId transactionType } } }"
}'
Request headers
Header | Required | Value |
---|---|---|
Content-Type | required | application/graphql or application/json |
Accept | required | application/json |
Authorization | required | Token billing_api_token . See authorization section |
Request filter parameters
Resulting billing transactions collection can be filtered using following filter parameters.
At least one parameter should be provided, but any combination can also work.
If startDate is provided, then endDate should also be provided and vice versa.
Date only format 'yyyy-mm-dd' equals to following date time format: yyyy-mm-dd 00:00:00.
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
startDate | required* | 'yyyy-mm-dd hh:mm:ss' or 'yyyy-mm-dd' | Start of the requested date range. Includes billing transactions, which were created after provided time or at the same moment. Max start and end date difference allowed is 7 days. |
endDate | required* | 'yyyy-mm-dd hh:mm:ss' or 'yyyy-mm-dd' | End of the requested date range. Includes billing transactions, which were created before provided time. Max start and end date difference allowed is 7 days. |
uniqueId | optional | list of strings | List of billing transaction unique IDs. Max number of elements is 10000 |
billingStatementId | optional | list of strings | List of billing statement IDs. Max number of elements allowed is 10. |
merchantTransactionId | optional | list of strings | List of merchant transaction IDs. Max number of elements allowed is 10000. |
masterAccountName | optional | list of strings | List of master account names. Max number of elements allowed is 100. |
transactionType | optional | string(255) | Billing transaction type. See available billing transaction type list below. To be passed with spaces and capital letters if any. |
required* = conditionally required
Billing transaction type field list:
- "Authorisation Approved"
- "Authorisation Declined"
- "Settlement Approved"
- "Settlement Declined"
- "Sale Approved"
- "Sale Declined"
- "Refund Approved"
- "Refund Declined"
- "Payout Approved"
- "Payout Declined"
- "CFT Other Approved"
- "CFT Declined"
- "Chargeback"
- "Chargeback Reversal"
- "Chargeback Representment"
- "Retrieval Request"
- "Void"
- "Visa EU Intraregional Fraud Chargeback"
- "MasterCard EU Region Chargeback"
- "Second Chargeback"
- "CFT Visa Approved"
- "CFT MasterCard Approved"
- "Visa RDR"
- "RDR Reversal"
- "Gateway Transaction Fee"
- "Risk Management Transaction Fee"
- "Fraud Engine Transaction Fee"
Request paging and order parameters
Resulting billing transactions collection can be divided into pages and ordered using following parameters.
Single page can be downloaded per request along with information about other pages.
In case 'asc' sort direction is used on field, which can contain null
value, null
entries will appear first.
In case 'desc' sort direction is used on field, which can contain null
value, null
entries will appear last.
Request Parameters
Parameter | Required | Format | Description |
---|---|---|---|
page | optional | integer | Requested page number. Pages enumeration starts from 1. Default value: 1 |
perPage | optional | integer | Max number of entries per page. Expected value is in range from 1 to 100. Default value: 100 |
orderByDirection | optional | string(enum) | Direction result collection is sorted by. Possible values: asc, desc. Default value: asc |
orderByField | optional | string(enum) | Field result collection is sorted by. Default value: transactionDate. See available field list below. |
required* = conditionally required
Order by field list:
- billingStatementId
- transactionDate
- transactionCurrency
- transactionAmount
- exchangeRate
- billingAmount
- transactionFeeAmount
- commissionPercent
- commissionAmount
- interchangeFee
- region
- settlementStatus
Filter By Date Range And Paginate/Sort
Request
curl https://staging.api.emerchantpay.net/billing_transactions/v1/graphql \
-X POST \
-H "Accept: application/json" \
-H "Content-Type: application/graphql" \
-d '
query {
billingTransactions(filter: { startDate: 2023-10-03, endDate: 2023-10-05 }, paging: { page: 2, perPage: 3 }, sort: { byDirection: desc, byField: transactionDate })
{
items
{
billingStatementId
uniqueId
transactionType
billingAmount
billingCurrency
transactionDate
}
paging
{
page
perPage
pagesCount
totalCount
}
}
}'
Successful Response
{
"data": {
"billingTransactions": {
"items": [
{
"billingStatementId": "A123",
"uniqueId": "g7h8i9",
"transactionType": "Settlement Approved",
"billingAmount": 9.99,
"billingCurrency": "USD",
"transactionDate": "2023-10-04 23:00:00"
},
{
"billingStatementId": "A456",
"uniqueId": "def456",
"transactionType": "Chargeback",
"billingAmount": 10.0,
"billingCurrency": "EUR",
"transactionDate": "2023-10-04 20:40:11"
},
{
"billingStatementId": "A123",
"uniqueId": "abc123",
"transactionType": "Sale Approved",
"billingAmount": 24.25,
"billingCurrency": "EUR",
"transactionDate": "2023-10-03 10:30:00"
}
],
"paging": {
"page": 2,
"perPage": 3,
"pagesCount": 10,
"totalCount": 28
}
}
}
}
Response fields
If request is successful, response should contain billing transactions list with requested fields and status code 200.
Paging information also needs to be explicitly requested.
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
id | integer | Transaction identifier. |
uniqueId | string | Transaction unique identifier. |
billingStatementId | string | Identifies to which billing statement the transaction belongs. |
arn | string* | Acquirer reference number. |
transactionType | string | Transaction type. See list of possible values in transactionType filter description |
transactionDate | yyyy-mm-dd hh:mm:ss* | Date and time when transaction was executed in UTC. |
transactionCurrency | string(3) | The processing currency code of the transaction in ISO 4217. |
transactionAmount | float(precise) | The transaction amount (in processing currency). |
exchangeRate | float(precise) | The applied exchange rate to convert from the processing to the billing currency of the transaction. |
billingCurrency | string(3) | Billing currency code in ISO 4217. |
billingAmount | float(precise)* | The calculated billing amount of the transaction. |
transactionFeeCurrency | string(3) | The currency code of the applied transaction fee according in ISO 4217. |
transactionFeeAmount | float(precise)* | The applied transaction fee amount. |
transactionFeeChargedOnBillingStatementId | integer | Identifies from which billing statement the transaction fee for this transaction is deducted. |
commissionPercent | float(precise)* | The applied commission (discount) percent. Empty for all types except Sale Approved and Settlement Approved. |
commissionAmount | float(precise)* | The applied commission (discount) amount in billing currency. Empty for all types except Sale Approved and Settlement Approved. |
interchangeFee | float(precise)* | The interchange fee amount (in interchange currency). |
interchangeCurrency | string(3)* | The interchange currency code of the transaction in ISO 4217. |
isInterchangeplusplus | boolean | Identifies if the transaction is Interchange++. |
interchangeplusplusChargedOnBillingStatementId | string(255) | The billing statement identifier, Interchange++ is charged on. |
schemeFee | float(precise)* | The scheme fee amount (in scheme fee currency). |
schemeFeeCurrency | string(3)* | The scheme fee currency of the transaction. |
standardDebitCardRate | float(precise)* | The standard debit card rate of the transaction. |
gstAmount | float | The GST tax calculated amount of the transaction(based on transaction fee and commission). |
gstRate | float | The applied GST over (transaction fee and discount) percent. |
vatAmount | float | The VAT tax calculated amount of the transaction(based on transaction fee and commission). |
vatRate | float | The applied VAT over (transaction fee and discount) percent. |
terminalName | string* | Associated terminal name. |
region | string* | Associated region. |
settlementBillingStatementIds | string* | Associated billing statement identifier(s), which partially or fully settled the transaction. Can be multiple statement identifiers separated with comma. |
settlementDates | yyyy-mm-dd* | Dates when transaction was partially or fully settled. Can be multiple dates separated with comma. |
settlementStatus | string(enum)* | Transaction settlement status. Possible values: Delayed, Balanced or not defined. |
merchantId | integer | Merchant unique identifier. |
merchantName | string | Merchant name. |
merchantTransactionId | string* | Transaction identifier provided by merchant. |
masterAccountName | string | Master account name. |
valueDate | yyyy-mm-dd* | Indicates when the corresponding billing statement was set to Paid status. Will be empty for billing statements with Status Pending. |
documentId | string* | Consumer personal identification. See Document ID Parameter. |
referenceId | string* | Reference (original) transaction unique identifier. |
authCode | string* | Authorization code generated by the card network when an authorisation has occurred. It is used to identify authorization and it consists of 6 alphanumeric chars. |
paymentType | string* | Reference (original) transaction type. |
cardBrand | string* | Card brand. Examples: Visa, MasterCard, Maestro |
cardNumber | string* | Masked card number. Example: 420000...0000 |
cardHolder | string* | Full name of customer as printed on card (first name and last name at least). Example: John Doe |
cardType | string* | Card type. Possible values: Debit, Credit, Charge Card |
cardSubtype | string* | Card subtype. Examples: Standard, Gold, Gift |
*
means that field can potentially contain null
value.
float(precise)
is float type, which maintains certain precision, which is typical for exchange rates, fee amounts, percentages and etc.
It is achieved by either rounding up original number to specific precision or by adding trailing zeros for consistency.
It is useful for displaying to user. Please note that trailing zeroes might be removed automatically by API platform tools, like Postman.
Examples:
- 1.000000 or 0.023000 for exchangeRate
- 0.0262 or 0.0000 for schemeFee
- 15.29 or 1.10 for transactionAmount
Select All Fields
Request
curl https://staging.api.emerchantpay.net/billing_transactions/v1/graphql \
-X POST \
-H "Accept: application/json" \
-H "Content-Type: application/graphql" \
-d '
query {
billingTransactions(filter: { uniqueId: "["abc123"]" })
{
items
{
id
billingStatementId
uniqueId
arn
transactionDate
transactionType
transactionCurrency
transactionAmount
exchangeRate
billingCurrency
billingAmount
transactionFeeCurrency
transactionFeeAmount
transactionFeeChargedOnBillingStatementId
commissionPercent
commissionAmount
interchangeFee
interchangeCurrency
isInterchangeplusplus
interchangeplusplusChargedOnBillingStatementId
schemeFee
schemeFeeCurrency
standardDebitCardRate
gstAmount
gstRate
vatAmount
vatRate
terminalName
region
settlementBillingStatementIds
settlementDates
settlementStatus
merchantId
merchantName
merchantTransactionId
masterAccountName
valueDate
documentId
referenceId
authCode
paymentType
cardBrand
cardNumber
cardHolder
cardType
cardSubtype
}
}
}'
Paging response fields
Successful Response Parameters
Parameter | Type | Description |
---|---|---|
page | integer | Current page number. Pages enumeration starts from 1. |
perPage | integer | Max number of entries per each page. |
pagesCount | integer | Total number of pages associated with particular request filter set. |
totalCount | integer | Total number of entries associated with particular request filter set. |
It is recommended to fetch pagesCount
and/or totalCount
with the first page of data and request subsequent pages w/o using these fields. This will significantly improve subsequent requests performance.
Response error codes
If request fails, following error codes and messages might be returned:
Error code | Error message | Response status code | Summary |
---|---|---|---|
GRAPHQL_PARSE_FAILED | invalid request syntax/schema | 422 | Invalid GraphQL syntax/schema in request from the billing transactions API client. |
GRAPHQL_VALIDATION_FAILED | invalid request query/types | 422 | Invalid GraphQL query/types in request from the billing transactions API client |
INVALID_REQUEST_PARAMETERS | invalid request parameters | 200 | Invalid input parameters values in request from the billing transactions API client, e.g. per page entries number exceeding max allowed value. |
REQUEST_TIMED_OUT | request timed out, retry recommended | 200 | Request took too long to execute and service interrupted it. |
INTERNAL_SERVICE_ERROR | internal service error | 200 | Unknown system error. Please contact support. |
GraphQL error(s) returned by service has format described in following GraphQL specification: https://spec.graphql.org/draft/#sec-Errors.
Returned error might be additionally supplied with debug
field, which contains detailed information about the issue.
Response status code 200 might be returned despite error occurred according to GraphQL conventions.
Error Response
{
"data": {
"billingTransactions": null
},
"errors": [
{
"message": "invalid request parameters",
"path": [
"billingTransactions"
],
"extensions": {
"code": "INVALID_REQUEST_PARAMETERS",
"debug": "validating request filter parameters: startDate and endDate fields should be defined together",
"domain": "billing-transactions-api"
}
}
]
}
Error Response
{
"data": null,
"errors": [
{
"message": "invalid request query/types",
"locations": [
{
"line": 2,
"column": 59
}
],
"extensions": {
"code": "GRAPHQL_VALIDATION_FAILED",
"debug": "string cannot represent a non string value: 123",
"domain": "billing-transactions-api"
}
},
{
"message": "invalid request query/types",
"locations": [
{
"line": 2,
"column": 86
}
],
"extensions": {
"code": "GRAPHQL_VALIDATION_FAILED",
"debug": "int cannot represent non-integer value: \"abc\"",
"domain": "billing-transactions-api"
}
}
]
}
Error Response
{
"data": {
"billingTransactions": null
},
"errors": [
{
"message": "internal service error",
"path": [
"billingTransactions"
],
"extensions": {
"code": "INTERNAL_SERVICE_ERROR",
"debug": "could not read Merchant ID value from request context",
"domain": "billing-transactions-api"
}
}
]
}