NAV
cURL php .NET Ruby Python

Introduction

This documentation is a concise reference manual containing instructions about how to effectively use and integrate with Alternative Payments API.

Supported Payment Options

Payment Option Supported Country (ISO Code) Processing Currency
AliPay CN ¥ CNY
ArgenCard AR $ USD
Banco do Brasil BR $ USD
Bancontact (MisterCash) BE € Euro
BLIK PL zł Polish Zloty
Boleto Bancario BR R$ Brazil Real
Bradesco BR € Euro
BrazilPay Bank Transfer BR R$ Brazil Real
BrazilPay Charge Card BR R$ Brazil Real
Bitcoin Global € Euro
Credit Card US $ USD
DirectPayEU AR, AT, BE, HR, CY, CZ, DK, EE, FI, FR, DE, GI, GR, HU, IS, IE, IT, LV, LT, LU, MK, MT, NL, NO, PL, PT, RO, RS, SK, SI, ES, SE, CH, TN, TR, GB € Euro
DPMax AT, BE, DK, EE, FI, FR, DE, IS, IE, IT, LV, LT, NL, NO, PL, PT, ES, SE € Euro
Efecty CO € Euro
EPS AT € Euro
GiroPay DE € Euro
IDEAL NL € Euro
Itau BR € Euro
Multicaja CL € Euro
MyBank IT, ES, GR € Euro
Oxxo MX € Euro
PagoEfectivo PE € Euro
Pago Facil AR € Euro
paysafecard AU, AT, BE, BG, CA, HR, HU, CY, CZ, DK, FI, FR, DE, GB*, GI, GR, IE, IT, LI, LV, LT, LU, MT, MX, NL, NO, PE, PL, PT, RO, SK, SI, ES, SE, CH, TR, UY € Euro
PIX BR R$ Brazil Real
POLI AU, NZ AUD $, NZD $
Przelewy24 PL zł Polish Zloty
QIWI RU ‎₽ RUB
Rapipago AR € Euro
SafetyPay AT, CO, CR, DE, ES, MX, NI, NL, PA, PE € Euro
Santander BR € Euro
SEPA AT, BE, BG, HR, CY, CZ, DK, EE, FI, FR, DE, GI, GR, HU, IS, IE, IT, LV, LI, LT, LU, MC, MT, NL, NO, PL, PT, RO, SK, SI, SM, ES, SE, CH, GB* € Euro
Servipag CL € Euro
SOFORT Überweisung AT, BE, DE, NL, ES € Euro
Teleingreso ES € Euro
Trustly AT, DK, EE, FI, DE, LV, LT, NL, NO, ES, SE € Euro
TrustPay CZ, SK € Euro
UnionPay CN ¥ CNY
Via Baloto CO € Euro
Webpay CL € Euro

Supported Currencies

Transactions can be submitted in the processing currency listed above for each payment option, or any of the currencies listed below. If not submitted in the processing currency, the submitted amount will be converted at the time of the transaction.

Currency Code Symbol
Australia Dollar AUD $
Brazil BRL R$
Chinese Yuan Renminbi CNY ¥
Croatia Kuna HRK kn
Euro EUR
Gibraltar Pound GIP £
Hungary Forint HUF Ft
Iceland Krona ISK kr
Lithuanian Litas LTL Lt
New Zaeland Dollar NZD $
Norway Krone NOK kr
Poland Zloty PLN
Romania New Leu RON lei
Sweden Krona SEK kr
United Kingdom Pound GBP £
US Dollar USD $

Authentication

Authentication to the API occurs via HTTP Basic Auth. Provide your API key as the basic auth username. You do not need to provide a password.

The API defines Public and Secret keys.

Test and live keys are supported for an easy switch from test to live mode. The test key works in the exact same way as the live key, but doesn’t do live transactions.

Keys are defined per website. You can manage your keys in your Merchant Tool.

Error Types Description
invalid_parameter_error Invalid request errors arise when your request has invalid parameters.
api_error API errors cover any other type of problem (e.g. a temporary problem with servers) and should turn up only very infrequently.
payment_error All errors related to invalid payment data, velocity control, fraud prevention, …

Pagination

curl https://api.alternativepayments.com/api/transactions/?limit=<LIMIT>&offset=<OFFSET> \
-u <WEBSITE_SECRET_KEY>:

The above command returns JSON structured like this:

{
  "transactions": [
    {
      "id": "trn_345812d991",
      "mode": "Test",
      "status": "Created",
      "customer": {
        "id": "cus_a8e955b73cbd45348",
        "mode": "Test",
        "firstName": "Jonathan",
        "lastName": "Scott",
        "email": "ligula.consectetuer.rhoncus@Fusce.com",
        "country": "DE",
        "created": "2016-02-25T08:51:37.823Z"
      },
      "payment": {
        "id": "pay_b1f063633853412eb",
        "mode": "Test",
        "customerId": "cus_a8e955b73cbd45348",
        "paymentOption": "sepa",
        "holder": "Jonathan Scott",
        "created": "2016-02-25T08:51:37.743Z"
      },
      "amount": 2499,
      "currency": "EUR",
      "merchantPassThruData": "7716902",
      "created": "2016-02-25T08:51:37.823Z"
    },
    {
      "id": "trn_ed77df2dcf",
      "mode": "Test",
      "status": "Created",
      "customer": {
        "id": "cus_4b08ee7682cb4afd8",
        "mode": "Test",
        "firstName": "ralf",
        "lastName": "Wright",
        "email": "eu@Namnullamagna.com",
        "country": "DE",
        "created": "2016-02-25T08:51:37.103Z"
      },
      "payment": {
        "id": "pay_37636b775d474cd4a",
        "mode": "Test",
        "customerId": "cus_4b08ee7682cb4afd8",
        "paymentOption": "sepa",
        "holder": "ralf Wright",
        "created": "2016-02-25T08:51:37.073Z"
      },
      "amount": 2900,
      "currency": "EUR",
      "merchantPassThruData": "7718021",
      "created": "2016-02-25T08:51:37.103Z"
    }
  ],
  "pagination": {
    "offset": 10,
    "limit": 2,
    "count": 2504
  }
}

Some responses can have large collections of data. We support pagination using offset and limit parameters.

By default, when you search for something, we will return all the matching records. However, you can use a parameter called limit to tell the API how many records you want to return all at once.

GET https://api.alternativepayments.com/api/transactions?limit=5

To get all the records you need to use another parameter along with limit called offset. This parameter tells the API where to start returning records from the entire set of results. If you don’t include this parameter, the default is to start at record number 0 and then return the number of records specified with the ‘limit’ parameter.

GET https://api.alternativepayments.com/api/transactions?limit=5&offset=10

In API response, you will receive information about the count, offset and count (for total record count).

Example:

"pagination": { "offset": 10, "limit": 5, "count": 2504 }

Webhooks

Sample data in JSON

{
  "id": "evt_5139d34fa67e4651ae2b5f",
  "type": "transaction.approved",
  "resourceName": "Transaction",
  "resource": {
    "id": "trn_23fc4cf",
    "mode": "Test",
    "status": "Pending",
    "customer": {
      "id": "cus_711e8c0f4f7b4893a",
      "mode": "Test",
      "firstName": "John",
      "lastName": "Doe",
      "email": "john@doe.com",
      "created": "2015-04-07T12:09:58.423Z"
    },
    "payment": {
      "id": "pay_20443651fcdf40228",
      "mode": "Test",
      "paymentOption": "sepa",
      "customerId": "cus_711e8c0f4f7b4893a",
      "iban": "DE71XXXXX3330",
      "bic": "INGDDEFFXXX",
      "holder": "John Doe",
      "created": "2015-04-07T12:09:58.42Z"
    },
    "amount": 578,
    "currency": "EUR",
    "created": "2015-04-07T12:09:58.527Z"
  },
  "created": "2015-04-07T13:54:05.8961484Z"
}

With webhooks, we give you the possibility to react automatically to certain events which happen within our system. A webhook is basically a URL where we send an HTTP POST request to, every time one of the events attached to that webhook is triggered.

Event Code Description
customer.created The customer object has been created in the system.
transaction.pending The transaction has been created in the system and is awaiting an action.
transaction.aborted A status indicating that a transaction has been canceled by the consumer during confirmation on his e-banking account page.
transaction.approved A transaction that has been accepted by an acquirer.
transaction.funded A transaction that has been accepted by an acquirer and has passed the System defined settlement guidelines
transaction.declined A status indicating that a transaction has been rejected prior to receiving an approved status.
transaction.chargeback A status received from the acquirer indicating a reversal of funds that was initiated by the consumer for a transaction.
transaction.isf A status indicating that there were insufficient funds in the consumer’s account to settle a transaction.
transaction.invalid A generic status received from the acquirer indicating that funds were unable to be transferred
transfer.pending A transfer has been created in the system and is awaiting an action.
transfer.approved A transfer has been approved by the bank.
transfer.voided A transfer has been nullified by the system prior to being approved.
transfer.declined A transfer has been declined prior to receiving an approved status.
void.succeeded A status indicating that the transaction was nullified by the system prior to being approved.
void.declined Void of the transaction is declined.
refund.pending Refund of the transaction is processed by the System, but not yet refunded.
refund.succeeded A status indicating that funds were reversed for a transaction, and the amount or a portion of this amount was returned back to the consumer.
refund.declined Refund of the transaction is declined.
preauth.approved Preauthorization has been approved, the amount can be captured.
preauth.voided Preauthorization has been voided, the amount cannot be captured.
preauth.declined Preauthorization has been declined, the amount cannot be captured.
plan.created A status indicating that the plan has been created.
plan.deactivated A status indicating that the plan has been deactivated.
plan.updated A status indicating that the plan has been updated.
subscription.created A status indicating that the subscription has been created.
subscription.canceled A status indicating that the subscription has been canceled.
subscription.expired A status indicating that the subscription has been expired.

To confirm transaction status, you can use Retrieve a transaction API call.

Test mode

The live and test environments each have a different API key pair. Both Live and Test APIs use the same API endpoint and both environments work in the same way, with some exceptions: in Test mode statuses of the transactions are automatically changed to Funded after a short delay, and blacklist/velocity controls are ignored.

For payment options with redirections, in Test mode customer will be redirected to simulator page that can be used to simulate real bank hosted pages.

Which IBAN and BIC numbers to use when testing SEPA?

For SEPA we provide test IBAN/BIC numbers, so you can simulate different return responses. Also, these test IBAN codes skip IBAN validation. They are valid for Test mode only!

Test IBAN codes

IBAN code Transaction return response
DEST1000200030004000500 transaction is valid
DEST1001XXX00XINVALID transaction is invalid
DEST2002XXX00XISF Insuficient Funds - ISF
DEST3003XXX00XCHGBACK chargeback

 

 

 

 

 

Transaction

Attributes ↓

Parameter Type Description Requirement
customer Customer object Customer object Optional, either Customer or customerId is required
customerId string Customer identifier Optional, either Customer or customerId is required
payment Payment object Payment object Optional, either Payment or token is required
token string Payment token Optional, either Payment or token is required
amount integer The used amount (calculated in cents) Required
currency string ISO 4217 formatted currency code Required
merchantPassThruData string Merchant’s identification Optional *Originating URL is required to be passed if you are an IPSP or service provider
merchantTransactionId string The unique identifier for a payment provided by the merchant Optional
description string Description Optional
ipAddress string Customer’s IP address Required
returnUrl string URL that customer is redirected to after successful payment Required for payment options with redirection
cancelUrl string URL that customer is redirected to on aborted payment Required for payment options with redirection

 

 

Descriptors

curl https://api.alternativepayments.com/api/payments -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
  "payment": {
    "holder": "John Doe",
    "paymentOption": "sepa",
    "iban": "DEST1000200030004000500"
  },
  "customer": {
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "DE"
  },
  "amount": 220,
  "currency": "EUR",
  "ipaddress": "123.01.1",
  "customDescriptor": "Test descriptor which will be sent by Merchant",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
}

Once transaction has been made, a consumer’s bank account will show the descriptors. Some of our descriptors are turned off by default and you might have to contact our support, so they can assist you with adding more descriptors.

We offer the following descriptors:

Parameter Type Description Default
TransactionId string Transaction ID Yes
WebsiteURL string Merchant’s Website Url Yes
Company Name string Merchant’s Company Name No
ProductDescription string Merchant’s Product Description No
TransactionCreated date Date of the transaction No
TransactionAmount integer Original Amount of the transaction No
TransactionCurrency string Currency of the transaction No

 

 

We also offer the possibility of sending custom descriptors in the transaction request.

Parameter Type Description Default
customDescriptor string Custom Descriptor sent by Merchant No

 

 

 

 

 

 

 

 

 

 

 

 

Creating a Transaction ↓

Every single payment request in the API will generate a Transaction. Each Transaction is uniquely identified by Transaction ID. To obtain details about a Transaction you need to make a separate GET request.

Using Payment Object

When creating a transaction, you can either send full payment object body each time transaction is made, or you can create payment object once and then reuse it when creating new transactions. Unlike token (can be used only once), payment object can be reused multiple times.

Creating Payment Object
curl https://api.alternativepayments.com/api/payments -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
"holder": "John Doe",
"paymentOption":"sepa",
"iban":"AT85XXXXX0817"
}'

The above command returns JSON structured like this:

{
  "id": "pay_4c03abe649914b1a9",
  "mode": "Test",
  "paymentOption": "sepa",
  "holder": "Jothn Smitht",
  "iban": "AT85XXXXX0817",
  "bic": "SPAEAT2SXXX",
  "created": "2016-09-09T03:40:32.7497062Z"
}

To create paymentObject, using Secret API key you must submit required payment object parameters. Required paremeters for payment object vary depending on payment option used.

In response, paymentObject id will be sent.  

 

 

 

 

 

 

 

 

 

 

 

Creating transaction using Payment Object
curl https://api.alternativepayments.com/api/transactions -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
  "currency": "EUR",
  "amount": 500,
  "ipaddress": "123.01.1",
  "paymentid":"pay_56ba8feffe2142dfb",
  "customer": {
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "DE"
  }
}

The above command returns JSON structured like this:

{
  "id": "trn_d12209838b",
  "mode": "Test",
  "status": "Pending",
  "customer": {
    "id": "cus_de0636cef44540a4a",
    "mode": "Test",
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "DE",
    "created": "2016-03-17T05:17:58.0438821Z"
  },
  "payment": {
    "id": "pay_917a86ff369e4f8a9",
    "mode": "Test",
    "paymentOption": "sepa",
    "holder": "John Doe",
    "iban": "DE85XXXXX0817",
    "bic": "SPAEAT2SXXX",
    "created": "2016-03-17T05:17:58.0108663Z"
  },
  "amount": 500,
  "currency": "EUR",
  "created": "2016-03-17T05:17:58.0388728Z"
}

Once payment object has been created, you can create a transaction using generated "paymentid". So, you don’t need to send, for example, in case of SEPA, holder, paymentOption or iban parameters.

Alipay

curl https://api.alternativepayments.com/api/transactions -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
  "customer": {
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "CN"
  },
  "payment": {
    "paymentOption": "alipay",
    "holder": "John Doe"
  },
  "amount": 100,
  "currency": "EUR",
  "ipaddress": "123.01.1",
  "redirectUrls": {
    "ReturnUrl":"http://alternativepayments.com/message/success.html",
    "CancelUrl":"http://alternativepayments.com/message/failure.html"
  }
}

The above command returns JSON structured like this:

{
  "id": "trn_2bbcd34628",
  "mode": "Test",
  "status": "Pending",
  "customer": {
    "id": "cus_b9c6a32127724ffea",
    "mode": "Test",
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "CN",
    "created": "2016-03-25T14:04:41.7643102Z"
  },
  "payment": {
    "id": "pay_f633ab65f86b4dac8",
    "mode": "Test",
    "paymentOption": "alipay",
    "holder": "John Doe",
    "created": "2016-03-25T14:04:41.6863101Z"
  },
  "amount": 100,
  "currency": "EUR",
  "created": "2016-03-25T14:04:41.7643102Z",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  },
  "ipaddress": "123.01.1",
  "redirectUrl": "http://checkout.nts.com/direction.aspx?transaction_id=trn_2688"
}

PAYMENT OBJECT

Parameter Type Description Requirement
paymentOption string alipay Mandatory
holder string Customer’s First and Last Name Mandatory

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Customer’s First Name Mandatory
lastName string Customer’s Last Name Mandatory
email string Customer’s Email Mandatory
address string Customer’s address - Street Name Optional
address2 string Customer’s address - Street Number Optional
city string Customer’s city Optional
zip string Customer’s city Postal Code Optional
state string Customer’s state - 2 letter code Optional
country string Customer’s country - ISO1 country Code Mandatory
birthday date Customer’s birthday - MM/DD/YYYY Optional
phone string Customer’s phone Number Optional

ArgenCard

curl https://api.alternativepayments.com/api/transactions -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
  "customer": {
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "AR",
    "birthDate": "02/15/1968"
  },
  "payment": {
    "paymentOption": "argencard",
    "holder": "John Doe",
    "documentId": "1111111111111111"
  },
  "amount": 100,
  "currency": "USD",
  "ipaddress": "123.01.1",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  }
}

{
  "customer": {
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "AR"
    "birthDate": "02/15/1968"
  },
  "payment": {
    "paymentOption": "argencard",
    "holder": "John Doe"
    "documentId": "1111111111111111"
  },
  "amount": 100,
  "currency": "USD",
  "ipaddress": "123.01.1",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  }
}

The above command returns JSON structured like this:

{
  "id": "trn_1a5f5e0c97",
  "mode": "Test",
  "status": "Pending",
  "customer": {
    "id": "cus_bf682a6c051145a09",
    "mode": "Test",
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "AR",
    "birthDate": "02/15/1968",
    "created": "2016-03-25T13:51:04.8497785Z"
  },
  "payment": {
    "id": "pay_ffd25121f84e4d249",
    "mode": "Test",
    "paymentOption": "argencard",
    "holder": "John Doe",
    "created": "2016-03-25T13:51:04.7717784Z",
    "documentId": "1111111111111111"
  },
  "amount": 100,
  "currency": "USD",
  "merchantPassThruData": "Order #1234958",
  "created": "2016-03-25T13:51:04.8497785Z",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  },
  "ipaddress": "123.01.1",
  "redirectUrl": "http://mybankingsite.com/hRedirection.aspx?transaction_id=trn_1a5f5e0c97"
}

You can also use preauthorization prior to executing the transaction. For this, please see Preauthorization

If you’re accepting credit cards, tokenization must be used to be PCI compliant.

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Customer’s First Name Mandatory
lastName string Customer’s Last Name Mandatory
email string Customer’s Email Mandatory
address string Customer’s address - Street Name Optional
address2 string Customer’s address - Street Number Optional
city string Customer’s city Optional
zip string Customer’s city Postal Code Optional
state string Customer’s state - 2 letter code Optional
country string Customer’s country - ISO1 country Code Mandatory
birthDate date Customer’s birthday - MM/DD/YYYY Optional
phone string Customer’s phone Number Optional

PAYMENT OBJECT

Parameter Type Description Requirement
paymentOption string argencard Mandatory
holder string Customer’s First and Last Name Mandatory
documentId string Customer’s Document Id Optional

Banco do Brasil

curl https://api.alternativepayments.com/api/transactions -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
  "customer": {
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "BR",
    "birthDate": "02/15/1968"
  },
  "payment": {
    "paymentOption": "bancodobrasil",
    "holder": "John Doe",
    "documentId": "1111111111111111"
  },
  "amount": 100,
  "currency": "USD",
  "ipaddress": "123.01.1",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  }
}

{
  "customer": {
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "BR",
    "birthDate": "02/15/1968"
  },
  "payment": {
    "paymentOption": "bancodobrasil",
    "holder": "John Doe",
    "documentId": "1111111111111111"
  },
  "amount": 100,
  "currency": "USD",
  "ipaddress": "123.01.1",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  }
}

The above command returns JSON structured like this:

{
  "id": "trn_1a5f5e0c97",
  "mode": "Test",
  "status": "Pending",
  "customer": {
    "id": "cus_bf682a6c051145a09",
    "mode": "Test",
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "BR",
    "birthDate": "02/15/1968",
    "created": "2016-03-25T13:51:04.8497785Z"
  },
  "payment": {
    "id": "pay_ffd25121f84e4d249",
    "mode": "Test",
    "paymentOption": "bancodobrasil",
    "holder": "John Doe",
    "created": "2016-03-25T13:51:04.7717784Z",
    "documentId": "1111111111111111"
  },
  "amount": 100,
  "currency": "USD",
  "merchantPassThruData": "Order #1234958",
  "created": "2016-03-25T13:51:04.8497785Z",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  },
  "ipaddress": "123.01.1",
  "redirectUrl": "http://mybankingsite.com/hRedirection.aspx?transaction_id=trn_1a5f5e0c97"
}

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Customer’s First Name Mandatory
lastName string Customer’s Last Name Mandatory
email string Customer’s Email Mandatory
address string Customer’s address - Street Name Optional
address2 string Customer’s address - Street Number Optional
city string Customer’s city Optional
zip string Customer’s city Postal Code Optional
state string Customer’s state - 2 letter code Optional
country string Customer’s country - ISO1 country Code Mandatory
birthDate date Customer’s birthday - MM/DD/YYYY Optional
phone string Customer’s phone Number Optional

PAYMENT OBJECT

Parameter Type Description Requirement
paymentOption string bancodobrasil Mandatory
holder string Customer’s First and Last Name Mandatory
documentId string Customer’s Document Id Optional

Bancontact (MisterCash)

curl https://api.alternativepayments.com/api/transactions -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
  "customer": {
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "BE"
  },
  "payment": {
    "paymentOption": "bancontact",
    "holder": "John Doe",
  },
  "amount": 100,
  "currency": "EUR",
  "ipaddress": "123.01.1",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  }
}
$customer = new \AlternativePayments\Model\Customer();
$customer->setEmail("john@doe.com");
$customer->setcountry("BE");
$customer->setFirstName("John");
$customer->setLastName("Doe");

$payment = new \AlternativePayments\Model\Payment();
$payment->setpaymentOption("mistercash");
$payment->setHolder("John Doe");

$redirect = new \AlternativePayments\Model\RedirectUrls();
$redirect->setReturnUrl("http://alternativepayments.com/message/success.html");
$redirect->setCancelUrl("http://alternativepayments.com/message/failure.html");

$transaction = new \AlternativePayments\Model\Transaction();
$transaction->setCustomer($customer);
$transaction->setPayment($payment);
$transaction->setRedirectUrls($redirect);
$transaction->setAmount(100);
$transaction->setCurrency("EUR");
$transaction->setIpAddress($ipAddress);
$res = Transaction :: post($transaction);
AlternativePayments.ApiUrl = _apiUrl;

var customer = new Customer();
customer.Email = "john@doe.com";
customer.FirstName = "John";
customer.LastName = "Doe";
customer.country = "BE";

var payment = new Payment();
payment.paymentOption = "mistercash";
payment.Holder = customer.FirstName + " " + customer.LastName;

var redirect = new RedirectUrls();
redirect.ReturnUrl = "http://alternativepayments.com/message/success.html"
redirect.CancelUrl = "http://alternativepayments.com/message/failure.html"

var transaction = new Transaction();
transaction.Customer = customer;
transaction.Payment = payment;
transaction.RedirectUrls = redirect;
transaction.Amount = 250;
transaction.Currency = "EUR";
transaction.Description = "Test transaction";

The above command returns JSON structured like this:

 customer = ApRubySdk::Customer.new(
        'firstName' => 'John',
        'lastName' => 'Doe',
        'email' => 'john@doe.com',
        'country' => 'BE'
    )

    payment = ApRubySdk::Payment.new(
        'paymentOption' => 'mistercash',
        'holder' => 'John Doe'
    )

    redirectUrls = ApRubySdk::RedirectUrls.new(
        'returnUrl' => 'http://alternativepayments.com/message/success.html',
        'cancelUrl' => 'http://alternativepayments.com/message/failure.html'
    )

    @transaction = ApRubySdk::Transaction.create(
        'customer' => customer,
        'payment' => payment,
        'amount' => 500,
        'currency' => 'EUR',
        'redirectUrls' => redirectUrls
    )
   customer = Customer(
        id='cus_bd838e3611d34d598',
        firstName='John',
        lastName='Doe',
        email='john@doe.com',
        country='BE'
    )

    payment = Payment(
        paymentOption='mistercash',
        holder='John Doe'
    )

    redirectUrls = RedirectUrls(
        returnUrl='http://alternativepayments.com/message/success.html',
        cancelUrl='http://alternativepayments.com/message/failure.html'
    )

    return Transaction.create({
        'customer': customer,
        'payment': payment,
        'amount': 500,
        'currency': 'EUR',
        'iPAddress': '123.01.1',
        'redirectUrls': redirectUrls
    })

The above command returns JSON structured like this:

{
  "id": "trn_1a5f5e0c97",
  "mode": "Test",
  "status": "Pending",
  "customer": {
    "id": "cus_bf682a6c051145a09",
    "mode": "Test",
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "BE",
    "created": "2016-03-25T13:51:04.8497785Z"
  },
  "payment": {
    "id": "pay_ffd25121f84e4d249",
    "mode": "Test",
    "paymentOption": "bancontact",
    "holder": "Piet Saar",
    "created": "2016-03-25T13:51:04.7717784Z"
  },
  "amount": 1700,
  "currency": "EUR",
  "merchantPassThruData": "Order #1234958",
  "created": "2016-03-25T13:51:04.8497785Z",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  },
  "ipaddress": "123.01.1",
  "redirectUrl": "http://mybankingsite.com/hRedirection.aspx?transaction_id=trn_1a5f5e0c97"
}

PAYMENT OBJECT

Parameter Type Description Requirement
paymentOption string bancontact Mandatory
holder string Customer’s First and Last Name Mandatory

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Customer’s First Name Mandatory
lastName string Customer’s Last Name Mandatory
email string Customer’s Email Mandatory
address string Customer’s address - Street Name Optional
address2 string Customer’s address - Street Number Optional
city string Customer’s city Optional
zip string Customer’s city Postal Code Optional
state string Customer’s state - 2 letter code Optional
country string Customer’s country - ISO1 country Code Mandatory
birthday date Customer’s birthday - MM/DD/YYYY Optional
phone string Customer’s phone Number Optional

Boleto Bancario

curl https://api.alternativepayments.com/api/transactions -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
  "customer": {
    "firstName": "Roberto",
    "lastName": "Doe",
    "email": "Roberto@Doe.com",
    "address": "Av Max Teixeira",
    "address2": "1040",
    "city": "Manaus",
    "zip": "69050-240",
    "country": "BR",
    "state": "AM",
    "birthDate": "02/05/1974",
    "phone": "+55AA7xxxxxxx",
  },
  "payment": {
    "paymentOption": "brazilpayboleto",
    "holder": "RobertoDoe",
    "documentId": "924.521.873-24",
  },
  "amount": 100,
  "currency": "EUR",
  "ipaddress": "123.01.1",
    "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  }
}
$customer = new \AlternativePayments\Model\Customer();
$customer->setFirstName("Roberto");
$customer->setLastName("Doe");
$customer->setEmail("Roberto@Doe.com");
$customer->setaddress("Av Max Teixeira");
$customer->setaddress2("1040");
$customer->setcity("Manaus");
$customer->setzip("69050-240");
$customer->setcountry("BR");
$customer->setstate("AM");
$customer->setBirthDate("02/05/1974");
$customer->setphone("+55AA7xxxxxxx");

$payment = new \AlternativePayments\Model\Payment();
$payment->setpaymentOption("brazilpayboleto");
$payment->setHolder("Roberto Doe");
$payment->setDocumentId("924.521.873-24");

$transaction = new \AlternativePayments\Model\Transaction();
$transaction->setCustomer($customer);
$transaction->setPayment($payment);
$transaction->setAmount(100);
$transaction->setCurrency("EUR");
$transaction->setIpAddress($ipAddress);
$res = Transaction :: post($transaction);
AlternativePayments.ApiUrl = _apiUrl;

var customer = new Customer();
customer.FirstName = "Roberto";
customer.LastName = "Doe";
customer.Email = "Roberto@Doe.com";
customer.address = "Av Max Teixeira";
customer.address2 = "1040";
customer.city = "Manaus";
customer.zip = "69050-240";
customer.country = "BR";
customer.state = "AM";
customer.BirthDate = "02/05/1974";
customer.phone = "+55AA7xxxxxxx";

var payment = new Payment();
payment.paymentOption = "brazilpayboleto";
payment.Holder = customer.FirstName + " " + customer.LastName;
payment.DocumentId = "924.521.873-24";

var transaction = new Transaction();
transaction.Customer = customer;
transaction.Payment = payment;
transaction.Amount = 100;
transaction.Currency = "EUR";

customer = ApRubySdk::Customer.new(
        'firstName' => 'Roberto',
        'lastName' => 'Doe',
        'email' => 'robero@doe.com',
        'address' => 'Av Max Teixeira',
        'address2' => '1040',
        'city' => 'Manaus',
        'zip' => '69050-240',
        'country' => 'BR',
        'state' => 'AM',
        'birthDate' => '13/05/1979',
        'phone' => '+5572222312'
    )

    payment = ApRubySdk::Payment.new(
        'paymentOption' => 'brazilpayboleto',
        'holder' => 'Roberto Doe',
        'documentId' => '924.521.873-24'
    )

    redirectUrls = ApRubySdk::RedirectUrls.new(
        'returnUrl' => 'http://alternativepayments.com/message/success.html',
        'cancelUrl' => 'http://alternativepayments.com/message/failure.html'
    )

    @transaction = ApRubySdk::Transaction.create(
        'customer' => customer,
        'payment' => payment,
        'amount' => 4500,
        'currency' => 'EUR',
        'redirectUrls' => redirectUrls
    )
    customer = Customer(
        firstName='Roberto',
        lastName='Doe',
        email='roberto@doe.com',
        address='Av Max Teixeira',
        address2='1040',
        city='Manaus',
        zip='69050-240',
        country='BR',
        state='AM',
        birthDate='02/05/1974',
        phone='+5572222312'
    )

    payment = Payment(
        paymentOption='brazilpayboleto',
        holder='Roberto Doe',
        documentId='924.521.873-24'
    )

    redirectUrls = RedirectUrls(
        returnUrl='http://alternativepayments.com/message/success.html',
        cancelUrl='http://alternativepayments.com/message/failure.html'
    )

    return Transaction.create({
        'customer': customer,
        'payment': payment,
        'amount': 4500,
        'currency': 'EUR',
        'iPAddress': '123.01.1',
        'redirectUrls': redirectUrls
    })

The above command returns JSON structured like this:

{
  "id": "trn_43baf0cf75",
  "mode": "Test",
  "status": "Pending",
  "customer": {
    "id": "cus_cacc9d89ee674e44b",
    "mode": "Test",
    "firstName": "Roberto",
    "lastName": "Doe",
    "email": "roberto@doe.com",
    "address": "Av Max Teixeira",
    "address2": "1040",
    "city": "Manaus",
    "zip": "69050-240",
    "country": "BR",
    "state": "AM",
    "phone": "+38132423423",
    "birthDate": "02/05/1974",
    "created": "2016-03-25T14:00:38.0421808Z"
  },
  "payment": {
    "id": "pay_abcaa1351f5c45fe8",
    "mode": "Test",
    "paymentOption": "brazilpayboleto",
    "holder": "Jose Doe",
    "created": "2016-03-25T14:00:37.9641807Z",
    "documentId": "924.521.873-24"
  },
  "amount": 1700,
  "currency": "EUR",
  "merchantPassThruData": "stevs9aara12",
  "created": "2016-03-25T14:00:38.0421808Z",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  },
  "ipaddress": "123.01.1",
  "redirectUrl": "https://sandbox.url.com/print/?hash=56f1bbf021c8a40"
}

PAYMENT OBJECT

Parameter Type Description Requirement
paymentOption string brazilpayboleto Mandatory
holder string Customer’s First and Last Name Mandatory
DocumentId string Customer’s Document Id Mandatory

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Customer’s First Name Mandatory
lastName string Customer’s Last Name Mandatory
email string Customer’s Email Mandatory
address string Customer’s address - Street Name Mandatory
address2 string Customer’s address - Street Number Mandatory
city string Customer’s city Mandatory
zip string Customer’s city Postal Code Mandatory
state string Customer’s state - 2 letter code Mandatory
country string Customer’s country - ISO1 country Code Mandatory
birthday date Customer’s birthday - MM/DD/YYYY Mandatory
phone string Customer’s phone Number Mandatory

Bradesco

curl https://api.alternativepayments.com/api/transactions -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
    "customer": {
        "firstName": "John",
        "lastName": "Doe",
        "email": "john@doe.com",
        "country": "BR",
        "phone": "+5500147258369"
    },
    "currency": "EUR",
    "amount": 313,
    "ipaddress": "72.201.94.150",
    "payment": {
        "holder": "John Doe",
        "paymentOption": "Bradesco",
        "DocumentId": "XXX.XXX.XXX"
    },
    "redirectUrls": {
        "returnUrl": "http://alternativepayments.com/message/success.html",
        "cancelUrl": "http://alternativepayments.com/message/failure.html"
    }
}

The above command returns JSON structured like this:

{
    "id": "trn_a9cf2fb609434e",
    "mode": "Live",
    "status": "Pending",
    "customer": {
        "id": "cus_a6b47e15f17a4c0b9",
        "mode": "Live",
        "firstName": "John",
        "lastName": "Doe",
        "email": "john@doe.com",
        "country": "BR",
        "phone": "+5500147258369",
        "created": "2020-11-20T13:35:06.3542905Z"
    },
    "payment": {
        "id": "pay_6b7036d90e3a449da",
        "mode": "Live",
        "paymentOption": "Bradesco",
        "holder": "John Doe",
        "created": "2020-11-20T13:35:06.2605426Z",
        "ipAddress": "72.201.94.150"
    },
    "amount": 313.0,
    "currency": "EUR",
    "created": "2020-11-20T13:35:06.3386658Z",
    "redirectUrls": {
        "returnUrl": "http://alternativepayments.com/message/success.html",
        "cancelUrl": "http://alternativepayments.com/message/failure.html"
    },
    "redirectUrl": "https://www.paygol.com/api/pay-direct/XXX-XXX-XXX",
    "ipAddress": "72.201.94.150"
}

PAYMENT OBJECT

Parameter Type Description Requirement
paymentOption string Bradesco Mandatory
holder string Customer’s First and Last Name Mandatory
DocumentId string Customer’s Document Id Mandatory

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Customer’s First Name Mandatory
lastName string Customer’s Last Name Mandatory
email string Customer’s Email Mandatory
address string Customer’s address - Street Name Optional
address2 string Customer’s address - Street Number Optional
city string Customer’s city Optional
zip string Customer’s city Postal Code Optional
state string Customer’s state - 2 letter code Optional
country string Customer’s country - ISO1 country Code Mandatory
birthday date Customer’s birthday - MM/DD/YYYY Optional
phone string Customer’s phone Number Optional

BrazilPay Bank Transfer

curl https://api.alternativepayments.com/api/transactions -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
  "customer": {
    "firstName": "Roberto",
    "lastName": "Doe",
    "email": "Roberto@Doe.com",
    "address": "Av Max Teixeira",
    "address2": "1040",
    "city": "Manaus",
    "zip": "69050-240",
    "country": "BR",
    "state": "AM",
    "birthDate": "02/05/1974",
    "phone": "+55AA7xxxxxxx"
  },
  "payment": {
    "paymentOption": "brazilpaybanktransfer",
    "holder": "Roberto Doe",
    "documentId": "924.521.873-24",
    "bankCode": "hsbc"
  },
  "amount": 100,
  "currency": "EUR",
  "ipaddress": "123.01.1",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  }
}
$customer = new \AlternativePayments\Model\Customer();
$customer->setFirstName("Roberto");
$customer->setLastName("Doe");
$customer->setEmail("Roberto@Doe.com");
$customer->setaddress("Av Max Teixeira");
$customer->setaddress2("1040");
$customer->setcity("Manaus");
$customer->setzip("69050-240");
$customer->setcountry("BR");
$customer->setstate("AM");
$customer->setBirthDate("02/05/1974");
$customer->setphone("+55AA7xxxxxxx");

$payment = new \AlternativePayments\Model\Payment();
$payment->setpaymentOption("brazilpayboleto");
$payment->setHolder("Roberto Doe");
$payment->setDocumentId("924.521.873-24");
$payment->setbankCode("hsbc");

$redirect = new \AlternativePayments\Model\RedirectUrls();
$redirect->setReturnUrl("http://alternativepayments.com/message/success.html");
$redirect->setCancelUrl("http://alternativepayments.com/message/failure.html");

$transaction = new \AlternativePayments\Model\Transaction();
$transaction->setCustomer($customer);
$transaction->setPayment($payment);
$transaction->setRedirectUrls($redirect);
$transaction->setAmount(100);
$transaction->setCurrency("EUR");
$transaction->setIpAddress($ipAddress);
$res = Transaction :: post($transaction);
 AlternativePayments.ApiUrl = _apiUrl;

var customer = new Customer();
customer.FirstName = "Roberto";
customer.LastName = "Doe";
customer.Email = "Roberto@Doe.com";
customer.address = "Av Max Teixeira";
customer.address2 = "1040";
customer.city = "Manaus";
customer.zip = "69050-240";
customer.country = "BR";
customer.state = "AM";
customer.BirthDate = "02/05/1974";
customer.phone = "+55AA7xxxxxxx";

var payment = new Payment();
payment.paymentOption = "brazilpaybanktransfer";
payment.Holder = customer.FirstName + " " + customer.LastName;
payment.DocumentId = "924.521.873-24";
payment.bankCode =  "hsbc";

var redirect = new RedirectUrls();
redirect.ReturnUrl = "http://alternativepayments.com/message/success.html"
redirect.CancelUrl = "http://alternativepayments.com/message/failure.html"

var transaction = new Transaction();
transaction.Customer = customer;
transaction.Payment = payment;
transaction.RedirectUrls = redirect;
transaction.Amount = 100;
transaction.Currency = "EUR";
    customer = ApRubySdk::Customer.new(
        'firstName' => 'Roberto',
        'lastName' => 'Doe',
        'email' => 'roberto@doe.com',
        'address' => '"Av Max Teixeira',
        'address2' => '1040',
        'city' => 'Manaus',
        'zip' => '69050-240',
        'country' => 'BR',
        'state' => 'AM',
        'birthDate' => '02/05/1974',
        'phone' => '+5572222312'
    )

    payment = ApRubySdk::Payment.new(
        'paymentOption' => 'brazilpaybanktransfer',
        'holder' => 'Roberto Doe',
        'documentId' => '924.521.873-24',
        'bankCode' => 'hsbc'
    )

    redirectUrls = ApRubySdk::RedirectUrls.new(
        'returnUrl' => 'http://alternativepayments.com/message/success.html',
        'cancelUrl' => 'http://alternativepayments.com/message/failure.html'
    )

    @transaction = ApRubySdk::Transaction.create(
        'customer' => customer,
        'payment' => payment,
        'amount' => 4500,
        'currency' => 'EUR',
        'redirectUrls' => redirectUrls
    )
    customer = Customer(
        firstName='Roberto',
        lastName='Doe',
        email='roberto@doe.com',
        address='Av Max Teixeira',
        address2='1040',
        city='Manaus',
        zip='69050-240',
        country='BR',
        state='AM',
        birthDate='02/05/1974',
        phone='+5572222312'
    )

    payment = Payment(
        paymentOption='brazilpaybanktransfer',
        holder='Roberto Doe',
        documentId='924.521.873-24',
        bankCode='hsbc'
    )

    redirectUrls = RedirectUrls(
        returnUrl='http://alternativepayments.com/message/success.html',
        cancelUrl='http://alternativepayments.com/message/failure.html'
    )

    return Transaction.create({
        'customer': customer,
        'payment': payment,
        'amount': 4500,
        'currency': 'EUR',
        'iPAddress': '123.01.1',
        'redirectUrls': redirectUrls
    })

The above command returns JSON structured like this:

{
  "id": "trn_e28e2e57ab",
  "mode": "Test",
  "status": "Pending",
  "customer": {
    "id": "cus_a39f89674ea840ce8",
    "mode": "Test",
    "firstName": "Roberto",
    "lastName": "Doe",
    "email": "roberto@doe.com",
    "address": "Av Max Teixeira",
    "address2": "1040",
    "city": "Manaus",
    "zip": "69050-240",
    "country": "BR",
    "state": "AM",
    "phone": "+38132423423",
    "birthDate": "02/05/1974",
    "created": "2016-03-25T13:57:50.5420268Z"
  },
  "payment": {
    "id": "pay_9ce54df4423e4b228",
    "mode": "Test",
    "paymentOption": "brazilpaybanktransfer",
    "holder": "Roberto Doe",
    "created": "2016-03-25T13:57:50.4484266Z",
    "bankCode": "hsbc",
    "documentId": "924.521.873-24"
  },
  "amount": 1700,
  "currency": "EUR",
  "ipaddress": "123.01.1",
  "merchantPassThruData": "stevs9aara12",
  "created": "2016-03-25T13:57:50.5420268Z",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  },
  "ipaddress": "123.01.1",
  "redirectUrl": "http://alternativepayments.com/message/success.html"
}

PAYMENT OBJECT

Parameter Type Description Requirement
paymentOption string brazilpaybanktransfer Mandatory
holder string Customer’s First and Last Name Mandatory
DocumentId string Customer’s Document Id Mandatory
bankCode string Customer’s Bank Code Mandatory

Bank Codes

bankCode Bank name
banrisul Banrisul
bradesco Bradesco
bancodobrasil Banco do Brasil
hsbc HSBC Bank
itau Itaú

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Customer’s First Name Mandatory
lastName string Customer’s Last Name Mandatory
email string Customer’s Email Mandatory
address string Customer’s address - Street Name Mandatory
address2 string Customer’s address - Street Number Mandatory
city string Customer’s city Mandatory
zip string Customer’s city Postal Code Mandatory
state string Customer’s state - 2 letter code Mandatory
country string Customer’s country - ISO1 country Code Mandatory
birthday date Customer’s birthday - MM/DD/YYYY Mandatory
phone string Customer’s phone Number Mandatory

BrazilPay Charge Card

curl https://api.alternativepayments.com/api/transactions -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
  "customer": {
    "firstName": "Roberto",
    "lastName": "Doe",
    "email": "Roberto@Doe.com",
    "address": "Av Max Teixeira",
    "address2": "1040",
    "city": "Manaus",
    "zip": "69050-240",
    "country": "BR",
    "state": "AM",
    "birthDate": "02/05/1974",
    "phone": "+55AA7xxxxxxx",
  },
  "payment": {
      "PaymentOption":"brazilpaychargecard",
      "Holder":"Habib Burgiba",
      "DocumentId":"851.453.477-03",
      "CreditCardType":"visa",
      "CreditCardNumber":"4111111111111111",
      "CVV2":"123",
      "ExpirationMonth":12,
      "ExpirationYear":2017
  },
  "amount": 100,
  "currency": "EUR",
  "ipaddress": "123.01.1",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  }
}

The above command returns JSON structured like this:

{
  "id": "trn_e28e2e57ab",
  "mode": "Test",
  "status": "Pending",
  "customer": {
    "id": "cus_a39f89674ea840ce8",
    "mode": "Test",
    "firstName": "Roberto",
    "lastName": "Doe",
    "email": "roberto@doe.com",
    "address": "Av Max Teixeira",
    "address2": "1040",
    "city": "Manaus",
    "zip": "69050-240",
    "country": "BR",
    "state": "AM",
    "phone": "+38132423423",
    "birthDate": "02/05/1974",
    "created": "2016-03-25T13:57:50.5420268Z"
  },
  "payment": {
    "id": "pay_f2c13c00da8d42adb",
    "mode": "Test",
    "paymentOption": "brazilpaychargecard",
    "holder": "Habib Burgiba",
    "created": "2017-02-09T10:01:13.5785715Z",
    "creditCardType": "visa",
    "creditCardNumber": "XXXXXXXXXXX1111",
    "ipAddress": "123.01.1"
  },
  "amount": 1700,
  "currency": "EUR",
  "ipaddress": "123.01.1",
  "created": "2016-03-25T13:57:50.5420268Z",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  },
  "ipaddress": "123.01.1",
  "redirectUrl": "http://alternativepayments.com/message/success.html"
}

PAYMENT OBJECT

Parameter Type Description Requirement
paymentOption string brazilpaychargecard Mandatory
holder string Customer’s First and Last Name Mandatory
DocumentId string Customer’s Document Id Mandatory
CreditCardType string Credit Card Type Mandatory
CreditCardNumber string Credit Card Number Mandatory
CVV2 string Customer’s Card Security Code Mandatory
ExpirationMonth integer Cards Expiration Month Mandatory
ExpirationYear integer Cards Expiration Year Mandatory

BANK CODES

bankCode Bank name
banrisul Banrisul
bradesco Bradesco
bancodobrasil Banco do Brasil
hsbc HSBC Bank
itau Itaú

CREDIT CARD TYPES

CreditCardType Credit Card types
amex American Express
aura Aura
diners Diners
discover Discover
elo Elo
hipercard Hipercard
mastercard Mastercard
visa Visa

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Customer’s First Name Mandatory
lastName string Customer’s Last Name Mandatory
email string Customer’s Email Mandatory
address string Customer’s address - Street Name Mandatory
address2 string Customer’s address - Street Number Mandatory
city string Customer’s city Mandatory
zip string Customer’s city Postal Code Mandatory
state string Customer’s state - 2 letter code Mandatory
country string Customer’s country - ISO1 country Code Mandatory
birthday date Customer’s birthday - MM/DD/YYYY Mandatory
phone string Customer’s phone Number Mandatory

Bitcoin

curl https://api.alternativepayments.com/api/transactions -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
  "customer": {
    "firstName": "John",
    "lastName": "Doe",
    "email": "johndoe@gmail.com",
    "country": "DE"
  },
  "currency": "EUR",
  "amount": 3000,
  "ipaddress": "123.01.1",
  "payment": {
    "holder": "John Doe",
    "paymentOption": "bitcoin"
  },
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  }
}

The above command returns JSON structured like this:

{
    "id": "trn_123abc123abc",
    "mode": "Live",
    "status": "Pending",
    "customer": {
        "id": "cus_501234552c94c9db",
        "mode": "Live",
        "firstName": "John",
        "lastName": "Doe",
        "email": "johndoe@gmail.com",
        "country": "DE",
        "created": "2018-09-12T12:17:09.0558721Z"
    },
    "payment": {
        "id": "pay_1234545e8be94888a",
        "mode": "Live",
        "paymentOption": "bitcoin",
        "holder": "John Doe",
        "created": "2018-09-12T12:17:09.0288548Z",
        "ipAddress": "123.01.1"
    },
    "amount": 3000,
    "currency": "EUR",
    "created": "2018-09-12T12:17:09.0518613Z",
    "redirectUrls": {
        "returnUrl": "http://alternativepayments.com/message/success.html",
        "cancelUrl": "http://alternativepayments.com/message/failure.html"
    },
    "redirectUrl": "https://bitpay.com/invoice?id=12345abcTXaN6o8wkdaagGa",
    "ipAddress": "123.01.1"
}

PAYMENT OBJECT

Parameter Type Description Requirement
paymentOption string bitcoin Mandatory
holder string Customer’s First and Last Name Mandatory

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Customer’s First Name Mandatory
lastName string Customer’s Last Name Mandatory
email string Customer’s Email Mandatory
address string Customer’s address - Street Name Optional
address2 string Customer’s address - Street Number Optional
city string Customer’s city Optional
zip string Customer’s city Postal Code Optional
state string Customer’s state - 2 letter code Optional
country string Customer’s country - ISO1 country Code Mandatory
birthday date Customer’s birthday - MM/DD/YYYY Optional
phone string Customer’s phone Number Optional

Credit Card

curl https://api.alternativepayments.com/api/transactions -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
   "customer": {
     "firstName": "John",
     "lastName": "Doe",
     "email": "john@doe.com",
     "country": "US"
   },
   "payment": {
     "paymentOption": "creditcard",
     "holder": "John Doe",
     "creditCardNumber": "4111111111111111",
     "CVV2": "222",
     "creditCardType": "visa",
     "expirationYear": "2019",
     "expirationMonth": "12"
   },
   "amount": 1500,
   "currency": "EUR",
   "ipaddress": "123.01.1"
}'

   customer = Customer(
        id='cus_bd838e3611d34d598',
        firstName='John',
        lastName='Doe',
        email='john@doe.com',
        country='US'
    )

    payment = Payment(
        paymentOption='creditcard',
        holder='John Doe',
        creditCardNumber='4111111111111111',
        CVV2='222',
        creditCardType='visa',
        expirationYear='2019',
        expirationMonth='12'
    )

    redirectUrls = RedirectUrls(
        returnUrl='http://alternativepayments.com/message/success.html',
        cancelUrl='http://alternativepayments.com/message/failure.html'
    )

    return Transaction.create({
        'customer': customer,
        'payment': payment,
        'amount': 500,
        'currency': 'EUR',
        'iPAddress': '123.01.1',
        'redirectUrls': redirectUrls
    })

The above command returns JSON structured like this:

{
  "id": "trn_f7cb2b6631",
  "mode": "Test",
  "status": "Funded",
  "customer": {
    "id": "cus_ecaec09a0776434ea",
    "mode": "Test",
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "US",
    "created": "2016-05-19T08:18:51.1610893Z"
  },
  "payment": {
    "id": "pay_b8bc6359ef1b4e4da",
    "mode": "Test",
    "paymentOption": "creditcard",
    "holder": "John Doe",
    "created": "2016-05-19T08:18:51.1298382Z",
    "creditCardNumber": "XXXXXXXXXXX1111",
    "creditCardType":"visa",
    "expirationMonth": 12,
    "expirationYear": 2019
  },
  "amount": 1500,
  "currency": "EUR",
  "created": "2016-05-19T08:18:51.1610893Z"
}

You can also use preauthorization prior to executing the transaction. For this, please see Preauthorization

If you’re accepting credit cards, tokenization must be used to be PCI compliant.

PAYMENT OBJECT

Parameter Type Description Requirement
paymentOption string creditcard Mandatory
holder string Customer’s First and Last Name Mandatory
creditCardNumber string Customer’s CC number Mandatory
CVV2 string Credit Card CVV2 number Mandatory
expirationYear integer Expiry year of the credit card Mandatory
expirationMonth integer Expiry month of the credit card Mandatory
creditCardType string Type of credit card Mandatory
creditCardType parameter Payment Option
visa Visa
mastercard Mastercard
jcb JCB
discover Discover

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Customer’s First Name Mandatory
lastName string Customer’s Last Name Mandatory
email string Customer’s Email Mandatory
address string Customer’s address - Street Name Optional
address2 string Customer’s address - Street Number Optional
city string Customer’s city Optional
zip string Customer’s city Postal Code Optional
state string Customer’s state - 2 letter code Optional
country string Customer’s country - ISO1 country Code Mandatory
birthday date Customer’s birthday - MM/DD/YYYY Optional
phone string Customer’s phone Number Optional

DirectPayEU

curl https://api.alternativepayments.com/api/transactions -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
   "customer":{
    "firstName":"John",
    "lastName":"Doe",
    "email":"john@doe.com",
    "country":"DE"
   },
   "payment":{
    "paymentOption":"directpayeu",
    "holder":"John Doe"
   },
   "amount": 100,
   "currency":"EUR",
   "ipAddress":"123.01.1",
   "redirectUrls":{
       "returnUrl": "http://alternativepayments.com/message/success.html",
       "cancelUrl": "http://alternativepayments.com/message/failure.html"
    }
}
$customer = new \AlternativePayments\Model\Customer();
$customer->setEmail("john@doe.com");
$customer->setcountry("DE");
$customer->setFirstName("John");
$customer->setLastName("Doe");

$payment = new \AlternativePayments\Model\Payment();
$payment->setpaymentOption("directpayeu");
$payment->setHolder("John Doe");

$redirect = new \AlternativePayments\Model\RedirectUrls();
$redirect->setReturnUrl("http://alternativepayments.com/message/success.html");
$redirect->setCancelUrl("http://alternativepayments.com/message/failure.html");

$transaction = new \AlternativePayments\Model\Transaction();
$transaction->setCustomer($customer);
$transaction->setPayment($payment);
$transaction->setRedirectUrls($redirect);
$transaction->setAmount(100);
$transaction->setCurrency("EUR");
$transaction->setIpAddress($ipAddress);
$res = Transaction :: post($transaction);
AlternativePayments.ApiUrl = _apiUrl;

var customer = new Customer();
customer.Email = "john@doe.com";
customer.FirstName = "John";
customer.LastName = "Doe";
customer.country = "DE";

var payment = new Payment();
payment.paymentOption = "directpayeu";
payment.Holder = customer.FirstName + " " + customer.LastName;

var redirect = new RedirectUrls();
redirect.ReturnUrl = "http://alternativepayments.com/message/success.html"
redirect.CancelUrl = "http://alternativepayments.com/message/failure.html"

var transaction = new Transaction();
transaction.Customer = customer;
transaction.Payment = payment;
transaction.RedirectUrls = redirect;
transaction.Amount = 250;
transaction.Currency = "EUR";
transaction.Description = "Test transaction";
customer = ApRubySdk::Customer.new(
        'firstName' => 'John',
        'lastName' => 'Doe',
        'email' => 'john@doe.com',
        'country' => 'DE'
    )

    payment = ApRubySdk::Payment.new(
        'paymentOption' => 'directpayeu',
        'holder' => 'John Doe'
    )

    redirectUrls = ApRubySdk::RedirectUrls.new(
        'returnUrl' => 'http://alternativepayments.com/message/success.html',
        'cancelUrl' => 'http://alternativepayments.com/message/failure.html'
    )

    @transaction = ApRubySdk::Transaction.create(
        'customer' => customer,
        'payment' => payment,
        'amount' => 100,
        'currency' => 'EUR',
        'redirectUrls' => redirectUrls
    )
   customer = Customer(
        firstName='John',
        lastName='Doe',
        email='john@doe.com',
        country='DE'
    )

    payment = Payment(
        paymentOption='directpayeu',
        holder='John Doe'
    )

    redirectUrls = RedirectUrls(
        returnUrl='http://alternativepayments.com/message/success.html',
        cancelUrl='http://alternativepayments.com/message/failure.html'
    )

    return Transaction.create({
        'customer': customer,
        'payment': payment,
        'amount': 100,
        'currency': 'EUR',
        'iPAddress': '123.01.1',
        'redirectUrls': redirectUrls
    })

The above command returns JSON structured like this:

{
  "id": "trn_1a5f5e0c97",
  "mode": "Test",
  "status": "Pending",
  "customer": {
    "id": "cus_bf682a6c051145a09",
    "mode": "Test",
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "DE",
    "created": "2016-03-25T13:51:04.8497785Z"
  },
  "payment": {
    "id": "pay_ffd25121f84e4d249",
    "mode": "Test",
    "paymentOption": "directpayeu",
    "holder": "John Doe",
    "created": "2016-03-25T13:51:04.7717784Z"
  },
  "amount": 1700,
  "currency": "EUR",
  "created": "2016-03-25T13:51:04.8497785Z",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  },
  "ipaddress": "123.01.1",
  "redirectUrl": "http://mybankingsite.com/hRedirection.aspx?transaction_id=trn_1a5f5e0c97"
}

DirectPayEU is credit transfer payment method made at the initiative of the consumer, and the payment is “pushed” to the bank account of the merchant. Bank transfers are the most common form of cashless consumer payments in most countries within the European Union and Asia–Pacific. It is not suitable for subscriptions or recurring payments since the consumer must initiate each payment.

PAYMENT OBJECT

Parameter Type Description Requirement
paymentOption string directpayeu Mandatory
holder string Customer’s First and Last Name Mandatory

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Customer’s First Name Mandatory
lastName string Customer’s Last Name Mandatory
email string Customer’s Email Mandatory
address string Customer’s address - Street Name Optional
address2 string Customer’s address - Street Number Optional
city string Customer’s city Optional
zip string Customer’s city Postal Code Optional
state string Customer’s state - 2 letter code Optional
country string Customer’s country - ISO1 country Code Mandatory
birthday date Customer’s birthday - MM/DD/YYYY Optional
phone string Customer’s phone Number Optional

DPMax

curl https://api.alternativepayments.com/api/transactions -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
   "customer":{
    "firstName":"John",
    "lastName":"Doe",
    "email":"john@doe.com",
    "country":"DE"
   },
   "payment":{
    "paymentOption":"DirectPayMax",
    "holder":"John Doe",
     "iban": "DE19500105171654629345"
   },
   "amount": 100,
   "currency":"EUR",
   "ipAddress":"123.01.1",
   "redirectUrls":{
       "returnUrl": "http://alternativepayments.com/message/success.html",
       "cancelUrl": "http://alternativepayments.com/message/failure.html"
    }
}
$customer = new \AlternativePayments\Model\Customer();
$customer->setEmail("john@doe.com");
$customer->setcountry("DE");
$customer->setFirstName("John");
$customer->setLastName("Doe");

$payment = new \AlternativePayments\Model\Payment();
$payment->setpaymentOption("DirectPayMax");
$payment->setHolder("John Doe");
$payment->iban("DE76500105171459832919");

$redirect = new \AlternativePayments\Model\RedirectUrls();
$redirect->setReturnUrl("http://alternativepayments.com/message/success.html");
$redirect->setCancelUrl("http://alternativepayments.com/message/failure.html");

$transaction = new \AlternativePayments\Model\Transaction();
$transaction->setCustomer($customer);
$transaction->setPayment($payment);
$transaction->setRedirectUrls($redirect);
$transaction->setAmount(100);
$transaction->setCurrency("EUR");
$transaction->setIpAddress($ipAddress);
$res = Transaction :: post($transaction);
AlternativePayments.ApiUrl = _apiUrl;

var customer = new Customer();
customer.Email = "john@doe.com";
customer.FirstName = "John";
customer.LastName = "Doe";
customer.country = "DE";

var payment = new Payment();
payment.paymentOption = "DirectPayMax";
payment.Holder = customer.FirstName + " " + customer.LastName;
payment.iban = "DE76500105171459832919";

var redirect = new RedirectUrls();
redirect.ReturnUrl = "http://alternativepayments.com/message/success.html"
redirect.CancelUrl = "http://alternativepayments.com/message/failure.html"

var transaction = new Transaction();
transaction.Customer = customer;
transaction.Payment = payment;
transaction.RedirectUrls = redirect;
transaction.Amount = 250;
transaction.Currency = "EUR";
transaction.Description = "Test transaction";
customer = ApRubySdk::Customer.new(
        'firstName' => 'John',
        'lastName' => 'Doe',
        'email' => 'john@doe.com',
        'country' => 'DE'
    )

    payment = ApRubySdk::Payment.new(
        'paymentOption' => 'DirectPayMax',
        'holder' => 'John Doe',
        'iban' => 'DE76500105171459832919'
    )

    redirectUrls = ApRubySdk::RedirectUrls.new(
        'returnUrl' => 'http://alternativepayments.com/message/success.html',
        'cancelUrl' => 'http://alternativepayments.com/message/failure.html'
    )

    @transaction = ApRubySdk::Transaction.create(
        'customer' => customer,
        'payment' => payment,
        'amount' => 100,
        'currency' => 'EUR',
        'redirectUrls' => redirectUrls
    )
   customer = Customer(
        firstName='John',
        lastName='Doe',
        email='john@doe.com',
        country='DE'
    )

    payment = Payment(
        paymentOption='DirectPayMax',
        holder='John Doe',
        iban='DE76500105171459832919'
    )

    redirectUrls = RedirectUrls(
        returnUrl='http://alternativepayments.com/message/success.html',
        cancelUrl='http://alternativepayments.com/message/failure.html'
    )

    return Transaction.create({
        'customer': customer,
        'payment': payment,
        'amount': 100,
        'currency': 'EUR',
        'iPAddress': '123.01.1',
        'redirectUrls': redirectUrls
    })

The above command returns JSON structured like this:

{
    "id": "trn_4295124a85ea46",
    "mode": "Live",
    "status": "AwaitingAuthorization",
    "customer": {
        "id": "cus_ba0df2c1723347979",
        "mode": "Live",
        "firstName": "John",
        "lastName": "Doe",
        "email": "john@doe.com",
        "country": "DE",
        "created": "2022-04-12T09:26:22.4547812Z"
    },
    "payment": {
        "id": "pay_35c9eb043a034301a",
        "mode": "Live",
        "paymentOption": "DirectPayMax",
        "holder": "John Doe",
        "iban": "DE19XXXXX9345",
        "created": "2022-04-12T09:26:22.4234722Z",
        "ipAddress": "123.01.1"
    },
    "amount": 100.0,
    "currency": "EUR",
    "created": "2022-04-12T09:26:22.4547812Z",
    "redirectUrls": {
        "returnUrl": "http://alternativepayments.com/message/success.html",
        "cancelUrl": "http://alternativepayments.com/message/failure.html"
    },
    "redirectUrl": "http://authorization-url.com",
  "authorizationFlow": "Redirect",
    "ipAddress": "123.01.1"
}

PAYMENT OBJECT

Parameter Type Description Requirement
paymentOption string DirectPayMax Mandatory
holder string Customer’s First and Last Name Mandatory
iban string Customers IBAN IBAN or BIC should be provided
psuId string Payment Service User Id Required for some institutions
bic string Customers BIC IBAN or BIC should be provided

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Customer’s First Name Mandatory
lastName string Customer’s Last Name Mandatory
email string Customer’s Email Mandatory
address string Customer’s address - Street Name Optional
address2 string Customer’s address - Street Number Optional
city string Customer’s city Optional
zip string Customer’s city Postal Code Optional
state string Customer’s state - 2 letter code Optional
country string Customer’s country - ISO1 country Code Mandatory
birthday date Customer’s birthday - MM/DD/YYYY Optional
phone string Customer’s phone Number Optional

EPS

curl https://api.alternativepayments.com/api/transactions -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
  "customer": {
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "AT"
  },
  "payment": {
    "paymentOption": "eps",
    "bic": "TESTDETT421",
    "holder": "John Doe"
  },
  "amount": 100,
  "currency": "EUR",
  "ipaddress": "123.01.1",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  }
}

$customer = new \AlternativePayments\Model\Customer();
$customer->setFirstName("John");
$customer->setLastName("Doe");
$customer->setEmail("john@doe.com");
$customer->setcountry("AT");

$payment = new \AlternativePayments\Model\Payment();
$payment->setpaymentOption("eps");
$payment->setHolder("John Doe");
$payment->setBIC("TESTDETT421");

$redirect = new \AlternativePayments\Model\RedirectUrls();
$redirect->setCancelUrl("http://alternativepayments.com/message/failure.html");
$redirect->setReturnUrl("http://alternativepayments.com/message/success.html");

$transaction = new \AlternativePayments\Model\Transaction();
$transaction->setCustomer($customer);
$transaction->setPayment($payment);
$transaction->setRedirectUrls($redirect);
$transaction->setAmount(100);
$transaction->setCurrency("EUR");
$transaction->setIpAddress($ipAddress);
$res = \AlternativePayments\Transaction :: post($transaction);
AlternativePayments.ApiUrl = _apiUrl;

var customer = new Customer();
customer.FirstName = "John";
customer.LastName = "Doe";
customer.Email = "john@doe.com";
customer.country = "AT";

var payment = new Payment();
payment.paymentOption = "eps";
payment.Holder = customer.FirstName + " " + customer.LastName;
payment.bic = "TESTDETT421";

var redirect = new RedirectUrls();
redirect.CancelUrl = "http://alternativepayments.com/message/failure.html"

var transaction = new Transaction();
transaction.Customer = customer;
transaction.Payment = payment;
transaction.RedirectUrls = redirect;
transaction.Amount = 100;
transaction.Currency = "EUR";
customer = ApRubySdk::Customer.new(
        'firstName' => 'John',
        'lastName' => 'Doe',
        'email' => 'john@doe.com',
        'country' => 'AT'
    )

    payment = ApRubySdk::Payment.new(
        'paymentOption' => 'eps',
        'holder' => 'John Doe',
        'bic' => 'TESTDETT421'

    )

    redirectUrls = ApRubySdk::RedirectUrls.new(
        'returnUrl' => 'http://alternativepayments.com/message/success.html',
        'cancelUrl' => 'http://alternativepayments.com/message/failure.html'
    )

    @transaction = ApRubySdk::Transaction.create(
        'customer' => customer,
        'payment' => payment,
        'amount' => 500,
        'currency' => 'EUR',
        'redirectUrls' => redirectUrls
    )
    customer = Customer(
        firstName='John',
        lastName='Doe',
        email='john@doe.com',
        country='AT'
    )

    payment = Payment(
        paymentOption='eps',
        holder='John Doe',
        bic='TESTDETT421'
    )

    redirectUrls = RedirectUrls(
        returnUrl='http://alternativepayments.com/message/success.html',
        cancelUrl='http://alternativepayments.com/message/failure.html'
    )

    return Transaction.create({
        'customer': customer,
        'payment': payment,
        'amount': 500,
        'currency': 'EUR',
        'iPAddress': '123.01.1',
        'redirectUrls': redirectUrls
    })

The above command returns JSON structured like this:

{
  "id": "trn_2bbcd34688",
  "mode": "Test",
  "status": "Pending",
  "customer": {
    "id": "cus_b9c6a32127724ecea",
    "mode": "Test",
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "AT",
    "created": "2016-03-25T14:04:41.7643102Z"
  },
  "payment": {
    "id": "pay_f633ab65f86b4dac8",
    "mode": "Test",
    "paymentOption": "eps",
    "holder": "John Doe",
    "bic": "TESTDETT421",
    "created": "2016-03-25T14:04:41.6863101Z"
  },
  "amount": 23,
  "currency": "EUR",
  "merchantPassThruData": "order_242444",
  "created": "2016-03-25T14:04:41.7643102Z",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  },
  "ipaddress": "123.01.1",
  "redirectUrl": "http://checkout.nts.com/direction.aspx?transaction_id=trn_2688"
}

PAYMENT OBJECT

Parameter Type Description Requirement
paymentOption string eps Mandatory
holder string Customer’s First and Last Name Mandatory
BIC string Customer’s BIC Mandatory

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Customer’s First Name Mandatory
lastName string Customer’s Last Name Mandatory
email string Customer’s Email Mandatory
address string Customer’s address - Street Name Optional
address2 string Customer’s address - Street Number Optional
city string Customer’s city Optional
zip string Customer’s city Postal Code Optional
state string Customer’s state - 2 letter code Optional
country string Customer’s country - ISO1 country Code Mandatory
birthday date Customer’s birthday - MM/DD/YYYY Optional
phone string Customer’s phone Number Optional

Efecty

curl https://api.alternativepayments.com/api/transactions -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
    "customer": {
        "firstName": "John",
        "lastName": "Doe",
        "email": "john@doe.com",
        "country": "CO"
    },
    "currency": "EUR",
    "amount": 1299,
    "ipaddress": "72.201.94.150",
    "payment": {
        "holder": "John Doe",
        "paymentOption": "Efecty",
        "DocumentId": "XXX.XXX.XXX"
    },
    "redirectUrls": {
        "returnUrl": "http://alternativepayments.com/message/success.html",
        "cancelUrl": "http://alternativepayments.com/message/failure.html"
    }
}

The above command returns JSON structured like this:

{
    "id": "trn_a9cf2fb609434e",
    "mode": "Live",
    "status": "Pending",
    "customer": {
        "id": "cus_a6b47e15f17a4c0b9",
        "mode": "Live",
        "firstName": "John",
        "lastName": "Doe",
        "email": "john@doe.com",
        "country": "CO",
        "created": "2020-11-20T13:35:06.3542905Z"
    },
    "payment": {
        "id": "pay_6b7036d90e3a449da",
        "mode": "Live",
        "paymentOption": "Efecty",
        "holder": "John Doe",
        "created": "2020-11-20T13:35:06.2605426Z",
        "ipAddress": "72.201.94.150"
    },
    "amount": 135.0,
    "currency": "EUR",
    "created": "2020-11-20T13:35:06.3386658Z",
    "redirectUrls": {
        "returnUrl": "http://alternativepayments.com/message/success.html",
        "cancelUrl": "http://alternativepayments.com/message/failure.html"
    },
    "redirectUrl": "https://www.paygol.com/api/pay-direct/XXX-XXX-XXX",
    "ipAddress": "72.201.94.150"
}

PAYMENT OBJECT

Parameter Type Description Requirement
paymentOption string Efecty Mandatory
holder string Customer’s First and Last Name Mandatory
DocumentId string Customer’s Document Id Mandatory

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Customer’s First Name Mandatory
lastName string Customer’s Last Name Mandatory
email string Customer’s Email Mandatory
address string Customer’s address - Street Name Optional
address2 string Customer’s address - Street Number Optional
city string Customer’s city Optional
zip string Customer’s city Postal Code Optional
state string Customer’s state - 2 letter code Optional
country string Customer’s country - ISO1 country Code Mandatory
birthday date Customer’s birthday - MM/DD/YYYY Optional
phone string Customer’s phone Number Optional

Giropay

curl https://api.alternativepayments.com/api/transactions -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
  "customer": {
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "DE"
  },
  "payment": {
    "paymentOption": "giropay",
    "bic": "TESTDETT421",
    "holder": "John Doe"
  },
  "amount": 100,
  "currency": "EUR",
  "ipaddress": "123.01.1",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  }
}

$customer = new \AlternativePayments\Model\Customer();
$customer->setFirstName("John");
$customer->setLastName("Doe");
$customer->setEmail("john@doe.com");
$customer->setcountry("DE");

$payment = new \AlternativePayments\Model\Payment();
$payment->setpaymentOption("Giropay");
$payment->setHolder("John Doe");
$payment->setBIC("TESTDETT421");

$redirect = new \AlternativePayments\Model\RedirectUrls();
$redirect->setCancelUrl("http://alternativepayments.com/message/failure.html");
$redirect->setReturnUrl("http://alternativepayments.com/message/success.html");

$transaction = new \AlternativePayments\Model\Transaction();
$transaction->setCustomer($customer);
$transaction->setPayment($payment);
$transaction->setRedirectUrls($redirect);
$transaction->setAmount(100);
$transaction->setCurrency("EUR");
$transaction->setIpAddress($ipAddress);
$res = \AlternativePayments\Transaction :: post($transaction);
AlternativePayments.ApiUrl = _apiUrl;

var customer = new Customer();
customer.FirstName = "John";
customer.LastName = "Doe";
customer.Email = "john@doe.com";
customer.country = "DE";

var payment = new Payment();
payment.paymentOption = "giropay";
payment.Holder = customer.FirstName + " " + customer.LastName;
payment.bic = "TESTDETT421";

var redirect = new RedirectUrls();
redirect.CancelUrl = "http://alternativepayments.com/message/failure.html"

var transaction = new Transaction();
transaction.Customer = customer;
transaction.Payment = payment;
transaction.RedirectUrls = redirect;
transaction.Amount = 100;
transaction.Currency = "EUR";
customer = ApRubySdk::Customer.new(
        'firstName' => 'John',
        'lastName' => 'Doe',
        'email' => 'john@doe.com',
        'country' => 'DE'
    )

    payment = ApRubySdk::Payment.new(
        'paymentOption' => 'giropay',
        'holder' => 'John Doe',
        'bic' => 'TESTDETT421'

    )

    redirectUrls = ApRubySdk::RedirectUrls.new(
        'returnUrl' => 'http://alternativepayments.com/message/success.html',
        'cancelUrl' => 'http://alternativepayments.com/message/failure.html'
    )

    @transaction = ApRubySdk::Transaction.create(
        'customer' => customer,
        'payment' => payment,
        'amount' => 500,
        'currency' => 'EUR',
        'redirectUrls' => redirectUrls
    )
    customer = Customer(
        firstName='John',
        lastName='Doe',
        email='john@doe.com',
        country='DE'
    )

    payment = Payment(
        paymentOption='giropay',
        holder='John Doe',
        bic='TESTDETT421'
    )

    redirectUrls = RedirectUrls(
        returnUrl='http://alternativepayments.com/message/success.html',
        cancelUrl='http://alternativepayments.com/message/failure.html'
    )

    return Transaction.create({
        'customer': customer,
        'payment': payment,
        'amount': 500,
        'currency': 'EUR',
        'iPAddress': '123.01.1',
        'redirectUrls': redirectUrls
    })

The above command returns JSON structured like this:

{
  "id": "trn_2bbcd34688",
  "mode": "Test",
  "status": "Pending",
  "customer": {
    "id": "cus_b9c6a32127724ecea",
    "mode": "Test",
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "DE",
    "created": "2016-03-25T14:04:41.7643102Z"
  },
  "payment": {
    "id": "pay_f633ab65f86b4dac8",
    "mode": "Test",
    "paymentOption": "giropay",
    "holder": "John Doe",
    "bic": "TESTDETT421",
    "created": "2016-03-25T14:04:41.6863101Z"
  },
  "amount": 23,
  "currency": "EUR",
  "merchantPassThruData": "order_242444",
  "created": "2016-03-25T14:04:41.7643102Z",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  },
  "ipaddress": "123.01.1",
  "redirectUrl": "http://checkout.nts.com/direction.aspx?transaction_id=trn_2688"
}

PAYMENT OBJECT

Parameter Type Description Requirement
paymentOption string giropay Mandatory
holder string Customer’s First and Last Name Mandatory
BIC string Customer’s BIC Mandatory

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Customer’s First Name Mandatory
lastName string Customer’s Last Name Mandatory
email string Customer’s Email Mandatory
address string Customer’s address - Street Name Optional
address2 string Customer’s address - Street Number Optional
city string Customer’s city Optional
zip string Customer’s city Postal Code Optional
state string Customer’s state - 2 letter code Optional
country string Customer’s country - ISO1 country Code Mandatory
birthday date Customer’s birthday - MM/DD/YYYY Optional
phone string Customer’s phone Number Optional

iDEAL

curl https://api.alternativepayments.com/api/transactions -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
  "customer": {
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "NL"
  },
  "payment": {
    "paymentOption": "iDEAL",
    "holder": "John Doe"
  },
  "amount": 11, 
  "description": "Some description", // required
  "merchantTransactionId": "12345678", // required
  "currency": "EUR",
  "ipaddress": "123.01.01",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  }
}
$customer = new \AlternativePayments\Model\Customer();
$customer->setEmail("john@doe.com");
$customer->setcountry("BE");
$customer->setFirstName("John");
$customer->setLastName("Doe");

$payment = new \AlternativePayments\Model\Payment();
$payment->setpaymentOption("ideal");
$payment->setHolder("John Doe");

$redirect = new \AlternativePayments\Model\RedirectUrls();
$redirect->setReturnUrl("http://alternativepayments.com/message/success.html");
$redirect->setCancelUrl("http://alternativepayments.com/message/failure.html");

$transaction = new \AlternativePayments\Model\Transaction();
$transaction->setCustomer($customer);
$transaction->setPayment($payment);
$transaction->setRedirectUrls($redirect);
$transaction->setAmount(100);
$transaction->setDescription("Some description");
$transaction->setMerchantTransactionId("12345678");
$transaction->setCurrency("EUR");
$transaction->setIpAddress($ipAddress);
$res = Transaction :: post($transaction);
AlternativePayments.ApiUrl = _apiUrl;

var customer = new Customer();
customer.Email = "john@doe.com";
customer.FirstName = "John";
customer.LastName = "Doe";
customer.country = "NL";

var payment = new Payment();
payment.paymentOption = "ideal";
payment.Holder = customer.FirstName + " " + customer.LastName;

var redirect = new RedirectUrls();
redirect.ReturnUrl = "http://alternativepayments.com/message/success.html"
redirect.CancelUrl = "http://alternativepayments.com/message/failure.html"

var transaction = new Transaction();
transaction.Customer = customer;
transaction.Payment = payment;
transaction.RedirectUrls = redirect;
transaction.Amount = 250;
transaction.Description = "Some description";
transaction.MerchantTransactionId = "12345678";
transaction.Currency = "EUR";
transaction.Description = "Test transaction";
customer = ApRubySdk::Customer.new(
        'firstName' => 'John',
        'lastName' => 'Doe',
        'email' => 'john@doe.com',
        'country' => 'NL'
    )

    payment = ApRubySdk::Payment.new(
        'paymentOption' => 'ideal',
        'holder' => 'John Doe'
    )

    redirectUrls = ApRubySdk::RedirectUrls.new(
        'returnUrl' => 'http://alternativepayments.com/message/success.html',
        'cancelUrl' => 'http://alternativepayments.com/message/failure.html'
    )

    @transaction = ApRubySdk::Transaction.create(
        'customer' => customer,
        'payment' => payment,
        'amount' => 500,
        'description' => 'Some description',
        'merchantTransactionId' => '12345678',
        'currency' => 'EUR',
        'redirectUrls' => redirectUrls
    )
   customer = Customer(
        id='cus_bd838e3611d34d598',
        firstName='John',
        lastName='Doe',
        email='john@doe.com',
        country='NL'
    )

    payment = Payment(
        paymentOption='ideal',
        holder='John Doe'
    )

    redirectUrls = RedirectUrls(
        returnUrl='http://alternativepayments.com/message/success.html',
        cancelUrl='http://alternativepayments.com/message/failure.html'
    )

        return Transaction.create({
        'customer': customer,
        'payment': payment,
        'amount': 500,
        'description': 'Some description',
        'merchantTransactionId': '12345678',
        'currency': 'EUR',
        'iPAddress': '123.01.1',
        'redirectUrls': redirectUrls
    })

The above command returns JSON structured like this:

{
    "id": "trn_afecfa2bb05d43",
    "mode": "Live",
    "status": "Pending",
    "customer": {
        "id": "cus_dd01be8ba9554de09",
        "mode": "Live",
        "firstName": "John",
        "lastName": "Doe",
        "email": "john@doe.com",
        "country": "NL",
        "created": "2022-05-12T09:14:25.4679409Z"
    },
    "payment": {
        "id": "pay_365485d22e59414b8",
        "mode": "Live",
        "paymentOption": "iDEAL",
        "holder": "John Doe",
        "created": "2022-05-12T09:14:25.4055419Z",
        "ipAddress": "123.02.02"
    },
    "amount": 11.0,
    "currency": "EUR",
    "merchantTransactionId": "12345678",
    "description": "Some description",
    "created": "2022-05-12T09:14:25.4679409Z",
    "redirectUrls": {
        "returnUrl": "http://alternativepayments.com/message/success.html",
        "cancelUrl": "http://alternativepayments.com/message/failure.html"
    },
    "redirectUrl": "http://mybankingsite.com/hRedirection.aspx?transaction_id=trn_afecfa2bb05d43",
    "ipAddress": "123.01.01"
}

PAYMENT OBJECT

Parameter Type Description Requirement
paymentOption string ideal Mandatory
holder string Customer’s First and Last Name Mandatory

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Customer’s First Name Mandatory
lastName string Customer’s Last Name Mandatory
email string Customer’s Email Mandatory
address string Customer’s address - Street Name Optional
address2 string Customer’s address - Street Number Optional
city string Customer’s city Optional
zip string Customer’s city Postal Code Optional
state string Customer’s state - 2 letter code Optional
country string Customer’s country - ISO1 country Code Mandatory
birthday date Customer’s birthday - MM/DD/YYYY Optional
phone string Customer’s phone Number Optional

ATTRIBUTES

Parameter Type Description Requirement
description string Description Mandatory
merchantTransactionId string The unique identifier for a payment provided by the merchant Mandatory

Itau

curl https://api.alternativepayments.com/api/transactions -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
    "customer": {
        "firstName": "John",
        "lastName": "Doe",
        "email": "john@doe.com",
        "country": "BR",
        "phone": "+5500147258369"
    },
    "currency": "EUR",
    "amount": 313,
    "ipaddress": "72.201.94.150",
    "payment": {
        "holder": "John Doe",
        "paymentOption": "itau",
        "DocumentId": "XXX.XXX.XXX"
    },
    "redirectUrls": {
        "returnUrl": "http://alternativepayments.com/message/success.html",
        "cancelUrl": "http://alternativepayments.com/message/failure.html"
    }
}

The above command returns JSON structured like this:

{
    "id": "trn_a9cf2fb609434e",
    "mode": "Live",
    "status": "Pending",
    "customer": {
        "id": "cus_a6b47e15f17a4c0b9",
        "mode": "Live",
        "firstName": "John",
        "lastName": "Doe",
        "email": "john@doe.com",
        "country": "BR",
        "created": "2020-11-20T13:35:06.3542905Z",
        "phone": "+5500147258369"
    },
    "payment": {
        "id": "pay_6b7036d90e3a449da",
        "mode": "Live",
        "paymentOption": "itau",
        "holder": "John Doe",
        "created": "2020-11-20T13:35:06.2605426Z",
        "ipAddress": "72.201.94.150"
    },
    "amount": 313.0,
    "currency": "EUR",
    "created": "2020-11-20T13:35:06.3386658Z",
    "redirectUrls": {
        "returnUrl": "http://alternativepayments.com/message/success.html",
        "cancelUrl": "http://alternativepayments.com/message/failure.html"
    },
    "redirectUrl": "https://www.paygol.com/api/pay-direct/XXX-XXX-XXX",
    "ipAddress": "72.201.94.150"
}

PAYMENT OBJECT

Parameter Type Description Requirement
paymentOption string itau Mandatory
holder string Customer’s First and Last Name Mandatory
DocumentId string Customer’s Document Id Mandatory

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Customer’s First Name Mandatory
lastName string Customer’s Last Name Mandatory
email string Customer’s Email Mandatory
address string Customer’s address - Street Name Optional
address2 string Customer’s address - Street Number Optional
city string Customer’s city Optional
zip string Customer’s city Postal Code Optional
state string Customer’s state - 2 letter code Optional
country string Customer’s country - ISO1 country Code Mandatory
birthday date Customer’s birthday - MM/DD/YYYY Optional
phone string Customer’s phone Number Optional

Multicaja

curl https://api.alternativepayments.com/api/transactions -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
    "customer": {
        "firstName": "John",
        "lastName": "Doe",
        "email": "john@doe.com",
        "country": "CL"
    },
    "currency": "EUR",
    "amount": 313,
    "ipaddress": "72.201.94.150",
    "payment": {
        "holder": "John Doe",
        "paymentOption": "multicaja",
        "DocumentId": "XXX.XXX.XXX"
    },
    "redirectUrls": {
        "returnUrl": "http://alternativepayments.com/message/success.html",
        "cancelUrl": "http://alternativepayments.com/message/failure.html"
    }
}

The above command returns JSON structured like this:

{
    "id": "trn_a9cf2fb609434e",
    "mode": "Live",
    "status": "Pending",
    "customer": {
        "id": "cus_a6b47e15f17a4c0b9",
        "mode": "Live",
        "firstName": "John",
        "lastName": "Doe",
        "email": "john@doe.com",
        "country": "CL",
        "created": "2020-11-20T13:35:06.3542905Z"
    },
    "payment": {
        "id": "pay_6b7036d90e3a449da",
        "mode": "Live",
        "paymentOption": "multicaja",
        "holder": "John Doe",
        "created": "2020-11-20T13:35:06.2605426Z",
        "ipAddress": "72.201.94.150"
    },
    "amount": 313.0,
    "currency": "EUR",
    "created": "2020-11-20T13:35:06.3386658Z",
    "redirectUrls": {
        "returnUrl": "http://alternativepayments.com/message/success.html",
        "cancelUrl": "http://alternativepayments.com/message/failure.html"
    },
    "redirectUrl": "https://www.paygol.com/api/pay-direct/XXX-XXX-XXX",
    "ipAddress": "72.201.94.150"
}

PAYMENT OBJECT

Parameter Type Description Requirement
paymentOption string multicaja Mandatory
holder string Customer’s First and Last Name Mandatory
DocumentId string Customer’s Document Id Mandatory

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Customer’s First Name Mandatory
lastName string Customer’s Last Name Mandatory
email string Customer’s Email Mandatory
address string Customer’s address - Street Name Optional
address2 string Customer’s address - Street Number Optional
city string Customer’s city Optional
zip string Customer’s city Postal Code Optional
state string Customer’s state - 2 letter code Optional
country string Customer’s country - ISO1 country Code Mandatory
birthday date Customer’s birthday - MM/DD/YYYY Optional
phone string Customer’s phone Number Optional

MyBank

curl https://api.alternativepayments.com/api/transactions -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
  "customer": {
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "IT"
  },
  "payment": {
    "paymentOption": "mybank",
    "holder": "John Doe",
  },
  "amount": 100,
  "currency": "EUR",
  "ipaddress": "123.01.1",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  }
}
{
  "id": "trn_2bbcd34628",
  "mode": "Test",
  "status": "Pending",
  "customer": {
    "id": "cus_b9c6a32127724ffea",
    "mode": "Test",
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "IT",
    "created": "2016-03-25T14:04:41.7643102Z"
  },
  "payment": {
    "id": "pay_f633ab65f86b4dac8",
    "mode": "Test",
    "paymentOption": "MyBank",
    "holder": "John Doe",
    "created": "2016-03-25T14:04:41.6863101Z"
  },
  "amount": 100,
  "currency": "EUR",
  "created": "2016-03-25T14:04:41.7643102Z",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  },
  "ipaddress": "123.01.1",
  "redirectUrl": "http://checkout.nts.com/direction.aspx?transaction_id=trn_2688"
}
{
  "id": "trn_2bbcd34628",
  "mode": "Test",
  "status": "Pending",
  "customer": {
    "id": "cus_b9c6a32127724ffea",
    "mode": "Test",
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "IT",
    "created": "2016-03-25T14:04:41.7643102Z"
  },
  "payment": {
    "id": "pay_f633ab65f86b4dac8",
    "mode": "Test",
    "paymentOption": "MyBank",
    "holder": "John Doe",
    "created": "2016-03-25T14:04:41.6863101Z"
  },
  "amount": 100,
  "currency": "EUR",
  "created": "2016-03-25T14:04:41.7643102Z",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  },
  "ipaddress": "123.01.1",
  "redirectUrl": "http://checkout.nts.com/direction.aspx?transaction_id=trn_2688"
}
{
  "id": "trn_2bbcd34628",
  "mode": "Test",
  "status": "Pending",
  "customer": {
    "id": "cus_b9c6a32127724ffea",
    "mode": "Test",
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "IT",
    "created": "2016-03-25T14:04:41.7643102Z"
  },
  "payment": {
    "id": "pay_f633ab65f86b4dac8",
    "mode": "Test",
    "paymentOption": "MyBank",
    "holder": "John Doe",
    "created": "2016-03-25T14:04:41.6863101Z"
  },
  "amount": 100,
  "currency": "EUR",
  "created": "2016-03-25T14:04:41.7643102Z",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  },
  "ipaddress": "123.01.1",
  "redirectUrl": "http://checkout.nts.com/direction.aspx?transaction_id=trn_2688"
}
{
  "id": "trn_2bbcd34628",
  "mode": "Test",
  "status": "Pending",
  "customer": {
    "id": "cus_b9c6a32127724ffea",
    "mode": "Test",
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "IT",
    "created": "2016-03-25T14:04:41.7643102Z"
  },
  "payment": {
    "id": "pay_f633ab65f86b4dac8",
    "mode": "Test",
    "paymentOption": "MyBank",
    "holder": "John Doe",
    "created": "2016-03-25T14:04:41.6863101Z"
  },
  "amount": 100,
  "currency": "EUR",
  "created": "2016-03-25T14:04:41.7643102Z",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  },
  "ipaddress": "123.01.1",
  "redirectUrl": "http://checkout.nts.com/direction.aspx?transaction_id=trn_2688"
}

The above command returns JSON structured like this:

{
  "id": "trn_2bbcd34628",
  "mode": "Test",
  "status": "Pending",
  "customer": {
    "id": "cus_b9c6a32127724ffea",
    "mode": "Test",
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "IT",
    "created": "2016-03-25T14:04:41.7643102Z"
  },
  "payment": {
    "id": "pay_f633ab65f86b4dac8",
    "mode": "Test",
    "paymentOption": "MyBank",
    "holder": "John Doe",
    "created": "2016-03-25T14:04:41.6863101Z"
  },
  "amount": 100,
  "currency": "EUR",
  "created": "2016-03-25T14:04:41.7643102Z",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  },
  "ipaddress": "123.01.1",
  "redirectUrl": "http://checkout.nts.com/direction.aspx?transaction_id=trn_2688"
}

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Customer’s First Name Mandatory
lastName string Customer’s Last Name Mandatory
email string Customer’s Email Mandatory
address string Customer’s address - Street Name Optional
address2 string Customer’s address - Street Number Optional
city string Customer’s city Optional
zip string Customer’s city Postal Code Optional
state string Customer’s state - 2 letter code Optional
country string Customer’s country - ISO1 country Code Mandatory
birthDate date Customer’s birthday - MM/DD/YYYY Optional
phone string Customer’s phone Number Optional

PAYMENT OBJECT

Parameter Type Description Requirement
paymentOption string mybank Mandatory
holder string Customer’s First and Last Name Mandatory

Oxxo

curl https://api.alternativepayments.com/api/transactions -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
    "customer": {
        "firstName": "John",
        "lastName": "Doe",
        "email": "John@Doe.com",
        "country": "MX"
    },
    "payment": {
        "paymentOption": "oxxo",
        "holder": "John Doe",
        "DocumentId": "XXX.XXXX.XXX"
    },
    "redirectUrls": {
        "returnUrl": "http://alternativepayments.com/message/success.html",
        "cancelUrl": "http://alternativepayments.com/message/failure.html"
    },
    "amount": 135,
    "currency": "EUR",
    "ipaddress": "72.201.94.150"
}

The above command returns JSON structured like this:

{
    "id": "trn_a9cf2fb609434e",
    "mode": "Live",
    "status": "Pending",
    "customer": {
        "id": "cus_a6b47e15f17a4c0b9",
        "mode": "Live",
        "firstName": "John",
        "lastName": "Doe",
        "email": "john@doe.com",
        "country": "MX",
        "created": "2020-11-20T13:35:06.3542905Z"
    },
    "payment": {
        "id": "pay_6b7036d90e3a449da",
        "mode": "Live",
        "paymentOption": "oxxo",
        "holder": "John Doe",
        "created": "2020-11-20T13:35:06.2605426Z",
        "ipAddress": "72.201.94.150"
    },
    "amount": 135.0,
    "currency": "EUR",
    "created": "2020-11-20T13:35:06.3386658Z",
    "redirectUrls": {
        "returnUrl": "http://alternativepayments.com/message/success.html",
        "cancelUrl": "http://alternativepayments.com/message/failure.html"
    },
    "redirectUrl": "https://www.paygol.com/api/pay-direct/XXX-XXX-XXX",
    "ipAddress": "72.201.94.150"
}

PAYMENT OBJECT

Parameter Type Description Requirement
paymentOption string oxxo Mandatory
holder string Customer’s First and Last Name Mandatory
DocumentId string Customer’s Document Id Mandatory

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Customer’s First Name Mandatory
lastName string Customer’s Last Name Mandatory
email string Customer’s Email Mandatory
address string Customer’s address - Street Name Optional
address2 string Customer’s address - Street Number Optional
city string Customer’s city Optional
zip string Customer’s city Postal Code Optional
state string Customer’s state - 2 letter code Optional
country string Customer’s country - ISO1 country Code Mandatory
birthday date Customer’s birthday - MM/DD/YYYY Optional
phone string Customer’s phone Number Optional

PagoEfectivo

curl https://api.alternativepayments.com/api/transactions -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
    "customer": {
        "firstName": "John",
        "lastName": "Doe",
        "email": "john@doe.com",
        "country": "PE",
        "phone": "+5500147258369"
    },
    "currency": "EUR",
    "amount": 313,
    "ipaddress": "72.201.94.150",
    "payment": {
        "holder": "John Doe",
        "paymentOption": "PagoEfectivo",
        "DocumentId": "XXX.XXX.XXX"
    },
    "redirectUrls": {
        "returnUrl": "http://alternativepayments.com/message/success.html",
        "cancelUrl": "http://alternativepayments.com/message/failure.html"
    }
}

The above command returns JSON structured like this:

{
    "id": "trn_a9cf2fb609434e",
    "mode": "Live",
    "status": "Pending",
    "customer": {
        "id": "cus_a6b47e15f17a4c0b9",
        "mode": "Live",
        "firstName": "John",
        "lastName": "Doe",
        "email": "john@doe.com",
        "country": "PE",
        "phone": "+5500147258369",
        "created": "2020-11-20T13:35:06.3542905Z"
    },
    "payment": {
        "id": "pay_6b7036d90e3a449da",
        "mode": "Live",
        "paymentOption": "PagoEfectivo",
        "holder": "John Doe",
        "created": "2020-11-20T13:35:06.2605426Z",
        "ipAddress": "72.201.94.150"
    },
    "amount": 313.0,
    "currency": "EUR",
    "created": "2020-11-20T13:35:06.3386658Z",
    "redirectUrls": {
        "returnUrl": "http://alternativepayments.com/message/success.html",
        "cancelUrl": "http://alternativepayments.com/message/failure.html"
    },
    "redirectUrl": "https://www.paygol.com/api/pay-direct/XXX-XXX-XXX",
    "ipAddress": "72.201.94.150"
}

PAYMENT OBJECT

Parameter Type Description Requirement
paymentOption string multicaja Mandatory
holder string Customer’s First and Last Name Mandatory
DocumentId string Customer’s Document Id Mandatory

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Customer’s First Name Mandatory
lastName string Customer’s Last Name Mandatory
email string Customer’s Email Mandatory
address string Customer’s address - Street Name Optional
address2 string Customer’s address - Street Number Optional
city string Customer’s city Optional
zip string Customer’s city Postal Code Optional
state string Customer’s state - 2 letter code Optional
country string Customer’s country - ISO1 country Code Mandatory
birthday date Customer’s birthday - MM/DD/YYYY Optional
phone string Customer’s phone Number Optional

Pago Facil

curl https://api.alternativepayments.com/api/transactions -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
    "customer": {
        "firstName": "John",
        "lastName": "Doe",
        "email": "john@doe.com",
        "country": "AR"
    },
    "currency": "EUR",
    "amount": 1299,
    "ipaddress": "72.201.94.150",
    "payment": {
        "holder": "John Doe",
        "paymentOption": "pagofacil",
        "DocumentId": "XXX.XXX.XXX"
    },
    "redirectUrls": {
        "returnUrl": "http://alternativepayments.com/message/success.html",
        "cancelUrl": "http://alternativepayments.com/message/failure.html"
    }
}

The above command returns JSON structured like this:

{
    "id": "trn_7707655ea34b4a",
    "mode": "Live",
    "status": "Pending",
    "customer": {
        "id": "cus_7aaad98e5b214ee68",
        "mode": "Live",
        "firstName": "John",
        "lastName": "Doe",
        "email": "john@doe.com",
        "country": "AR",
        "created": "2020-11-23T13:15:58.6751618Z"
    },
    "payment": {
        "id": "pay_4f59691e7cc348e59",
        "mode": "Live",
        "paymentOption": "pagofacil",
        "holder": "John Doe",
        "created": "2020-11-23T13:15:58.6439125Z",
        "ipAddress": "72.201.94.150"
    },
    "amount": 1299,
    "currency": "EUR",
    "created": "2020-11-23T13:15:58.6595367Z",
    "redirectUrls": {
        "returnUrl": "http://alternativepayments.com/message/success.html",
        "cancelUrl": "http://alternativepayments.com/message/failure.html"
    },
    "redirectUrl": "https://www.paygol.com/api/pay-direct/XXX-XXX-XXX",
    "ipAddress": "72.201.94.150"
}

PAYMENT OBJECT

Parameter Type Description Requirement
paymentOption string pagofacil Mandatory
holder string Customer’s First and Last Name Mandatory
DocumentId string Customer’s Document Id Mandatory

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Customer’s First Name Mandatory
lastName string Customer’s Last Name Mandatory
email string Customer’s Email Mandatory
address string Customer’s address - Street Name Optional
address2 string Customer’s address - Street Number Optional
city string Customer’s city Optional
zip string Customer’s city Postal Code Optional
state string Customer’s state - 2 letter code Optional
country string Customer’s country - ISO1 country Code Mandatory
birthday date Customer’s birthday - MM/DD/YYYY Optional
phone string Customer’s phone Number Optional

PaySafe Card

curl https://api.alternativepayments.com/api/transactions -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
  "customer": {
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "DE"
  },
  "payment": {
    "paymentOption": "paysafe",
    "holder": "John Doe"
  },
  "amount": 100,
  "currency": "EUR",
  "ipaddress": "123.01.1",
  "redirectUrls": {
    "ReturnUrl":"http://alternativepayments.com/message/success.html",
    "CancelUrl":"http://alternativepayments.com/message/failure.html"
  }
}

The above command returns JSON structured like this:

{
  "id": "trn_2bbcd34628",
  "mode": "Test",
  "status": "Pending",
  "customer": {
    "id": "cus_b9c6a32127724ffea",
    "mode": "Test",
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "DE",
    "created": "2016-03-25T14:04:41.7643102Z"
  },
  "payment": {
    "id": "pay_f633ab65f86b4dac8",
    "mode": "Test",
    "paymentOption": "paysafe",
    "holder": "John Doe",
    "created": "2016-03-25T14:04:41.6863101Z"
  },
  "amount": 100,
  "currency": "EUR",
  "created": "2016-03-25T14:04:41.7643102Z",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  },
  "ipaddress": "123.01.1",
  "redirectUrl": "http://checkout.nts.com/direction.aspx?transaction_id=trn_2688"
}

PAYMENT OBJECT

Parameter Type Description Requirement
paymentOption string paysafe Mandatory
holder string Customer’s First and Last Name Mandatory

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Customer’s First Name Mandatory
lastName string Customer’s Last Name Mandatory
email string Customer’s Email Mandatory
address string Customer’s address - Street Name Optional
address2 string Customer’s address - Street Number Optional
city string Customer’s city Optional
zip string Customer’s city Postal Code Optional
state string Customer’s state - 2 letter code Optional
country string Customer’s country - ISO1 country Code Mandatory
birthday date Customer’s birthday - MM/DD/YYYY Optional
phone string Customer’s phone Number Optional

Pix

curl https://api.alternativepayments.com/api/transactions -u \
<WEBSITE_SECRET_KEY>
    :  -H "Content-Type:application/json" -X POST -d '
{
  "customer": {
    "firstName": "Roberto",
    "lastName": "Doe",
    "email": "Roberto@Doe.com",
    "country": "BR"
  },
  "payment": {
    "paymentOption": "pix",
    "holder": "RobertoDoe",
    "documentId": "014.423.868-35"
  },
  "amount": 100,
  "currency": "BRL",
  "description": "Purchase details", 
  "merchantTransactionId": "12345678", 
  "ipaddress": "123.01.1",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  }
}

$customer = new \AlternativePayments\Model\Customer();
$customer->setFirstName("Roberto");
$customer->setLastName("Doe");
$customer->setEmail("Roberto@Doe.com");
$customer->setcountry("BR");


$payment = new \AlternativePayments\Model\Payment();
$payment->setpaymentOption("pix");
$payment->setHolder("Roberto Doe");
$payment->setDocumentId("014.423.868-35");

$transaction = new \AlternativePayments\Model\Transaction();
$transaction->setCustomer($customer);
$transaction->setPayment($payment);
$transaction->setAmount(100);
$transaction->setCurrency("BRL");
$transaction->setDescription("Purchase details");
$transaction->setMerchantTransactionId("12345678");
$transaction->setIpAddress($ipAddress);
$res = Transaction :: post($transaction);
AlternativePayments.ApiUrl = _apiUrl;

var customer = new Customer();
customer.FirstName = "Roberto";
customer.LastName = "Doe";
customer.Email = "Roberto@Doe.com";
customer.country = "BR";

var payment = new Payment();
payment.paymentOption = "pix";
payment.Holder = customer.FirstName + " " + customer.LastName;
payment.DocumentId = "014.423.868-35";

var transaction = new Transaction();
transaction.Customer = customer;
transaction.Payment = payment;
transaction.Amount = 100;
transaction.Currency = "BRL";
transaction.MerchantTransactionId = "12345678";
transaction.Description = "Purchase details";

customer = ApRubySdk::Customer.new(
        'firstName' => 'Roberto',
        'lastName' => 'Doe',
        'email' => 'robero@doe.com',
        'country' => 'BR'
    )

    payment = ApRubySdk::Payment.new(
        'paymentOption' => 'pix',
        'holder' => 'Roberto Doe',
        'documentId' => '014.423.868-35'
    )

    redirectUrls = ApRubySdk::RedirectUrls.new(
        'returnUrl' => 'http://alternativepayments.com/message/success.html',
        'cancelUrl' => 'http://alternativepayments.com/message/failure.html'
    )

    @transaction = ApRubySdk::Transaction.create(
        'customer' => customer,
        'payment' => payment,
        'amount' => 4500,
        'currency' => 'EUR',
        'merchantTransactionId' => '12345678',
        'description' => 'Purchase details',
        'redirectUrls' => redirectUrls
    )
    customer = Customer(
        firstName='Roberto',
        lastName='Doe',
        email='roberto@doe.com',
        country='BR'
    )

    payment = Payment(
        paymentOption='pix',
        holder='Roberto Doe',
        documentId='014.423.868-35'
    )

    redirectUrls = RedirectUrls(
        returnUrl='http://alternativepayments.com/message/success.html',
        cancelUrl='http://alternativepayments.com/message/failure.html'
    )

    return Transaction.create({
        'customer': customer,
        'payment': payment,
        'amount': 4500,
        'currency': 'EUR',
        'merchantTransactionId': '12345678',
        'description': 'Purchase details',
        'iPAddress': '123.01.1',
        'redirectUrls': redirectUrls
    })

The above command returns JSON structured like this:

    {
  "id": "trn_43baf0cf75",
  "mode": "Test",
  "status": "Pending",
  "customer": {
    "id": "cus_cacc9d89ee674e44b",
    "mode": "Test",
    "firstName": "Roberto",
    "lastName": "Doe",
    "email": "roberto@doe.com",
    "country": "BR",
    "created": "2024-03-25T14:00:38.0421808Z"
  },
  "payment": {
    "id": "pay_abcaa1351f5c45fe8",
    "mode": "Test",
    "paymentOption": "pix",
    "holder": "Roberto Doe",
    "created": "2024-03-25T14:00:37.9641807Z",
    "documentId": "014.423.868-35"
  },
  "amount": 100,
  "currency": "BRL",
  "merchantTransactionId": "12345678",
  "created": "2024-03-25T14:00:38.0421808Z",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  },
  "ipaddress": "123.01.1",
  "redirectUrl": "https://sandbox.url.com/print/?hash=56f1bbf021c8a40"
}

PAYMENT OBJECT

Parameter Type Description Requirement
paymentOption string pix Mandatory
holder string Customer’s First and Last Name Mandatory
DocumentId string Customer’s Document Id Mandatory

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Customer’s First Name Mandatory
lastName string Customer’s Last Name Mandatory
email string Customer’s Email Mandatory
country string Customer’s country - ISO1 country Code Mandatory

POLi

curl https://api.alternativepayments.com/api/transactions -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
  "customer": {
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "AU"
  },
  "payment": {
    "paymentOption": "poli",
    "holder": "John Doe",
  },
  "amount": 100,
  "currency": "EUR",
  "ipaddress": "123.01.1",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  }
}
$customer = new \AlternativePayments\Model\Customer();
$customer->setEmail("john@doe.com");
$customer->setcountry("AU");
$customer->setFirstName("John");
$customer->setLastName("Doe");

$payment = new \AlternativePayments\Model\Payment();
$payment->setpaymentOption("poli");
$payment->setHolder("John Doe");

$redirect = new \AlternativePayments\Model\RedirectUrls();
$redirect->setReturnUrl("http://alternativepayments.com/message/success.html");
$redirect->setCancelUrl("http://alternativepayments.com/message/failure.html");

$transaction = new \AlternativePayments\Model\Transaction();
$transaction->setCustomer($customer);
$transaction->setPayment($payment);
$transaction->setRedirectUrls($redirect);
$transaction->setAmount(100);
$transaction->setCurrency("EUR");
$transaction->setIpAddress($ipAddress);
$res = Transaction :: post($transaction);
AlternativePayments.ApiUrl = _apiUrl;

var customer = new Customer();
customer.Email = "john@doe.com";
customer.FirstName = "John";
customer.LastName = "Doe";
customer.country = "AU";

var payment = new Payment();
payment.paymentOption = "poli";
payment.Holder = customer.FirstName + " " + customer.LastName;

var redirect = new RedirectUrls();
redirect.ReturnUrl = "http://alternativepayments.com/message/success.html"
redirect.CancelUrl = "http://alternativepayments.com/message/failure.html"

var transaction = new Transaction();
transaction.Customer = customer;
transaction.Payment = payment;
transaction.RedirectUrls = redirect;
transaction.Amount = 250;
transaction.Currency = "EUR";
transaction.Description = "Test transaction";

The above command returns JSON structured like this:

 customer = ApRubySdk::Customer.new(
        'firstName' => 'John',
        'lastName' => 'Doe',
        'email' => 'john@doe.com',
        'country' => 'AU'
    )

    payment = ApRubySdk::Payment.new(
        'paymentOption' => 'poli',
        'holder' => 'John Doe'
    )

    redirectUrls = ApRubySdk::RedirectUrls.new(
        'returnUrl' => 'http://alternativepayments.com/message/success.html',
        'cancelUrl' => 'http://alternativepayments.com/message/failure.html'
    )

    @transaction = ApRubySdk::Transaction.create(
        'customer' => customer,
        'payment' => payment,
        'amount' => 500,
        'currency' => 'EUR',
        'redirectUrls' => redirectUrls
    )
   customer = Customer(
        id='cus_bd838e3611d34d598',
        firstName='John',
        lastName='Doe',
        email='john@doe.com',
        country='AU'
    )

    payment = Payment(
        paymentOption='poli',
        holder='John Doe'
    )

    redirectUrls = RedirectUrls(
        returnUrl='http://alternativepayments.com/message/success.html',
        cancelUrl='http://alternativepayments.com/message/failure.html'
    )

    return Transaction.create({
        'customer': customer,
        'payment': payment,
        'amount': 500,
        'currency': 'EUR',
        'iPAddress': '123.01.1',
        'redirectUrls': redirectUrls
    })

The above command returns JSON structured like this:

{
  "id": "trn_1a5f5e0c97",
  "mode": "Test",
  "status": "Pending",
  "customer": {
    "id": "cus_bf682a6c051145a09",
    "mode": "Test",
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "AU",
    "created": "2016-03-25T13:51:04.8497785Z"
  },
  "payment": {
    "id": "pay_ffd25121f84e4d249",
    "mode": "Test",
    "paymentOption": "poli",
    "holder": "Piet Saar",
    "created": "2016-03-25T13:51:04.7717784Z"
  },
  "amount": 1700,
  "currency": "EUR",
  "merchantPassThruData": "Order #1234958",
  "created": "2016-03-25T13:51:04.8497785Z",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  },
  "ipaddress": "123.01.1",
  "redirectUrl": "http://mybankingsite.com/hRedirection.aspx?transaction_id=trn_1a5f5e0c97"
}

PAYMENT OBJECT

Parameter Type Description Requirement
paymentOption string poli Mandatory
holder string Customer’s First and Last Name Mandatory

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Customer’s First Name Mandatory
lastName string Customer’s Last Name Mandatory
email string Customer’s Email Mandatory
address string Customer’s address - Street Name Optional
address2 string Customer’s address - Street Number Optional
city string Customer’s city Optional
zip string Customer’s city Postal Code Optional
state string Customer’s state - 2 letter code Optional
country string Customer’s country - ISO1 country Code Mandatory
birthday date Customer’s birthday - MM/DD/YYYY Optional
phone string Customer’s phone Number Optional

Przelewy24

curl https://api.alternativepayments.com/api/transactions -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
  "customer": {
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "PL"
  },
  "payment": {
    "paymentOption": "przelewy24",
    "holder": "John Doe",
  },
  "amount": 100,
  "currency": "EUR",
  "ipaddress": "123.01.1",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  }
}
$customer = new \AlternativePayments\Model\Customer();
$customer->setEmail("john@doe.com");
$customer->setcountry("PL");
$customer->setFirstName("John");
$customer->setLastName("Doe");

$payment = new \AlternativePayments\Model\Payment();
$payment->setpaymentOption("przelewy24");
$payment->setHolder("John Doe");

$redirect = new \AlternativePayments\Model\RedirectUrls();
$redirect->setReturnUrl("http://alternativepayments.com/message/success.html");
$redirect->setCancelUrl("http://alternativepayments.com/message/failure.html");

$transaction = new \AlternativePayments\Model\Transaction();
$transaction->setCustomer($customer);
$transaction->setPayment($payment);
$transaction->setRedirectUrls($redirect);
$transaction->setAmount(100);
$transaction->setCurrency("EUR");
$transaction->setIpAddress($ipAddress);
$res = Transaction :: post($transaction);
AlternativePayments.ApiUrl = _apiUrl;

var customer = new Customer();
customer.Email = "john@doe.com";
customer.FirstName = "John";
customer.LastName = "Doe";
customer.country = "PL";

var payment = new Payment();
payment.paymentOption = "przelewy24";
payment.Holder = customer.FirstName + " " + customer.LastName;

var redirect = new RedirectUrls();
redirect.ReturnUrl = "http://alternativepayments.com/message/success.html"
redirect.CancelUrl = "http://alternativepayments.com/message/failure.html"

var transaction = new Transaction();
transaction.Customer = customer;
transaction.Payment = payment;
transaction.RedirectUrls = redirect;
transaction.Amount = 250;
transaction.Currency = "EUR";
transaction.Description = "Test transaction";

The above command returns JSON structured like this:

 customer = ApRubySdk::Customer.new(
        'firstName' => 'John',
        'lastName' => 'Doe',
        'email' => 'john@doe.com',
        'country' => 'PL'
    )

    payment = ApRubySdk::Payment.new(
        'paymentOption' => 'przelewy24',
        'holder' => 'John Doe'
    )

    redirectUrls = ApRubySdk::RedirectUrls.new(
        'returnUrl' => 'http://alternativepayments.com/message/success.html',
        'cancelUrl' => 'http://alternativepayments.com/message/failure.html'
    )

    @transaction = ApRubySdk::Transaction.create(
        'customer' => customer,
        'payment' => payment,
        'amount' => 500,
        'currency' => 'EUR',
        'redirectUrls' => redirectUrls
    )
   customer = Customer(
        id='cus_bd838e3611d34d598',
        firstName='John',
        lastName='Doe',
        email='john@doe.com',
        country='PL'
    )

    payment = Payment(
        paymentOption='przelewy24',
        holder='John Doe'
    )

    redirectUrls = RedirectUrls(
        returnUrl='http://alternativepayments.com/message/success.html',
        cancelUrl='http://alternativepayments.com/message/failure.html'
    )

    return Transaction.create({
        'customer': customer,
        'payment': payment,
        'amount': 500,
        'currency': 'EUR',
        'iPAddress': '123.01.1',
        'redirectUrls': redirectUrls
    })

The above command returns JSON structured like this:

{
  "id": "trn_1a5f5e0c97",
  "mode": "Test",
  "status": "Pending",
  "customer": {
    "id": "cus_bf682a6c051145a09",
    "mode": "Test",
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "PL",
    "created": "2016-03-25T13:51:04.8497785Z"
  },
  "payment": {
    "id": "pay_ffd25121f84e4d249",
    "mode": "Test",
    "paymentOption": "przelewy24",
    "holder": "Piet Saar",
    "created": "2016-03-25T13:51:04.7717784Z"
  },
  "amount": 1700,
  "currency": "EUR",
  "merchantPassThruData": "Order #1234958",
  "created": "2016-03-25T13:51:04.8497785Z",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  },
  "ipaddress": "123.01.1",
  "redirectUrl": "http://mybankingsite.com/hRedirection.aspx?transaction_id=trn_1a5f5e0c97"
}

PAYMENT OBJECT

Parameter Type Description Requirement
paymentOption string przelewy24 Mandatory
holder string Customer’s First and Last Name Mandatory

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Customer’s First Name Mandatory
lastName string Customer’s Last Name Mandatory
email string Customer’s Email Mandatory
address string Customer’s address - Street Name Optional
address2 string Customer’s address - Street Number Optional
city string Customer’s city Optional
zip string Customer’s city Postal Code Optional
state string Customer’s state - 2 letter code Optional
country string Customer’s country - ISO1 country Code Mandatory
birthday date Customer’s birthday - MM/DD/YYYY Optional
phone string Customer’s phone Number Optional

QIWI

curl https://api.alternativepayments.com/api/transactions -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
  "customer": {
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "RU",
    "phone":"+7855555555555"
  },
  "payment": {
    "paymentOption": "qiwi",
    "holder": "John Doe"
  },
  "amount": 15000,
  "currency": "RUB",
  "ipaddress": "123.01.1",
  "redirectUrls": {
    "ReturnUrl":"http://alternativepayments.com/message/success.html",
    "CancelUrl":"http://alternativepayments.com/message/failure.html"
  }
}

The above command returns JSON structured like this:

{
  "id": "trn_2bbcd34648",
  "mode": "Test",
  "status": "Pending",
  "customer": {
    "id": "cus_b9c6a32127724ffea",
    "mode": "Test",
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "RU",
    "phone":"+7855555555555",
    "created": "2016-03-25T14:04:41.7643102Z"
  },
  "payment": {
    "id": "pay_f633ab65f86b4dac8",
    "mode": "Test",
    "paymentOption": "qiwi",
    "holder": "John Doe",
    "created": "2016-03-25T14:04:41.6863101Z"
  },
  "amount": 15000,
  "currency": "RUB",
  "created": "2016-03-25T14:04:41.7643102Z",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  },
  "ipaddress": "123.01.1",
  "redirectUrl": "http://checkout.nts.com/direction.aspx?transaction_id=trn_2688"
}

PAYMENT OBJECT

Parameter Type Description Requirement
paymentOption string qiwi Mandatory
holder string Customer’s First and Last Name Mandatory

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Customer’s First Name Mandatory
lastName string Customer’s Last Name Mandatory
email string Customer’s Email Mandatory
country string Customer’s country - ISO1 country Code Mandatory
phone string Customer’s phone Number Mandatory

Rapipago

curl https://api.alternativepayments.com/api/transactions -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
    "customer": {
        "firstName": "John",
        "lastName": "Doe",
        "email": "john@doe.com",
        "country": "AR"
    },
    "currency": "EUR",
    "amount": 1299,
    "ipaddress": "72.201.94.150",
    "payment": {
        "holder": "John Doe",
        "paymentOption": "Rapipago",
        "DocumentId": "XXX.XXX.XXX"
    },
    "redirectUrls": {
        "returnUrl": "http://alternativepayments.com/message/success.html",
        "cancelUrl": "http://alternativepayments.com/message/failure.html"
    }
}

The above command returns JSON structured like this:

{
    "id": "trn_948d2876f1d746",
    "mode": "Live",
    "status": "Pending",
    "customer": {
        "id": "cus_e086bd1ea4b247348",
        "mode": "Live",
        "firstName": "John",
        "lastName": "Doe",
        "email": "john@doe.com",
        "country": "AR",
        "created": "2020-11-23T13:09:46.2216104Z"
    },
    "payment": {
        "id": "pay_cf5c9e98c7b641979",
        "mode": "Live",
        "paymentOption": "rapipago",
        "holder": "John Doe",
        "created": "2020-11-23T13:09:46.2059846Z",
        "ipAddress": "72.201.94.150"
    },
    "amount": 1299,
    "currency": "EUR",
    "created": "2020-11-23T13:09:46.2216104Z",
    "redirectUrls": {
        "returnUrl": "http://alternativepayments.com/message/success.html",
        "cancelUrl": "http://alternativepayments.com/message/failure.html"
    },
    "redirectUrl": "https://www.paygol.com/api/pay-direct/XXX-XXX-XXX",
    "ipAddress": "72.201.94.150"
}

PAYMENT OBJECT

Parameter Type Description Requirement
paymentOption string rapipago Mandatory
holder string Customer’s First and Last Name Mandatory
DocumentId string Customer’s Document Id Mandatory

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Customer’s First Name Mandatory
lastName string Customer’s Last Name Mandatory
email string Customer’s Email Mandatory
address string Customer’s address - Street Name Optional
address2 string Customer’s address - Street Number Optional
city string Customer’s city Optional
zip string Customer’s city Postal Code Optional
state string Customer’s state - 2 letter code Optional
country string Customer’s country - ISO1 country Code Mandatory
birthday date Customer’s birthday - MM/DD/YYYY Optional
phone string Customer’s phone Number Optional

SafetyPay

curl https://api.alternativepayments.com/api/transactions -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
  "customer": {
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "NL"
  },
  "payment": {
    "paymentOption": "safetypay",
    "holder": "John Doe",
  },
  "amount": 100,
  "currency": "EUR",
  "ipaddress": "123.01.1",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  }
}
$customer = new \AlternativePayments\Model\Customer();
$customer->setEmail("john@doe.com");
$customer->setcountry("NL");
$customer->setFirstName("John");
$customer->setLastName("Doe");

$payment = new \AlternativePayments\Model\Payment();
$payment->setpaymentOption("safetypay");
$payment->setHolder("John Doe");

$redirect = new \AlternativePayments\Model\RedirectUrls();
$redirect->setReturnUrl("http://alternativepayments.com/message/success.html");
$redirect->setCancelUrl("http://alternativepayments.com/message/failure.html");

$transaction = new \AlternativePayments\Model\Transaction();
$transaction->setCustomer($customer);
$transaction->setPayment($payment);
$transaction->setRedirectUrls($redirect);
$transaction->setAmount(100);
$transaction->setCurrency("EUR");
$transaction->setIpAddress($ipAddress);
$res = Transaction :: post($transaction);
AlternativePayments.ApiUrl = _apiUrl;

var customer = new Customer();
customer.Email = "john@doe.com";
customer.FirstName = "John";
customer.LastName = "Doe";
customer.country = "NL";

var payment = new Payment();
payment.paymentOption = "safetypay";
payment.Holder = customer.FirstName + " " + customer.LastName;

var redirect = new RedirectUrls();
redirect.ReturnUrl = "http://alternativepayments.com/message/success.html"
redirect.CancelUrl = "http://alternativepayments.com/message/failure.html"

var transaction = new Transaction();
transaction.Customer = customer;
transaction.Payment = payment;
transaction.RedirectUrls = redirect;
transaction.Amount = 250;
transaction.Currency = "EUR";
transaction.Description = "Test transaction";

The above command returns JSON structured like this:

 customer = ApRubySdk::Customer.new(
        'firstName' => 'John',
        'lastName' => 'Doe',
        'email' => 'john@doe.com',
        'country' => 'NL'
    )

    payment = ApRubySdk::Payment.new(
        'paymentOption' => 'safetypay',
        'holder' => 'John Doe'
    )

    redirectUrls = ApRubySdk::RedirectUrls.new(
        'returnUrl' => 'http://alternativepayments.com/message/success.html',
        'cancelUrl' => 'http://alternativepayments.com/message/failure.html'
    )

    @transaction = ApRubySdk::Transaction.create(
        'customer' => customer,
        'payment' => payment,
        'amount' => 500,
        'currency' => 'EUR',
        'redirectUrls' => redirectUrls
    )
   customer = Customer(
        id='cus_bd838e3611d34d598',
        firstName='John',
        lastName='Doe',
        email='john@doe.com',
        country='NL'
    )

    payment = Payment(
        paymentOption='safetypay',
        holder='John Doe'
    )

    redirectUrls = RedirectUrls(
        returnUrl='http://alternativepayments.com/message/success.html',
        cancelUrl='http://alternativepayments.com/message/failure.html'
    )

    return Transaction.create({
        'customer': customer,
        'payment': payment,
        'amount': 500,
        'currency': 'EUR',
        'iPAddress': '123.01.1',
        'redirectUrls': redirectUrls
    })

The above command returns JSON structured like this:

{
  "id": "trn_1a5f5e0c97",
  "mode": "Test",
  "status": "Pending",
  "customer": {
    "id": "cus_bf682a6c051145a09",
    "mode": "Test",
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "NL",
    "created": "2016-03-25T13:51:04.8497785Z"
  },
  "payment": {
    "id": "pay_ffd25121f84e4d249",
    "mode": "Test",
    "paymentOption": "safetypay",
    "holder": "Piet Saar",
    "created": "2016-03-25T13:51:04.7717784Z"
  },
  "amount": 1700,
  "currency": "EUR",
  "merchantPassThruData": "Order #1234958",
  "created": "2016-03-25T13:51:04.8497785Z",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  },
  "ipaddress": "123.01.1",
  "redirectUrl": "http://mybankingsite.com/hRedirection.aspx?transaction_id=trn_1a5f5e0c97"
}

PAYMENT OBJECT

Parameter Type Description Requirement
paymentOption string safetypay Mandatory
holder string Customer’s First and Last Name Mandatory

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Customer’s First Name Mandatory
lastName string Customer’s Last Name Mandatory
email string Customer’s Email Mandatory
address string Customer’s address - Street Name Optional
address2 string Customer’s address - Street Number Optional
city string Customer’s city Optional
zip string Customer’s city Postal Code Optional
state string Customer’s state - 2 letter code Optional
country string Customer’s country - ISO1 country Code Mandatory
birthday date Customer’s birthday - MM/DD/YYYY Optional
phone string Customer’s phone Number Optional

Santander

curl https://api.alternativepayments.com/api/transactions -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
    "customer": {
        "firstName": "John",
        "lastName": "Doe",
        "email": "john@doe.com",
        "country": "BR",
        "phone": "+5500147258369"
    },
    "currency": "EUR",
    "amount": 313,
    "ipaddress": "72.201.94.150",
    "payment": {
        "holder": "John Doe",
        "paymentOption": "Santander",
        "DocumentId": "XXX.XXX.XXX"
    },
    "redirectUrls": {
        "returnUrl": "http://alternativepayments.com/message/success.html",
        "cancelUrl": "http://alternativepayments.com/message/failure.html"
    }
}

The above command returns JSON structured like this:

{
    "id": "trn_a9cf2fb609434e",
    "mode": "Live",
    "status": "Pending",
    "customer": {
        "id": "cus_a6b47e15f17a4c0b9",
        "mode": "Live",
        "firstName": "John",
        "lastName": "Doe",
        "email": "john@doe.com",
        "country": "BR",
        "phone": "+5500147258369",
        "created": "2020-11-20T13:35:06.3542905Z"
    },
    "payment": {
        "id": "pay_6b7036d90e3a449da",
        "mode": "Live",
        "paymentOption": "Santander",
        "holder": "John Doe",
        "created": "2020-11-20T13:35:06.2605426Z",
        "ipAddress": "72.201.94.150"
    },
    "amount": 313.0,
    "currency": "EUR",
    "created": "2020-11-20T13:35:06.3386658Z",
    "redirectUrls": {
        "returnUrl": "http://alternativepayments.com/message/success.html",
        "cancelUrl": "http://alternativepayments.com/message/failure.html"
    },
    "redirectUrl": "https://www.paygol.com/api/pay-direct/XXX-XXX-XXX",
    "ipAddress": "72.201.94.150"
}

PAYMENT OBJECT

Parameter Type Description Requirement
paymentOption string Santander Mandatory
holder string Customer’s First and Last Name Mandatory
DocumentId string Customer’s Document Id Mandatory

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Customer’s First Name Mandatory
lastName string Customer’s Last Name Mandatory
email string Customer’s Email Mandatory
address string Customer’s address - Street Name Optional
address2 string Customer’s address - Street Number Optional
city string Customer’s city Optional
zip string Customer’s city Postal Code Optional
state string Customer’s state - 2 letter code Optional
country string Customer’s country - ISO1 country Code Mandatory
birthday date Customer’s birthday - MM/DD/YYYY Optional
phone string Customer’s phone Number Optional

SEPA

You must specify 'SEPA’ as a parameter for 'paymentOption’.

curl https://api.alternativepayments.com/api/transactions -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
  "customer": {
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "DE"
  },
  "payment": {
    "paymentOption": "sepa",
    "holder": "John Doe",
    "iban": "DE71XXXXX3330"
  },
  "amount": 100,
  "currency": "EUR",
  "ipaddress": "123.01.1",
}
$customer = new \AlternativePayments\Model\Customer();
$customer->setEmail("john@doe.com");
$customer->setcountry("DE");
$customer->setFirstName("John");
$customer->setLastName("Doe");

$payment = new \AlternativePayments\Model\Payment();
$payment->setpaymentOption("sepa");
$payment->setHolder("John Doe");
$payment->setIBAN("DE71XXXXX3330");


$transaction = new \AlternativePayments\Model\Transaction();
$transaction->setCustomer($customer);
$transaction->setPayment($payment);
$transaction->setAmount(100);
$transaction->setCurrency("EUR");
$transaction->setIpAddress($ipAddress);
$res = Transaction :: post($transaction);
AlternativePayments.ApiUrl = _apiUrl;

var customer = new Customer();
customer.Email = "john@doe.com";
customer.FirstName = "John";
customer.LastName = "Doe";
customer.country = "DE";

var payment = new Payment();
payment.paymentOption = "sepa";
payment.IBAN = "DE71XXXXX3330";
payment.Holder = customer.FirstName + " " + customer.LastName;

var transaction = new Transaction();
transaction.Customer = customer;
transaction.Payment = payment;
transaction.Amount = 100;
transaction.Currency = "EUR";
customer = ApRubySdk::Customer.new(
        'firstName' => 'John',
        'lastName' => 'Doe',
        'email' => 'john@doe.com',
        'country' => 'DE'
    )

    payment = ApRubySdk::Payment.new(
        'paymentOption' => 'sepa',
        'holder' => 'John Doe',
        'iban' => 'DE71XXXXX3330'
    )

    @transaction = ApRubySdk::Transaction.create(
        'customer' => customer,
        'payment' => payment,
        'amount' => 500,
        'currency' => 'EUR'
    )
    customer = Customer(
        id='cus_bd838e3611d34d598',
        firstName='John',
        lastName='Doe',
        email='john@doe.com',
        country='DE'
    )

    payment = Payment(
        paymentOption='sepa',
        holder='John Doe',
        iban='BE88271080782541'
    )

    return Transaction.create({
        'customer': customer,
        'payment': payment,
        'amount': 500,
        'currency': 'EUR',
        'merchantPassThruData': 'test_sepa_123',
        'iPAddress': '123.01.1'
    })

The above command returns JSON structured like this:

{
  "id": "trn_d12209838b",
  "mode": "Test",
  "status": "Pending",
  "customer": {
    "id": "cus_de0636cef44540a4a",
    "mode": "Test",
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "DE",
    "created": "2016-03-17T05:17:58.0438821Z"
  },
  "payment": {
    "id": "pay_917a86ff369e4f8a9",
    "mode": "Test",
    "paymentOption": "sepa",
    "holder": "John Doe",
    "iban": "DE85XXXXX0817",
    "bic": "SPAEAT2SXXX",
    "created": "2016-03-17T05:17:58.0108663Z"
  },
  "amount": 500,
  "ipaddress": "123.01.1",
  "currency": "EUR",
  "created": "2016-03-17T05:17:58.0388728Z"
}

ATTRIBUTES (for recuring payments)

Parameter Type Description Requirement
isRecurring string Set if the transaction is recurring or not. Must be true for recurring payments Mandatory for recurring transactions
initialTransactionId string transaction id of the first transaction in a series of recurring transactions Mandatory for transaction that is part of a series of recurring transactions

NOTE: If the transaction is sent without isRecuring and initialTransactionId parameters, it will be processed as a one-time transaction. For recurring transactions, you must use those parameters.

An initial transaction that is first in a series of recurring transactions must be sent with isRecuring set to true. For all subsequent transactions in the recuring series, you must use initialTransactionId of the first transaction that is part of that series.

PAYMENT OBJECT

Parameter Type Description Requirement
paymentOption string sepa Mandatory
holder string Customer’s First and Last Name Mandatory
iban string customer’s IBAN code Mandatory

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Customer’s First Name Mandatory
lastName string Customer’s Last Name Mandatory
email string Customer’s Email Mandatory
address string Customer’s address - Street Name Optional
address2 string Customer’s address - Street Number Optional
city string Customer’s city Optional
zip string Customer’s city Postal Code Optional
state string Customer’s state - 2 letter code Optional
country string Customer’s country - ISO1 country Code Mandatory
birthday date Customer’s birthday - MM/DD/YYYY Optional
phone string Customer’s phone Number Optional

PHONE VERIFICATION OBJECT

To create the transaction, phoneVerification object must be sent, together with all other required objects.

For a detailed explanation how creating of the transaction with SMS verification works, find out more in section Phone Verification.

Phone verification is mandatory for SEPA only.

Parameter Type Description Requirement
token string generated token Mandatory
pin string pin code received by SMS Mandatory

 

 

 

 

 

 

 

 

 

 

 

 

Servipag

curl https://api.alternativepayments.com/api/transactions -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
    "customer": {
        "firstName": "John",
        "lastName": "Doe",
        "email": "john@doe.com",
        "country": "CL"
    },
    "currency": "EUR",
    "amount": 313,
    "ipaddress": "72.201.94.150",
    "payment": {
        "holder": "John Doe",
        "paymentOption": "servipag",
        "DocumentId": "XXX.XXX.XXX"
    },
    "redirectUrls": {
        "returnUrl": "http://alternativepayments.com/message/success.html",
        "cancelUrl": "http://alternativepayments.com/message/failure.html"
    }
}

The above command returns JSON structured like this:

{
    "id": "trn_a9cf2fb609434e",
    "mode": "Live",
    "status": "Pending",
    "customer": {
        "id": "cus_a6b47e15f17a4c0b9",
        "mode": "Live",
        "firstName": "John",
        "lastName": "Doe",
        "email": "john@doe.com",
        "country": "CL",
        "created": "2020-11-20T13:35:06.3542905Z"
    },
    "payment": {
        "id": "pay_6b7036d90e3a449da",
        "mode": "Live",
        "paymentOption": "servipag",
        "holder": "John Doe",
        "created": "2020-11-20T13:35:06.2605426Z",
        "ipAddress": "72.201.94.150"
    },
    "amount": 313.0,
    "currency": "EUR",
    "created": "2020-11-20T13:35:06.3386658Z",
    "redirectUrls": {
        "returnUrl": "http://alternativepayments.com/message/success.html",
        "cancelUrl": "http://alternativepayments.com/message/failure.html"
    },
    "redirectUrl": "https://www.paygol.com/api/pay-direct/XXX-XXX-XXX",
    "ipAddress": "72.201.94.150"
}

PAYMENT OBJECT

Parameter Type Description Requirement
paymentOption string servipag Mandatory
holder string Customer’s First and Last Name Mandatory
DocumentId string Customer’s Document Id Mandatory

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Customer’s First Name Mandatory
lastName string Customer’s Last Name Mandatory
email string Customer’s Email Mandatory
address string Customer’s address - Street Name Optional
address2 string Customer’s address - Street Number Optional
city string Customer’s city Optional
zip string Customer’s city Postal Code Optional
state string Customer’s state - 2 letter code Optional
country string Customer’s country - ISO1 country Code Mandatory
birthday date Customer’s birthday - MM/DD/YYYY Optional
phone string Customer’s phone Number Optional

SOFORT Überweisung

curl https://api.alternativepayments.com/api/transactions -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
  "customer": {
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "DE"
  },
  "payment": {
    "paymentOption": "sofortuberweisung",
    "holder": "John Doe"
  },
  "amount": 100,
  "currency": "EUR",
  "ipaddress": "123.01.1",
  "redirectUrls": {
    "ReturnUrl":"http://alternativepayments.com/message/success.html",
    "CancelUrl":"http://alternativepayments.com/message/failure.html"
  }
}

The above command returns JSON structured like this:

{
  "id": "trn_2bbcd34628",
  "mode": "Test",
  "status": "Pending",
  "customer": {
    "id": "cus_b9c6a32127724ffea",
    "mode": "Test",
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "DE",
    "created": "2016-03-25T14:04:41.7643102Z"
  },
  "payment": {
    "id": "pay_f633ab65f86b4dac8",
    "mode": "Test",
    "paymentOption": "sofortuberweisung",
    "holder": "John Doe",
    "created": "2016-03-25T14:04:41.6863101Z"
  },
  "amount": 100,
  "currency": "EUR",
  "created": "2016-03-25T14:04:41.7643102Z",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  },
  "ipaddress": "123.01.1",
  "redirectUrl": "http://checkout.nts.com/direction.aspx?transaction_id=trn_2688"
}

PAYMENT OBJECT

Parameter Type Description Requirement
paymentOption string sofortuberweisung Mandatory
holder string Customer’s First and Last Name Mandatory

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Customer’s First Name Mandatory
lastName string Customer’s Last Name Mandatory
email string Customer’s Email Mandatory
address string Customer’s address - Street Name Optional
address2 string Customer’s address - Street Number Optional
city string Customer’s city Optional
zip string Customer’s city Postal Code Optional
state string Customer’s state - 2 letter code Optional
country string Customer’s country - ISO1 country Code Mandatory
birthday date Customer’s birthday - MM/DD/YYYY Optional
phone string Customer’s phone Number Optional

TrustPay

curl https://api.alternativepayments.com/api/transactions -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
  "customer": {
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "CZ"
  },
  "payment": {
    "paymentOption": "trustpay",
    "holder": "John Doe",
  },
  "amount": 100,
  "currency": "EUR",
  "ipaddress": "123.01.1",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  }
}
$customer = new \AlternativePayments\Model\Customer();
$customer->setEmail("john@doe.com");
$customer->setcountry("CZ");
$customer->setFirstName("John");
$customer->setLastName("Doe");

$payment = new \AlternativePayments\Model\Payment();
$payment->setpaymentOption("trustpay");
$payment->setHolder("John Doe");

$redirect = new \AlternativePayments\Model\RedirectUrls();
$redirect->setReturnUrl("http://alternativepayments.com/message/success.html");
$redirect->setCancelUrl("http://alternativepayments.com/message/failure.html");

$transaction = new \AlternativePayments\Model\Transaction();
$transaction->setCustomer($customer);
$transaction->setPayment($payment);
$transaction->setRedirectUrls($redirect);
$transaction->setAmount(100);
$transaction->setCurrency("EUR");
$transaction->setIpAddress($ipAddress);
$res = Transaction :: post($transaction);
AlternativePayments.ApiUrl = _apiUrl;

var customer = new Customer();
customer.Email = "john@doe.com";
customer.FirstName = "John";
customer.LastName = "Doe";
customer.country = "CZ";

var payment = new Payment();
payment.paymentOption = "trustpay";
payment.Holder = customer.FirstName + " " + customer.LastName;

var redirect = new RedirectUrls();
redirect.ReturnUrl = "http://alternativepayments.com/message/success.html"
redirect.CancelUrl = "http://alternativepayments.com/message/failure.html"

var transaction = new Transaction();
transaction.Customer = customer;
transaction.Payment = payment;
transaction.RedirectUrls = redirect;
transaction.Amount = 250;
transaction.Currency = "EUR";
transaction.Description = "Test transaction";

The above command returns JSON structured like this:

 customer = ApRubySdk::Customer.new(
        'firstName' => 'John',
        'lastName' => 'Doe',
        'email' => 'john@doe.com',
        'country' => 'CZ'
    )

    payment = ApRubySdk::Payment.new(
        'paymentOption' => 'trustpay',
        'holder' => 'John Doe'
    )

    redirectUrls = ApRubySdk::RedirectUrls.new(
        'returnUrl' => 'http://alternativepayments.com/message/success.html',
        'cancelUrl' => 'http://alternativepayments.com/message/failure.html'
    )

    @transaction = ApRubySdk::Transaction.create(
        'customer' => customer,
        'payment' => payment,
        'amount' => 500,
        'currency' => 'EUR',
        'redirectUrls' => redirectUrls
    )
   customer = Customer(
        id='cus_bd838e3611d34d598',
        firstName='John',
        lastName='Doe',
        email='john@doe.com',
        country='CZ'
    )

    payment = Payment(
        paymentOption='trustpay',
        holder='John Doe'
    )

    redirectUrls = RedirectUrls(
        returnUrl='http://alternativepayments.com/message/success.html',
        cancelUrl='http://alternativepayments.com/message/failure.html'
    )

    return Transaction.create({
        'customer': customer,
        'payment': payment,
        'amount': 500,
        'currency': 'EUR',
        'iPAddress': '123.01.1',
        'redirectUrls': redirectUrls
    })

The above command returns JSON structured like this:

{
  "id": "trn_1a5f5e0c97",
  "mode": "Test",
  "status": "Pending",
  "customer": {
    "id": "cus_bf682a6c051145a09",
    "mode": "Test",
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "CZ",
    "created": "2016-03-25T13:51:04.8497785Z"
  },
  "payment": {
    "id": "pay_ffd25121f84e4d249",
    "mode": "Test",
    "paymentOption": "trustpay",
    "holder": "Piet Saar",
    "created": "2016-03-25T13:51:04.7717784Z"
  },
  "amount": 1700,
  "currency": "EUR",
  "merchantPassThruData": "Order #1234958",
  "created": "2016-03-25T13:51:04.8497785Z",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  },
  "ipaddress": "123.01.1",
  "redirectUrl": "http://mybankingsite.com/hRedirection.aspx?transaction_id=trn_1a5f5e0c97"
}

PAYMENT OBJECT

Parameter Type Description Requirement
paymentOption string trustpay Mandatory
holder string Customer’s First and Last Name Mandatory

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Customer’s First Name Mandatory
lastName string Customer’s Last Name Mandatory
email string Customer’s Email Mandatory
address string Customer’s address - Street Name Optional
address2 string Customer’s address - Street Number Optional
city string Customer’s city Optional
zip string Customer’s city Postal Code Optional
state string Customer’s state - 2 letter code Optional
country string Customer’s country - ISO1 country Code Mandatory
birthday date Customer’s birthday - MM/DD/YYYY Optional
phone string Customer’s phone Number Optional

Trustly

curl https://api.alternativepayments.com/api/transactions -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
  "customer": {
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "DE"
  },
  "currency": "EUR",
  "amount": 1050,
  "ipaddress": "72.201.94.150",
  "payment": {
    "holder": "Brian Cheung",
    "paymentOption": "Trustly"
  },
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  }
}

The above command returns JSON structured like this:

{
    "id": "trn_ab527643a0cd4f",
    "mode": "Live",
    "status": "Pending",
    "customer": {
        "id": "cus_70da1c2fb8524aab9",
        "mode": "Live",
        "firstName": "Brian",
        "lastName": "Cheung",
        "email": "brian.cheung@alternativepayments.com",
        "country": "DE",
        "created": "2019-10-19T06:25:11.2719892Z"
    },
    "payment": {
        "id": "pay_11a29a378e3c442aa",
        "mode": "Live",
        "paymentOption": "Trustly",
        "holder": "Brian Cheung",
        "created": "2019-10-19T06:25:11.1669832Z",
        "ipAddress": "72.201.94.150"
    },
    "amount": 1050.0,
    "currency": "EUR",
    "created": "2019-10-19T06:25:11.267989Z",
    "redirectUrls": {
        "returnUrl": "http://alternativepayments.com/message/success.html",
        "cancelUrl": "http://alternativepayments.com/message/failure.html"
    },
    "redirectUrl": "https://test.trustly.com/_/orderclient.php?SessionID=7f995897-2b9b-4615-b258-ff5a70810262&OrderID=2975245001&Locale=en_US",
    "ipAddress": "72.201.94.150"
}

PAYMENT OBJECT

Parameter Type Description Requirement
paymentOption string Trustly Mandatory
holder string Customer’s First and Last Name Mandatory

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Customer’s First Name Mandatory
lastName string Customer’s Last Name Mandatory
email string Customer’s Email Mandatory
address string Customer’s address - Street Name Optional
address2 string Customer’s address - Street Number Optional
city string Customer’s city Optional
zip string Customer’s city Postal Code Optional
state string Customer’s state - 2 letter code Optional
country string Customer’s country - ISO1 country Code Mandatory
birthday date Customer’s birthday - MM/DD/YYYY Optional
phone string Customer’s phone Number Optional

Teleingreso

curl https://api.alternativepayments.com/api/transactions -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
  "customer": {
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "ES"
  },
  "payment": {
    "paymentOption": "teleingreso",
    "holder": "John Doe",
  },
  "amount": 100,
  "currency": "EUR",
  "ipaddress": "123.01.1",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  }
}
$customer = new \AlternativePayments\Model\Customer();
$customer->setEmail("john@doe.com");
$customer->setcountry("ES");
$customer->setFirstName("John");
$customer->setLastName("Doe");

$payment = new \AlternativePayments\Model\Payment();
$payment->setpaymentOption("teleingreso");
$payment->setHolder("John Doe");

$redirect = new \AlternativePayments\Model\RedirectUrls();
$redirect->setReturnUrl("http://alternativepayments.com/message/success.html");
$redirect->setCancelUrl("http://alternativepayments.com/message/failure.html");

$transaction = new \AlternativePayments\Model\Transaction();
$transaction->setCustomer($customer);
$transaction->setPayment($payment);
$transaction->setRedirectUrls($redirect);
$transaction->setAmount(100);
$transaction->setCurrency("EUR");
$transaction->setIpAddress($ipAddress);
$res = Transaction :: post($transaction);
AlternativePayments.ApiUrl = _apiUrl;

var customer = new Customer();
customer.Email = "john@doe.com";
customer.FirstName = "John";
customer.LastName = "Doe";
customer.country = "ES";

var payment = new Payment();
payment.paymentOption = "teleingreso";
payment.Holder = customer.FirstName + " " + customer.LastName;

var redirect = new RedirectUrls();
redirect.ReturnUrl = "http://alternativepayments.com/message/success.html"
redirect.CancelUrl = "http://alternativepayments.com/message/failure.html"

var transaction = new Transaction();
transaction.Customer = customer;
transaction.Payment = payment;
transaction.RedirectUrls = redirect;
transaction.Amount = 250;
transaction.Currency = "EUR";
transaction.Description = "Test transaction";

The above command returns JSON structured like this:

 customer = ApRubySdk::Customer.new(
        'firstName' => 'John',
        'lastName' => 'Doe',
        'email' => 'john@doe.com',
        'country' => 'ES'
    )

    payment = ApRubySdk::Payment.new(
        'paymentOption' => 'teleingreso',
        'holder' => 'John Doe'
    )

    redirectUrls = ApRubySdk::RedirectUrls.new(
        'returnUrl' => 'http://alternativepayments.com/message/success.html',
        'cancelUrl' => 'http://alternativepayments.com/message/failure.html'
    )

    @transaction = ApRubySdk::Transaction.create(
        'customer' => customer,
        'payment' => payment,
        'amount' => 500,
        'currency' => 'EUR',
        'redirectUrls' => redirectUrls
    )
   customer = Customer(
        id='cus_bd838e3611d34d598',
        firstName='John',
        lastName='Doe',
        email='john@doe.com',
        country='ES'
    )

    payment = Payment(
        paymentOption='teleingreso',
        holder='John Doe'
    )

    redirectUrls = RedirectUrls(
        returnUrl='http://alternativepayments.com/message/success.html',
        cancelUrl='http://alternativepayments.com/message/failure.html'
    )

    return Transaction.create({
        'customer': customer,
        'payment': payment,
        'amount': 500,
        'currency': 'EUR',
        'iPAddress': '123.01.1',
        'redirectUrls': redirectUrls
    })

The above command returns JSON structured like this:

{
  "id": "trn_1a5f5e0c97",
  "mode": "Test",
  "status": "Pending",
  "customer": {
    "id": "cus_bf682a6c051145a09",
    "mode": "Test",
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "ES",
    "created": "2016-03-25T13:51:04.8497785Z"
  },
  "payment": {
    "id": "pay_ffd25121f84e4d249",
    "mode": "Test",
    "paymentOption": "teleingreso",
    "holder": "Piet Saar",
    "created": "2016-03-25T13:51:04.7717784Z"
  },
  "amount": 1700,
  "currency": "EUR",
  "merchantPassThruData": "Order #1234958",
  "created": "2016-03-25T13:51:04.8497785Z",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  },
  "ipaddress": "123.01.1",
  "redirectUrl": "http://mybankingsite.com/hRedirection.aspx?transaction_id=trn_1a5f5e0c97"
}

PAYMENT OBJECT

Parameter Type Description Requirement
paymentOption string teleingreso Mandatory
holder string Customer’s First and Last Name Mandatory

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Customer’s First Name Mandatory
lastName string Customer’s Last Name Mandatory
email string Customer’s Email Mandatory
address string Customer’s address - Street Name Optional
address2 string Customer’s address - Street Number Optional
city string Customer’s city Optional
zip string Customer’s city Postal Code Optional
state string Customer’s state - 2 letter code Optional
country string Customer’s country - ISO1 country Code Mandatory
birthday date Customer’s birthday - MM/DD/YYYY Optional
phone string Customer’s phone Number Optional

UnionPay

curl https://api.alternativepayments.com/api/transactions -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
  "customer": {
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "CN"
  },
  "payment": {
    "paymentOption": "unionpay",
    "holder": "John Doe"
  },
  "amount": 100,
  "currency": "EUR",
  "ipaddress": "123.01.1",
  "redirectUrls": {
    "ReturnUrl":"http://alternativepayments.com/message/success.html",
    "CancelUrl":"http://alternativepayments.com/message/failure.html"
  }
}

The above command returns JSON structured like this:

{
  "id": "trn_2bbcd34628",
  "mode": "Test",
  "status": "Pending",
  "customer": {
    "id": "cus_b9c6a32127724ffea",
    "mode": "Test",
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "CN",
    "created": "2016-03-25T14:04:41.7643102Z"
  },
  "payment": {
    "id": "pay_f633ab65f86b4dac8",
    "mode": "Test",
    "paymentOption": "unionpay",
    "holder": "John Doe",
    "created": "2016-03-25T14:04:41.6863101Z"
  },
  "amount": 100,
  "currency": "EUR",
  "created": "2016-03-25T14:04:41.7643102Z",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  },
  "ipaddress": "123.01.1",
  "redirectUrl": "http://checkout.nts.com/direction.aspx?transaction_id=trn_2688"
}

PAYMENT OBJECT

Parameter Type Description Requirement
paymentOption string unionpay Mandatory
holder string Customer’s First and Last Name Mandatory

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Customer’s First Name Mandatory
lastName string Customer’s Last Name Mandatory
email string Customer’s Email Mandatory
address string Customer’s address - Street Name Optional
address2 string Customer’s address - Street Number Optional
city string Customer’s city Optional
zip string Customer’s city Postal Code Optional
state string Customer’s state - 2 letter code Optional
country string Customer’s country - ISO1 country Code Mandatory
birthday date Customer’s birthday - MM/DD/YYYY Optional
phone string Customer’s phone Number Optional

Via Baloto

curl https://api.alternativepayments.com/api/transactions -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
    "customer": {
        "firstName": "John",
        "lastName": "Doe",
        "email": "jane@doe.com",
        "country": "CO"
    },
    "currency": "EUR",
    "amount": 135,
    "ipaddress": "72.201.94.150",
    "payment": {
        "holder": "John Doe",
        "paymentOption": "Viabaloto",
        "DocumentId": "XXX.XXX.XXX"
    },
    "redirectUrls": {
        "returnUrl": "http://alternativepayments.com/message/success.html",
        "cancelUrl": "http://alternativepayments.com/message/failure.html"
    }
}

The above command returns JSON structured like this:

{
    "id": "trn_a9cf2fb609434e",
    "mode": "Live",
    "status": "Pending",
    "customer": {
        "id": "cus_a6b47e15f17a4c0b9",
        "mode": "Live",
        "firstName": "John",
        "lastName": "Doe",
        "email": "john@doe.com",
        "country": "CO",
        "created": "2020-11-20T13:35:06.3542905Z"
    },
    "payment": {
        "id": "pay_6b7036d90e3a449da",
        "mode": "Live",
        "paymentOption": "Viabaloto",
        "holder": "John Doe",
        "created": "2020-11-20T13:35:06.2605426Z",
        "ipAddress": "72.201.94.150"
    },
    "amount": 135.0,
    "currency": "EUR",
    "created": "2020-11-20T13:35:06.3386658Z",
    "redirectUrls": {
        "returnUrl": "http://alternativepayments.com/message/success.html",
        "cancelUrl": "http://alternativepayments.com/message/failure.html"
    },
    "redirectUrl": "https://www.paygol.com/api/pay-direct/XXX-XXX-XXX",
    "ipAddress": "72.201.94.150"
}

PAYMENT OBJECT

Parameter Type Description Requirement
paymentOption string Viabaloto Mandatory
holder string Customer’s First and Last Name Mandatory
DocumentId string Customer’s Document Id Mandatory

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Customer’s First Name Mandatory
lastName string Customer’s Last Name Mandatory
email string Customer’s Email Mandatory
address string Customer’s address - Street Name Optional
address2 string Customer’s address - Street Number Optional
city string Customer’s city Optional
zip string Customer’s city Postal Code Optional
state string Customer’s state - 2 letter code Optional
country string Customer’s country - ISO1 country Code Mandatory
birthday date Customer’s birthday - MM/DD/YYYY Optional
phone string Customer’s phone Number Optional

Webpay

curl https://api.alternativepayments.com/api/transactions -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
    "customer": {
        "firstName": "John",
        "lastName": "Doe",
        "email": "john@doe.com",
        "country": "CL"
    },
    "currency": "EUR",
    "amount": 313,
    "ipaddress": "72.201.94.150",
    "payment": {
        "holder": "John Doe",
        "paymentOption": "webpay",
        "DocumentId": "XXX.XXX.XXX"
    },
    "redirectUrls": {
        "returnUrl": "http://alternativepayments.com/message/success.html",
        "cancelUrl": "http://alternativepayments.com/message/failure.html"
    }
}

The above command returns JSON structured like this:

{
    "id": "trn_a9cf2fb609434e",
    "mode": "Live",
    "status": "Pending",
    "customer": {
        "id": "cus_a6b47e15f17a4c0b9",
        "mode": "Live",
        "firstName": "John",
        "lastName": "Doe",
        "email": "john@doe.com",
        "country": "CL",
        "created": "2020-11-20T13:35:06.3542905Z"
    },
    "payment": {
        "id": "pay_6b7036d90e3a449da",
        "mode": "Live",
        "paymentOption": "webpay",
        "holder": "John Doe",
        "created": "2020-11-20T13:35:06.2605426Z",
        "ipAddress": "72.201.94.150"
    },
    "amount": 313.0,
    "currency": "EUR",
    "created": "2020-11-20T13:35:06.3386658Z",
    "redirectUrls": {
        "returnUrl": "http://alternativepayments.com/message/success.html",
        "cancelUrl": "http://alternativepayments.com/message/failure.html"
    },
    "redirectUrl": "https://www.paygol.com/api/pay-direct/XXX-XXX-XXX",
    "ipAddress": "72.201.94.150"
}

PAYMENT OBJECT

Parameter Type Description Requirement
paymentOption string webpay Mandatory
holder string Customer’s First and Last Name Mandatory
DocumentId string Customer’s Document Id Mandatory

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Customer’s First Name Mandatory
lastName string Customer’s Last Name Mandatory
email string Customer’s Email Mandatory
address string Customer’s address - Street Name Optional
address2 string Customer’s address - Street Number Optional
city string Customer’s city Optional
zip string Customer’s city Postal Code Optional
state string Customer’s state - 2 letter code Optional
country string Customer’s country - ISO1 country Code Mandatory
birthday date Customer’s birthday - MM/DD/YYYY Optional
phone string Customer’s phone Number Optional

Retrieving Transaction ↓

 curl https://api.alternativepayments.com/api/transactions/{Id} \
 -u <WEBSITE_SECRET_KEY>:
$res = Transaction :: get("trn_543256467");
AlternativePayments.ApiUrl = _apiUrl;
var id = "trn_543256467";
var result = AlternativePayments.Get(id).Result;
  def index
    if params[:transaction_id]
      @transaction = ApRubySdk::Transaction.retrieve(params[:transaction_id])
    end
  end
transaction = Transaction.retrieve(transaction_id)

The above command returns JSON structured like this:

{
    "id": "trn_326cf8bab3a742",
    "mode": "Live",
    "status": "Funded",
    "customer": {
        "id": "cus_0fe9bf220263461c9",
        "mode": "Live",
        "firstName": "John",
        "lastName": "Doe",
        "email": "john@doe.com",
        "created": "2020-10-05T10:25:32.677Z"
    },
    "paymentId": "pay_b010589bb3f944a48",
    "payment": {
        "id": "pay_b010589bb3f944a48",
        "mode": "Live",
        "customerId": "cus_0fe9bf220263461c9",
        "paymentOption": "Sofortuberweisung",
        "holder": "John Doe",
        "created": "2020-10-05T10:25:32.56Z",
        "ipAddress": "77.46.149.145"
    },
    "amount": 100.0000,
    "currency": "EUR",
    "created": "2020-10-05T10:25:32.67Z",
    "redirectUrl": "https://www.sofort.com/payment/go/e9b48f532274ae2626cf8be1339c8f8e01badaf2",
    "ipAddress": "77.46.149.145",
    "sequenceType": "OOFF"
}

Retrieves the details of a transaction using the identifier of the transaction (transaction id).

ATTRIBUTES

Parameter Type Description
id string Unique identifier of the transaction
Request example

GET https://api.alternativepayments.com/api/transactions/trn_326cf8bab3a742

RESPONSE ATTRIBUTES
Parameter Type Description
id string Unique identifier for this transaction
mode Enum (Test, Live) Indication if the transaction was created using Test or Live keys
status Enum Identifies transaction status
customer customer object Customer Object
paymentId string Unique identifier for payment
payment payment object Payment Object
amount integer Transaction amount
currency string Transaction currency
created string UTC creation date
redirectUrl string Redirection URL
ipAddress string Customer IP address
sequenceType string Sequence type

Retrieve SCT and SDD

 curl GET https://api.alternativepayments.com/api/sepa/transactions/?{offset}&{Limit}&{CreatedFrom}&{CreatedTo}&{UpdatedFrom}&{UpdatedTo}&{transactionStatus} \
 -u <WEBSITE_SECRET_KEY>:
$res = Transaction :: get("trn_543256467");
AlternativePayments.ApiUrl = _apiUrl;
var id = "trn_543256467";
var result = AlternativePayments.Get(id).Result;
  def index
    if params[:transaction_id]
      @transaction = ApRubySdk::Transaction.retrieve(params[:transaction_id])
    end
  end
transaction = Transaction.retrieve(transaction_id)

The above command returns JSON structured like this:

{
    "transactions": [
        {
            "id": "trn_123a4bc5678",
            "status": "Pending",
            "customer": {
                "firstName": "John",
                "lastName": "Doe",
                "country": "DE",
                "created": "2018-06-12T11:18:58.913Z"
            },
            "amount": 200,
            "currency": "EUR",
            "created": "2018-06-17T12:00:18.977Z",
            "updated": "2018-06-17T12:00:21.537Z",
            "type": "Sale"
        },
        {
            "id": "trn_123a4bc5678",
            "status": "Pending",
            "customer": {
                "firstName": "John",
                "lastName": "Doe",
                "country": "DE",
                "created": "2018-06-12T11:18:58.913Z"
            },
            "amount": 200,
            "currency": "EUR",
            "created": "2018-06-16T12:00:22.147Z",
            "updated": "2018-06-16T12:00:25.407Z",
            "type": "Sale"
        },
        {
            "id": "trn_123a4bc5678",
            "status": "Pending",
            "customer": {
                "firstName": "John",
                "lastName": "Doe",
                "country": "DE",
                "created": "2018-06-12T11:18:58.913Z"
            },
            "amount": 200,
            "currency": "EUR",
            "created": "2018-06-15T12:00:21.033Z",
            "updated": "2018-06-15T12:00:23.803Z",
            "type": "Sale"
        },
        {
            "id": "trn_123a4bc5678",
            "status": "Pending",
            "customer": {
                "firstName": "John",
                "lastName": "Doe",
                "country": "DE",
                "created": "2018-06-12T11:18:58.913Z"
            },
            "amount": 200,
            "currency": "EUR",
            "created": "2018-06-14T12:00:26.197Z",
            "updated": "2018-06-14T12:00:29.91Z",
            "type": "Sale"
        }
    ],
    "pagination": {
        "offset": 0,
        "limit": 20,
        "count": 4
    }
}

Retrieves the details of SEPA Credit Transfers(SCT) and SEPA Direct Debit Transactions(SDD).

REQUEST ATTRIBUTES

Parameter Type Description Requirement
Offset string Number of pages Optional
Limit string Upper Limit for transactions in response Optional
CreatedFrom date Created FROM date and time Optional
CreatedTo date Created TO date and time Optional
UpdatedFrom date Updated FROM date and time Optional
UpdatedTo date Updated TO date and time Optional
transactionStatus string Transaction status Optional
Request example

GET https://api.alternativepayments.com/api/sepa/transactions/?offset=0&Limit=1000&CreatedFrom=2018-06-01T13:21:42Z&CreatedTo=2018-06-12T15:21:42Z&transactionStatus=Funded

RESPONSE ATTRIBUTES
Parameter Type Description
id string Unique identifier for this transaction
status string Transaction status
merchantTransactionId string Reference ID
firstName string Customer’s First Name
lastName string Customer’s Last Name
country string Customer’s country - ISO1 country Code
created date Transaction created date and time
updated date Transaction updated date and time
type string Transaction type
declineReason string Returned/Declined reason
count string Total number of transaction
TRANSACTION TYPES
Transaction Type Data Type Description
Sale string Debit transactions
Transfer string Transfer transactions
Refund string Refunded transactions
Void string Voided transactions
Returned string Returned transactions (CB, ISF, Invalid)

Retrieve Refund

curl https://api.alternativepayments.com/api/transactions/{transactionId}/refunds/{refundId} \
-u <WEBSITE_SECRET_KEY>:
$res = Refund :: get("trn_d70bcef", "trn_543256467");
var result = AlternativePayments.Get<Refund>(code, parentCode).Result;
  def index
    if params[:refund_id] && params[:transaction_id]
      @refund = ApRubySdk::Transaction.retrieve_refund(params[:refund_id], params[:transaction_id])
    end
  end

The above command returns JSON structured like this:

{
    "id": "ref_f811756",
    "mode": "Test",
    "amount": 89.77,
    "currency": "EUR",
    "originalTransactionId": "trn_00dc520",
    "originalTransaction": {
        "id": "trn_00dc520",
        "mode": "Test",
        "status": "Refunded",
        "customer": {
            "id": "cus_0635336b935f4d14b",
            "mode": "Test",
            "firstName": "Jane",
            "lastName": "Doe",
            "email": "jane@doe.com",
            "country": "DE",
            "created": "2015-06-22T12:07:18.323Z"
        },
        "payment": {
            "id": "pay_55e66facd4874733a",
            "mode": "Test",
            "customerId": "cus_0635336b935f4d14b",
            "paymentOption": "sepa",
            "holder": "John Doe",
            "created": "2015-06-22T12:07:17.71Z"
        },
        "amount": 100,
        "currency": "USD",
        "created": "2015-06-22T12:07:18.32Z"
    },
    "created": "2015-06-23T12:46:10.917Z",
    "status": "Approved"
}

Retrieves the details of an existing refund.

REQUEST

GET https://api.alternativepayments.com/api/{transactionId}/refunds/{refundId}

Retrieve Void

curl https://api.alternativepayments.com/api/transactions/{transactionId}/voids/{voidId} \
-u <WEBSITE_SECRET_KEY>:
$res = Void :: get("trn_f09f256", "trn_543256467"); //class, void transaction if, parent transaction id
var result = AlternativePayments.Get<VoidTransaction>(code, parentCode).Result;
  def index
    if params[:void_id] && params[:transaction_id]
      @void = ApRubySdk::Transaction.retrieve_void(params[:void_id], params[:transaction_id])
    end
  end
void = Transaction.retrieve_void(void_id, transaction_id)

The above command returns JSON structured like this:

{
    "id": "void_0a3f6b2",
    "mode": "Test",
    "amount": 4000,
    "currency": "EUR",
    "originalTransactionId": "trn_41f1487",
    "originalTransaction": {
        "id": "trn_41f1487",
        "mode": "Test",
        "status": "Voided",
        "customer": {
            "id": "cus_7f0724f3b1d745d49",
            "mode": "Test",
            "firstName": "Jane",
            "lastName": "Doe",
            "email": "jane@doe.com",
            "country": "DE",
            "created": "2015-06-24T11:46:35.303Z"
        },
        "payment": {
            "id": "pay_13f3beaf091b43308",
            "mode": "Test",
            "customerId": "cus_7f0724f3b1d745d49",
            "paymentOption": "sepa",
            "holder": "John Doe",
            "created": "2015-06-24T11:46:35.267Z"
        },
        "amount": 4000,
        "currency": "EUR",
        "created": "2015-06-24T11:46:35.303Z"
    },
    "created": "2015-06-24T11:47:30.68Z",
    "status": "Approved"
}          

Retrieves the details of an existing void.

ATTRIBUTES

Parameter Type Description
transactionId string Original transaction id

REQUEST

GET https://api.alternativepayments.com/api/transactions/{transactionId}/voids/{voidId}

List Transactions ↓

 -u <WEBSITE_SECRET_KEY>:
 curl https://api.alternativepayments.com/api/transactions/
 curl https://api.alternativepayments.com/api/transactions/?{offset}&{Limit}&{startDate}&{endDate}
$res = Transaction :: getAll();
AlternativePayments.ApiUrl = _apiUrl;
var result = AlternativePayments.GetAll().Result;
  def transactions
    @transactions = ApRubySdk::Transaction.all
  end

The above command returns JSON structured like this:

{
  "transactions": [
    {
      "id": "trn_2bbcd34688",
      "mode": "Test",
      "status": "Pending",
      "customer": {
        "id": "cus_b9c6a32127724ecea",
        "mode": "Test",
        "firstName": "John",
        "lastName": "Doe",
        "email": "john@doe.com",
        "country": "DE",
        "created": "2016-03-25T14:04:41.763Z"
      },
      "payment": {
        "id": "pay_f633ab65f86b4dac8",
        "mode": "Test",
        "customerId": "cus_b9c6a32127724ecea",
        "paymentOption": "giropay",
        "holder": "John Doe",
        "created": "2016-03-25T14:04:41.687Z"
      },
      "amount": 23,
      "currency": "EUR",
      "merchantPassThruData": "order_242444",
      "created": "2016-03-25T14:04:41.763Z",
      "redirectUrl": "http://cichents.com/Tn.aspx?transaction_id=trn_2bbcd34688"
    },
    {
      "id": "trn_1a5f5e0c97",
      "mode": "Test",
      "status": "Pending",
      "customer": {
        "id": "cus_bf682a6c051145a09",
        "mode": "Test",
        "firstName": "John",
        "lastName": "Doe",
        "email": "john@doe.com",
        "country": "BE",
        "created": "2016-03-25T13:51:04.85Z"
      },
      "payment": {
        "id": "pay_ffd25121f84e4d249",
        "mode": "Test",
        "customerId": "cus_bf682a6c051145a09",
        "paymentOption": "mistercash",
        "holder": "Piet Saar",
        "created": "2016-03-25T13:51:04.773Z"
      },
      "amount": 1700,
      "currency": "EUR",
      "merchantPassThruData": "ideal",
      "created": "2016-03-25T13:51:04.85Z",
      "redirectUrl": "http://ce.io/ion.aspx?ion_id=trn_1a5f5e0c97"
    }
  ]

This API call returns a list of transactions created for a particular website.

Request examples

GET https://api.alternativepayments.com/api/transactions/

GET https://api.alternativepayments.com/api/transactions/?offset=1&Limit=1000&startDate=2017-08-07T11:14:09.5621581Z&endDate=2018-06-18T11:14:09.5621581Z

REQUEST ATTRIBUTES

Parameter Type Description
offset string Number of pages
Limit string Upper Limit for transactions in response
startDate date Created FROM date and time
endDate date Created TO date and time

RESPONSE ATTRIBUTES

Parameter Type Description
id string Unique identifier for the transaction
mode Enum (Test, Live) Indication if the transaction was created using Test or Live keys
status Enum Identifies transaction status
customer customer object Customer object
payment payment object Payment Object
amount integer Transaction amount
currency string ISO 4217 formatted currency code
created string UTC creation date

The above command returns JSON structured like this:

{
    "transactions": [
        {
            "id": "trn_4e8dc68",
            "mode": "Test",
            "status": "Refunded",
            "customer": {
                "id": "cus_004259ff7622456fb",
                "mode": "Test",
                "firstName": "Jane",
                "lastName": "Doe",
                "email": "jane@doe.com",
                "country": "DE",
                "created": "2015-06-22T13:35:38.467Z"
            },
            "payment": {
                "id": "pay_1ea32718e5664ae3b",
                "mode": "Test",
                "customerId": "cus_004259ff7622456fb",
                "paymentOption": "sepa",
                "holder": "John Doe",
                "created": "2015-06-22T13:35:38.423Z"
            },
            "amount": 100,
            "currency": "EUR",
            "created": "2015-06-22T13:35:38.467Z"
        },
        {
            "id": "trn_cc7e03d",
            "mode": "Test",
            "status": "Refunded",
            "customer": {
                "id": "cus_4130397035104ca38",
                "mode": "Test",
                "firstName": "Jane",
                "lastName": "Doe",
                "email": "jane@doe.com",
                "country": "DE",
                "created": "2015-06-22T13:39:10.547Z"
            },
            "payment": {
                "id": "pay_1c45c65d5be24054a",
                "mode": "Test",
                "customerId": "cus_4130397035104ca38",
                "paymentOption": "sepa",
                "holder": "John Doe",
                "created": "2015-06-22T13:39:10.493Z"
            },
            "amount": 100,
            "currency": "USD",
            "created": "2015-06-22T13:39:10.547Z"
        },
        {
            "id": "trn_5032300",
            "mode": "Test",
            "status": "Pending",
            "customer": {
                "id": "cus_8bfb7b0f7f9843458",
                "mode": "Test",
                "firstName": "Jane",
                "lastName": "Doe",
                "email": "jane@doe.com",
                "country": "DE",
                "created": "2015-06-23T07:39:40.57Z"
            },
            "payment": {
                "id": "pay_7f1dcd13f19c4963a",
                "mode": "Test",
                "customerId": "cus_8bfb7b0f7f9843458",
                "paymentOption": "sepa",
                "holder": "Jane Doe",
                "created": "2015-06-23T07:39:40.517Z"
            },
            "amount": 100,
            "currency": "USD",
            "created": "2015-06-23T07:39:40.57Z"
        }
    ]
}

List Voids

curl https://api.alternativepayments.com/api/transactions/{transactionId}/voids \
-u <WEBSITE_SECRET_KEY>:
$res = Void :: getAll("trn_543256467");
var result = AlternativePayments.GetAll<VoidTransaction>(parentCode).Result;
def voids
    if params[:transaction_id]
      @voids = ApRubySdk::Transaction.voids(params[:transaction_id])
    end
  end

The above command returns JSON structured like this:

{
    "voidTransactions": [
        {
            "id": "void_0a3f6b2",
            "mode": "Test",
            "amount": 4000,
            "currency": "EUR",
            "reason": "Fraud",
            "originalTransactionId": "trn_41f1487",
            "originalTransaction": {
                "id": "trn_41f1487",
                "mode": "Test",
                "status": "Voided",
                "customer": {
                    "id": "cus_7f0724f3b1d745d49",
                    "mode": "Test",
                    "firstName": "Jane",
                    "lastName": "Doe",
                    "email": "jane@doe.com",
                    "country": "DE",
                    "created": "2015-06-24T11:46:35.303Z"
                },
                "payment": {
                    "id": "pay_13f3beaf091b43308",
                    "mode": "Test",
                    "customerId": "cus_7f0724f3b1d745d49",
                    "paymentOption": "sepa",
                    "holder": "Johny Smithy",
                    "created": "2015-06-24T11:46:35.267Z"
                },
                "amount": 4000,
                "currency": "EUR",
                "created": "2015-06-24T11:46:35.303Z"
            },
            "created": "2015-06-24T11:47:30.68Z",
            "status": "Approved"
        }
    ]
}

Retrieves a list of all voids for an existing transaction.

ATTRIBUTES

Parameter Type Description
transactionId string Original transaction id

REQUEST

GET https://api.alternativepayments.com/api/transactions/{transactionId}/voids

Phone Verification ↓

SMS verification is a fraud control tool to help prevent fraudulent payments. Customers (consumers) need to enter a PIN number they receive on their mobile to complete the transaction. SMS verification is mandatory on SEPA but can be disabled on a case by case basis.

Please note that no SMS is sent when using a test API key. To proceed past PIN entry field to complete test enter the test PIN number 1234.

To request disabling SMS verification, please contact us.

It is necessary to use internationally-standardized format for all phone numbers, and it includes all the relevant information to route SMS messages globally. For example, in Germany, and many other countries internationally, local dialing requires the addition of a '0’ in front of the subscriber number. However, to use standardized formatting, this '0’ must be removed. A number such as 017 5555 5555 in the Germany would be formatted as +491755555555.

If you choose to integrate our API on your checkout page, we advise splitting the mobile number into two fields, country prefix, and mobile number. Check if the mobile number entered begins with 0. If the customer enters a mobile number that begins with 0, drop the 0. Append country prefix to the mobile number based on customer’s selection.

Here is an example of the best practice for requesting a mobile number from the consumer:

Country selector

When the customer clicks the country selector, show a list of countries containing the flag, country name, and country prefix. Sorting A-Z is good, but it is recommended to show the most popular countries A-Z first, then a divider, then all other countries A-Z. The initially selected country should be the one that you get the most international traffic from, however, you can use any country you wish. We suggest not using the United States as the initially selected country, as most SEPA customers will not be in the US.

Country selector

Here is a list of popular countries, however you can edit as desired:
Austria
Belgium
France
Germany
Greece
Ireland
Italy
Netherlands
Spain
Sweden
Switzerland
United Kingdom
United States of America

To help with the integration here are some helpful downloads:
- Zip file of all country flags
- csv file or json file of country codes and their country prefixes.

If you need further assistance, please do no hesitate to contact us.

Check SMS Verification

curl https://api.alternativepayments.com/api/websites/{publicKey}/paymentoptions/{paymentOption} \
-u <WEBSITE_SECRET_KEY>:


The above command returns JSON structured like this:

{
    "id": "web_6547gfhu67yrru43",
    "mode": "Test",
    "hasSmsVerification": true,
    "url": "http://www.mywebshop.com"
}

In response you will get hasSmsVerification parameter. If value is true, SMS verification is active on the business case.

Recieve PIN by SMS

curl https://api.alternativepayments.com/api/phoneverification \
  -H "Content-Type:application/json" -X POST -d '
{
    "key":"pk_live_cyelxxxxxxxxddddddddBQuFeAGDDNG",
    "phone":"+15555555555"
}'


The above command returns JSON structured like this:

{
  "mode": "Test",
  "key": "pk_live_cyelxxxxxxxxddddddddBQuFeAGDDNG",
  "type": "SMS",
  "phone": "1555555555555",
  "token": "8b340ecdfc63ccccccc1fe59310",
  "created": "2016-05-26T00:25:55.6886656Z"
}

Before creating the transaction, API must send PIN code by SMS to customer’s phone. Customer will then receive pin code. You must send public key in the request using the key parameter.

Token and Pin

curl https://api.alternativepayments.com/api/transactions -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
  "customer": {
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "DE"
  },
  "payment": {
    "paymentOption": "sepa",
    "holder": "John Doe",
    "iban": "DE71XXXXX3330"
  },
    "amount": 100,
    "currency": "EUR",
    "ipaddress": "123.01.1",
  "phoneverification":{
    "token":"8b340ecdfc63ccccccc1fe59310",
    "pin":"6010"
  }
}



The above command returns JSON structured like this:

{
  "id": "trn_d12209838b",
  "mode": "Test",
  "status": "Pending",
  "customer": {
    "id": "cus_de0636cef44540a4a",
    "mode": "Test",
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "DE",
    "created": "2016-03-17T05:17:58.0438821Z"
  },
  "payment": {
    "id": "pay_917a86ff369e4f8a9",
    "mode": "Test",
    "paymentOption": "sepa",
    "holder": "John Doe",
    "iban": "DE85XXXXX0817",
    "created": "2016-03-17T05:17:58.0108663Z"
  },
  "amount": 500,
  "currency": "EUR",
  "created": "2016-03-17T05:17:58.0388728Z",
  "phoneverification":{
    "token":"8b340ecdfc63ccccccc1fe59310",
    "pin":"6010"
  }
}

To create the transaction, phoneVerification object must be sent, together with all other required objects.

ATTRIBUTES

Parameter Type Description
token string generated token
pin string pin code received by SMS (range 1111-9999)

Refund a Transaction

curl https://api.alternativepayments.com/api/transactions/{transactionId}/refunds \
-u <WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
    "reason": "FRAUD"
}'
$obj = new \AlternativePayments\Model\RefundTransaction();
$obj->setReason(ReturnReason::UNSATISFIED_CUSTOMER);
$res = Refund :: post($obj, "trn_543256467");

var refund - new RefundTransaction(){

   Reason = "unsatisfied customer"
};

var result = AlternativePayments.Post<RefundTransaction>(refund, "Parent_code");
  def create
    refund = ApRubySdk::Transaction.refund(ApRubySdk::RefundReason::FRAUD, params[:transaction_id])

    flash[:notice] = refund.to_json
    redirect_to new_refund_url
  end
refund = Transaction.refund(RefundReason.FRAUD, transaction_id);

The above command returns JSON structured like this:

{
    "id": "ref_f811756",
    "mode": "Test",
    "amount": 89.77,
    "currency": "EUR",
    "reason": "FRAUD",
    "originalTransactionId": "trn_00dc520",
    "originalTransaction": {
        "id": "trn_00dc520",
        "mode": "Test",
        "status": "Refunded",
        "customer": {
            "id": "cus_0635336b935f4d14b",
            "mode": "Test",
            "firstName": "Jane",
            "lastName": "Doe",
            "email": "jane@doe.com",
            "country": "DE",
            "created": "2015-06-22T12:07:18.323Z"
        },
        "payment": {
            "id": "pay_55e66facd4874733a",
            "mode": "Test",
            "customerId": "cus_0635336b935f4d14b",
            "paymentOption": "sepa",
            "holder": "John Doe",
            "created": "2015-06-22T12:07:17.71Z"
        },
        "amount": 100,
        "currency": "USD",
        "created": "2015-06-22T12:07:18.32Z"
    },
    "created": "2015-06-23T12:46:10.9169922Z",
    "status": "Approved"
}

Refunds a transaction that has been created previously.

ATTRIBUTES

Parameter Type Description
reason string Reason for the refund, from predefined list
REFUND REASONS
Parameter Description
CHARGEBACK_AVOIDANCE Chargeback avoidance
END_USER_ERROR End user error
FRAUD Fraud
UNSATISFIED_CUSTOMER Unsatisfied customer
INVALID_TRANSACTION Invalid transaction
MERCHANT_REQUEST Merchant request
MANAGEMENT_REQUEST Management request
DUPLICATED Duplicated

REQUEST

POST https://api.alternativepayments.com/api/transactions/{transactionId}/refunds

Void a Transaction

curl https://api.alternativepayments.com/api/transactions/{transactionId}/voids \
-u <WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
    "reason": "FRAUD"
}'

$obj = new \AlternativePayments\Model\VoidTransaction();
$obj->setReason(ReturnReason::UNSATISFIED_CUSTOMER);
$res = Void :: post($obj, "trn_543256467");
var void - new VoidTransaction(){

   Reason = "unsatisfied customer"
};

var result = AlternativePayments.Post<VoidTransaction>(void, "Parent_code");
 def create
    void = ApRubySdk::Transaction.void(ApRubySdk::RefundReason::FRAUD, params[:transaction_id])

    flash[:notice] = void.to_json
    redirect_to new_void_url
  end
 void = Transaction.void(RefundReason.FRAUD, transaction_id);

The above command returns JSON structured like this:

{
    "id": "void_0a3f6b2",
    "mode": "Test",
    "amount": 4000,
    "currency": "EUR",
    "reason": "FRAUD",
    "originalTransactionId": "trn_41f1487",
    "originalTransaction": {
        "id": "trn_41f1487",
        "mode": "Test",
        "status": "Voided",
        "amount": 4000,
        "currency": "EUR",
        "created": "2015-06-24T11:46:35.303Z"
    },
    "created": "2015-06-24T11:47:30.6806641Z",
    "status": "Approved"
}

Void created transaction.

ATTRIBUTES

Parameter Type Description
reason string Reason for void, from predefined list

REQUEST

POST https://api.alternativepayments.com/api/transactions/{transactionId}/voids

Transfer

The transfer is a transaction that credits recipient’s account and is initiated by the Merchant.*

Create Transfer

curl https://api.alternativepayments.com/api/transfers -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
  "sender": {
    "firstName": "Jane",
    "lastName": "Doe",
    "email": "jane@doe.com",
    "country": "DE"
  },
  "recipient": {
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "DE",
  "payment": {
    "holder": "John Doe",
    "paymentOption": "sepa",
    "iban": "BE88XXXXX2541"
    }
  },
  "currency": "EUR",
  "amount": 100,
  "ipaddress": "123.01.1"
}

The above command returns JSON structured like this:

{
  "id": "tsf_f7614deaf8f6",
  "mode": "Test",
  "status": "Approved",
  "recipient": {
    "id": "cus_a8b90e060ec34544b",
    "mode": "Test",
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "DE",
    "payment": {
      "id": "pay_781860822f034b1d9",
      "mode": "Test",
      "paymentOption": "sepa",
      "holder": "John Doe",
      "iban": "BE88XXXXX2541",
      "bic": "GEBABEBBXXX",
      "created": "2017-03-27T11:18:16.3857116Z",
      "ipAddress": "123.01.1"
    },
    "created": "2017-03-27T11:18:16.4177116Z"
  },
  "sender": {
    "mode": "Test",
    "firstName": "Jane",
    "lastName": "Doe",
    "email": "jane@doe.com",
    "country": "DE",
    "created": "0001-01-01T00:00:00Z"
  },
  "amount": 100,
  "currency": "EUR",
  "created": "2017-03-27T11:18:16.4157111Z",
  "ipAddress": "123.01.1"
}

To create a transfer you must send recipient and sender objects. Recipient’s account will be credited for a set amount.

ATTRIBUTES

SENDER OBJECT

Parameter Type Description Requirement
firstName string Sender’s First Name Mandatory
lastName string Sender’s Last Name Mandatory
email string Sender’s Email Mandatory
country string Sender’s country - ISO1 country Code Mandatory

You must send sender’s object which represents information of the transaction sender. This will not automatically create a debit transaction, you must make that transaction separately.

RECIPIENT OBJECT

Parameter Type Description Requirement
firstName string Recipient’s First Name Mandatory
lastName string Recipient’s Last Name Mandatory
country string Recipient’s country - ISO1 country Code Mandatory
payment Payment object Payment object Mandatory

PAYMENT OBJECT ( to be sent in Recipient object)

Parameter Type Description Requirement
paymentOption string Payment Option Mandatory
holder string Recipient’s First and Last Name Mandatory
iban string Recipient’s IBAN code Mandatory

Plans and Subscriptions

A subscription is defined as the association of a customer with a plan. It is used for recurring billing.

Create Plan

curl https://api.alternativepayments.com/api/plans -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
  "name": "Gold Unlimited",
  "description": "Monthly subscription to Gold Plan - 1 year",
  "amount": 1000,
  "currency": "EUR",
  "IntervalUnit": "Month",
  "IntervalCount": 1,
  "billingCycles": 12,
  "isConversionRateFixed": true,
  "ipAddress": "123.01.1",
  "trialPeriod": 7
}'

The above command returns JSON structured like this:

{
  "id": "pln_7021187813bb",
  "mode": "Test",
  "name": "Gold Unlimited",
  "description": "Monthly subscription to Gold Plan - 1 year",
  "amount": 1000,
  "currency": "EUR",
  "intervalUnit": "Month",
  "intervalCount": 1,
  "billingCycles": 12,
  "trialPeriod": 7,
  "isConversionRateFixed": true,
  "ipAddress": "123.01.1"
}

A subscription plan contains the pricing information for different products or features. The plan can be reused by assigning different customers and/or payment data.

ATTRIBUTES

Parameter Type Description Requirement
name string User-friendly label for the plan Mandatory
description string User-friendly description (verbose). Mandatory
amount integer what the customer will be charged per subscription per interval Mandatory
currency string Currency in which customer will be charged in Mandatory
intervalUnit integer the billing period for the plan, which can range from a single day to a year. The intervalUnit options are: day, week, month, or year. Mandatory
intervalCount integer Number which defines when the charge will be created, based on the selected period. Mandatory
billingCycles integer Number of times plan is to be executed and recurring transaction created. Mandatory
trialPeriod integer Trial period in days before the first transaction is created. Optional
isConversionRateFixed boolean Option to set if transaction will be charged in original (fixed) exchange rate, or each time transaction is created it will be recalculated using current exchange rate: true or false Optional
ipAddress string IP Address Mandatory

Deactivate a Plan

curl https://api.alternativepayments.com/api/plans/pln_7021187813bb -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X DELETE -d '
{
 "cancelSubscriptions":false
}'

The above command returns JSON structured like this:

{
  "id": "pln_7021187813bb",
  "mode": "Test",
  "name": "Gold Unlimited",
  "description": "Monthly subscription to Gold Plan - 1 year",
  "amount": 1000,
  "currency": "EUR",
  "intervalUnit": "Month",
  "intervalCount": 1,
  "billingCycles": 12,
  "trialPeriod": 7,
  "isConversionRateFixed": true,
   "status": "Inactive",
  "created": "2016-12-01T09:42:25.207Z",
  "cancelSubscriptions": false
}

You can deactivate a plan, with an option to either cancel all associated subscriptions or leaving all associated subscription to be active until they expire. Please keep in mind, you need to pass cancelSubscriptions parameter.

ATTRIBUTES

Parameter Type Description Requirement
cancelSubscriptions boolean Option to either cancel all associated subscriptions or not. Can be true or false Mandatory

Update a Plan

curl https://api.alternativepayments.com/api/plans/pln_7021187813bb -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X PUT -d '
{
      "name": "Gold One Year",
      "description": "Monthly subscription to Gold One Year Plan - for one year!"
}'

The above command returns JSON structured like this:

{
  "id": "pln_7021187813bb",
  "mode": "Test",
  "name": "Gold One Year",
  "description": "Monthly subscription to Gold One Year Plan - for one year!",
  "amount": 1000,
  "currency": "EUR",
  "intervalUnit": "Month",
  "intervalCount": 1,
  "isConversionRateFixed": true,
  "created": "2016-12-01T12:56:35.09Z",
  "cancelSubscriptions": false
}

You can edit existing plan, but you can only edit name and description. If you want to edit, for example, amount, you must create a new plan and subscribe your customers to it.

ATTRIBUTES

Parameter Type Description Requirement
name string User-friendly label for the plan Optional
description string User-friendly description (verbose) Optional

Retrieve a Plan

curl https://api.alternativepayments.com/api/plans/pln_7021187813bb -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X GET -d

The above command returns JSON structured like this:

{
  "id": "pln_7021187813bb",
  "mode": "Test",
  "name": "Gold One Year",
  "description": "Monthly subscription to Gold One Year Plan - for one year!",
  "amount": 1000,
  "currency": "EUR",
  "intervalUnit": "Month",
  "intervalCount": 1,
  "isConversionRateFixed": true,
  "created": "2016-12-01T12:56:35.09Z",
  "ipAddress": "123.01.1"
}

You can retrieve plan information in the API request.

Create Subscription

curl https://api.alternativepayments.com/api/subscriptions -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
  "payment": {
    "holder": "John Doe",
    "paymentOption": "SEPA",
    "iban": "DE8937040xxxxx13000"
  },
  "customer": {
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "DE"
  },
  "planId": "pln_41cd17a5fe13",
  "ipAddress": "123.01.1",
  "quantity": 2,
  "phoneverification":{
    "token":"1d91d2083c5d4xxxbb424798c2fafdca",
    "pin":"9411"
    }
}

The above command returns JSON structured like this:

{
  "id": "sbs_e71bbe5375af",
  "mode": "Test",
  "planId": "pln_7021187813bb",
  "customerId": "cus_5210f6ee95c445f5a",
  "customer": {
    "id": "cus_5210f6ee95c445f5a",
    "mode": "Test",
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "DE",
    "created": "2016-12-01T10:40:34.258387Z"
  },
  "payment": {
    "id": "pay_7c3a29e41fba4171a",
    "mode": "Test",
    "paymentOption": "sepa",
    "holder": "John Doe",
    "iban": "NL02XXXXX9585",
    "bic": "ABNANL2AXXX",
    "created": "2016-12-01T10:40:34.2243803Z"
  },
  "amount": 0,
  "isConversionRateFixed": false,
  "quantity": 2,
  "currentBillingCycle": 0,
  "ipAddress": "123.01.1",
  "status": "Trial",
  "created": "2016-12-01T10:40:34.3693928Z",
  "phoneVerification": {
    "pin": "1212",
    "token": "1d91d2083c5dxxxx24798c2fafdca"
  }
}

After creating a plan and collecting customer’s data, next step is to subscribe customers to plans.

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Customer’s First Name Mandatory
lastName string Customer’s Last Name Mandatory
email string Customer’s Email Mandatory
address string Customer’s address - Street Name Optional
address2 string Customer’s address - Street Number Optional
city string Customer’s city Optional
zip string Customer’s city Postal Code Optional
state string Customer’s state - 2 letter code Optional
country string Customer’s country - ISO1 country Code Mandatory
birthday date Customer’s birthday - MM/DD/YYYY Optional
phone string Customer’s phone Number Optional

PAYMENT OBJECT

Parameter Type Description Requirement
paymentOption string sepa Mandatory
holder string Customer’s First and Last Name Mandatory
iban string customer’s IBAN code Mandatory

PHONE VERIFICATION OBJECT

Parameter Type Description Requirement
token string generated token Mandatory
pin string pin code received by SMS Mandatory

Retrieve a Subscription

curl https://api.alternativepayments.com/api/subscriptions/sbs_b9a2ba8b8285 -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X GET -d '
'

The above command returns JSON structured like this:

{
  "id": "sbs_b9a2ba8b8285",
  "mode": "Test",
  "planId": "pln_e06119d1c5ab",
  "plan": {
    "id": "pln_e06119d1c5ab",
    "mode": "Test",
    "name": "Gold Unlimited",
    "description": "Monthly subscription to Gold Plan - 1 year",
    "amount": 1000,
    "currency": "EUR",
    "intervalUnit": "Month",
    "intervalCount": 1,
    "billingCycles": 12,
    "trialPeriod": 7,
    "isConversionRateFixed": true,
    "status": "Active",
    "ipAddress": "123.01.1",
    "created": "2016-12-01T13:25:53.797Z",
    "cancelSubscriptions": false
  },
  "customerId": "cus_f2043b2a4d7f4da99",
  "customer": {
    "id": "cus_f2043b2a4d7f4da99",
    "mode": "Test",
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "created": "2016-12-01T13:26:03.363Z"
  },
  "paymentId": "pay_aa3xd2cd1aaa49528",
  "payment": {
    "id": "pay_aa33d2cd1aaa49528",
    "mode": "Test",
    "holder": "John Doe",
    "created": "2016-12-01T13:26:03.34Z"
  },
  "amount": 2000,
  "currency": "EUR",
  "isConversionRateFixed": true,
  "quantity": 2,
  "trialEndDate": "2016-12-08T13:26:03.417Z",
  "nextRecurringDate": "2016-12-08T13:26:03.417Z",
  "currentBillingCycle": 0,
  "ipAddress": "123.01.1",
  "status": "Trial",
  "created": "2016-12-01T13:26:03.417Z"
}

You can retrieve subscription information in the API request.

Cancel a Subscription

curl https://api.alternativepayments.com/api/subscriptions/sbs_b9a2ba8b8285 -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X DELETE -d '
{
    "CancelationReason":"END_USER_ERROR"
}

The above command returns JSON structured like this:

{
    "id": "sbs_a31ba70dcb4e",
    "mode": "Live",
    "planId": "pln_19f8cab8a077",
    "plan": {
        "id": "pln_19f8cab8a077",
        "mode": "Live",
        "name": "Payment Plan Name",
        "description": "Payment Plan Description",
        "amount": 1,
        "currency": "EUR",
        "intervalUnit": "Day",
        "intervalCount": 1,
        "billingCycles": 365,
        "trialPeriod": 0,
        "isConversionRateFixed": true,
        "status": "Active",
        "created": "2021-10-05T13:40:09.037Z",
        "cancelSubscriptions": false
    },
    "customerId": "cus_c636c5c2ac974ad29",
    "customer": {
        "id": "cus_c636c5c2ac974ad29",
        "mode": "Live",
        "firstName": "John",
        "lastName": "Doe",
        "email": "john@doe.com",
        "created": "2021-10-22T12:48:43.837Z"
    },
    "paymentId": "pay_18133c15b8d04b1da",
    "payment": {
        "id": "pay_18133c15b8d04b1da",
        "mode": "Live",
        "customerId": "cus_c636c5c2ac974ad29",
        "paymentOption": "SEPA",
        "holder": "John Doe",
        "created": "2021-10-22T12:48:43.83Z",
        "mandateID": "bcb592dcb5fc4b",
        "mandateDateOfSignature": "10/22/2021"
    },
    "amount": 6,
    "currency": "EUR",
    "isConversionRateFixed": true,
    "quantity": 6,
    "intervalStartDate": "2021-10-22T12:48:43.85Z",
    "nextRecurringDate": "2021-10-23T12:48:43.85Z",
    "currentBillingCycle": 1,
    "ipAddress": "123.01.1",
    "status": "Canceled",
    "created": "2021-10-22T12:48:43.85Z"
}

You can cancel a existing active subscription via API request.

Hosted Page

You can create the transaction using our hosted page. When the transaction is created, you will receive redirect URL in redirectUrl, on which your customer should be redirected and where payment option can be selected to complete the payment.

Create Transaction

curl https://api.alternativepayments.com/api/transactions/hosted -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
   "Customer":{
    "FirstName":"John",
    "LastName":"Doe",
    "Email":"john@doe.com",
    "Country":"NL"
   },
   "Amount":200,
   "Currency":"EUR",
   "ipAddress":"123.01.1",
   "RedirectUrls":{
       "returnUrl": "http://alternativepayments.com/message/success.html",
       "cancelUrl": "http://alternativepayments.com/message/failure.html"
    }
}'

The above command returns JSON structured like this:

{
  "id": "trn_6a013b5221a7",
  "mode": "Test",
  "status": "Created",
  "customer": {
    "id": "cus_aacd0143efd349dd9",
    "mode": "Test",
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "NL",
    "created": "2017-04-03T14:18:24.1812715Z"
  },
  "amount": 200,
  "currency": "EUR",
  "created": "2017-04-03T14:18:24.2332783Z",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  },
  "redirectUrl": "https://checkout.alternativepayments.com/payment?id=8bf6dcxxxxxxxxxxxx8bdbb2",
  "ipAddress": "123.01.1"
}

To create the transaction using hosted page option you must send required parameters, which also include price, amount, customer’s email and customer’s country. They can’t be changed later on the hosted page.

We also give you the possibility of using a hosted page with previously set payment option on the initial API request. Please keep in mind, if the payment option is sent in the payment object, it cannot be changed later on the hosted page.

ATTRIBUTES

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Sender’s First Name Mandatory
lastName string Sender’s Last Name Mandatory
email string Sender’s Email Mandatory
country string Sender’s country - ISO1 country Code Mandatory
Parameter Type Description Requirement
amount integer The used amount (calculated in cents) Mandatory
currency string ISO 4217 formatted currency code Mandatory
ipAddress string Customer’s IP address Mandatory
merchantPassThruData string Merchant’s Identification Optional *Originating URL is required to be sent if you are an IPSP or service provider
returnUrl string url that customer is redirected to after successful payment Mandatory
cancelUrl string url that customer is redirected to on aborted payment Mandatory
paymentOption string Payment Option Optional

Create Subscription

curl https://api.alternativepayments.com/api/subscriptions/hosted -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
   "planId":"pln_41cd17a123",
   "quantity":1,
   "customer":{
      "firstName":"John",
      "lastName":"Doe",
      "email":"john@doe.com",
      "country":"DE",
      "city":"City12",
      "zip":"1007",
      "address":"address line 1",
      "address2":"address line 2"
   },
   "ipAddress":"123.01.1",
   "redirectUrls":{
      "returnUrl":"http://alternativepayments.com/message/success.html",
      "cancelUrl":"http://alternativepayments.com/message/failure.html"
   },
   "merchantPassThruData":"merchant data",
   "payment":{
      "mandateId":"1234",
      "mandateDateOfSignature":"09/08/2020"
   }
}'

The above command returns JSON structured like this:

{
   "id":"sbs_e71bb123",
   "mode":"Test",
   "planId":"pln_7021187813bb",
   "amount":100,
   "currency":"EUR",
   "isConversionRateFixed":false,
   "quantity":1,
   "ipAddress":"123.01.1",
   "created":"2020-12-01T10:40:34.3693928Z",
   "customer":{
      "firstName":"John",
      "lastName":"Doe",
      "email":"john@doe.com",
      "country":"DE",
      "address":"address line 1",
      "address2":"address line 2"
   },
   "redirectUrls":{
      "returnUrl":"http://alternativepayments.com/message/success.html",
      "cancelUrl":"http://alternativepayments.com/message/failure.html"
   },
   "redirectUrl":"https://checkout.alternativepayments.com/subscription?id=8bf6dcxxxxxxxxxxxx8bdbb2",
   "merchantPassThruData":"custom data"
}

To create the subscription using the hosted page you must send required parameters, such as customer’s email, payment plan identification code and customer’s IP address. Optional parameters can be later changed on the hosted page.

ATTRIBUTES

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Senders First Name Optional
lastName string Senders Last Name Optional
email string Senders Email Optional
country string Senders country - ISO1 country Code Optional
city string Senders city Optional
zip string Secondary zip code Optional
address string Senders address line Optional
address2 string Secondary senders address line Optional

PAYMENT OBJECT

Parameter Type Description Requirement
mandateId string Unique mandate identifier Optional
mandateDateOfSignature string Mandate signature date Optional
Parameter Type Description Requirement
planId string A unique payment plan identifier Mandatory
quantity integer Amount of items in related subscription Optional
customer obejct Object that contains customer data Optional
ipAddress string Customer’s IP address Mandatory
merchantPassThruData string Merchant’s Identification Optional *Originating URL is required to be sent if you are an IPSP or service provider
returnUrl string url that customer’s is redirected to after successful payment Mandatory
cancelUrl string url that customer’s is redirected to on aborted or failed payment Mandatory
payment object url that customer is redirected to on aborted or failed payment Optional

DPMax - Open Banking

Introduction

DPMax represents our dedication to continue providing our clients with the best in class service based on the PSD2 Open Banking concept. With “Pay by Bank” functionality, customers can seamlessly initiate payments upon purchase, directly debiting funds from their accounts. DPMax stands out as the optimal choice for businesses seeking maximum coverage and redundancy, leveraging the advantages of Open Banking

Creating DPMax transaction

There are 3 options for creating DPMax transaction: Checkout page, Widget and custom UI

Using Checkout page

curl https://api.alternativepayments.com/api/transactions/hosted -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
   "Customer":{
    "FirstName":"John",
    "LastName":"Doe",
    "Email":"john@doe.com",
    "Country":"NL"
   },
   "payment" : {
    "paymentOption":"DirectPayMax"
   },
   "Amount":200,
   "Currency":"EUR",
   "ipAddress":"123.01.1",
   "RedirectUrls":{
       "returnUrl": "http://alternativepayments.com/message/success.html",
       "cancelUrl": "http://alternativepayments.com/message/failure.html"
    }
}'

The above command returns JSON structured like this:

{
  "id": "trn_6a013b5221a7",
  "mode": "Test",
  "status": "Created",
  "customer": {
    "id": "cus_aacd0143efd349dd9",
    "mode": "Test",
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "NL",
    "created": "2017-04-03T14:18:24.1812715Z"
  },
  "amount": 200,
  "currency": "EUR",
  "created": "2017-04-03T14:18:24.2332783Z",
  "redirectUrls": {
    "returnUrl": "http://alternativepayments.com/message/success.html",
    "cancelUrl": "http://alternativepayments.com/message/failure.html"
  },
  "redirectUrl": "https://checkout.alternativepayments.com/payment?id=8bf6dcxxxxxxxxxxxx8bdbb2",
  "ipAddress": "123.01.1"
}

Authentication

You can create the transaction using our hosted page. When the transaction is created, you will receive redirect URL in redirectUrl, on which your customer should be redirected.

ATTRIBUTES

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Sender’s First Name Mandatory
lastName string Sender’s Last Name Mandatory
email string Sender’s Email Mandatory
country string Sender’s country - ISO1 country Code Mandatory

PAYMENT OBJECT

Parameter Type Value Description Requirement
paymentOption string DirectPayMax Payment Option Mandatory
Parameter Type Description Requirement
amount integer The used amount (calculated in cents) Mandatory
currency string ISO 4217 formatted currency code Mandatory
ipAddress string Customer’s IP address Mandatory
merchantPassThruData string Merchant’s Identification Optional *Originating URL is required to be sent if you are an IPSP or service provider
returnUrl string url that customer is redirected to after successful payment Mandatory
cancelUrl string url that customer is redirected to on aborted payment Mandatory

Using Widget

SDK available for widget: dotNet, Java, Python, Ruby, PHP

PHP SDK Setup

Install

After creating a test account download and extract ap-php-sdk to your server from the link - ap-php-sdk

API keys

Locate the ap-php-sdk/AlternativePayments.php file and insert your Public and Secret API keys. You must insert your API keys. After the registration process you will be provided with the API Test Keys and API Production Keys, the parameters needed to start accepting payments through our payment system.

NOTE: Production API Keys are avaliable once you are verified, and are used to proccess live transactions.

Include the following code to your page

Insert the script below before the opening tag of your webpage, ie
<!DOCTYPE html>
<html>

<?php require_once 'ap-php-sdk/AlternativePayments.php';
$product_data = (object) array(
'currency' => "USD";
'amount' => "125.00";
'productDescription' => "Red T-shirt";
'formPost' => isset($_POST) ? $_POST : '',
'successUrl' => "https://alternativepayments.com/message/success.html";
'cancelUrl' => "https://alternativepayments.com/message/failure.html";
);
$transaction_status = $AlternativePayments->transaction($product_data);
?>

If Windows hosting and using SSL

After line 178 in ap-php-sdk/lib/AlternativePayments/request.php you will see:

$curl = curl_init($url);
/* Begin windows ssl line. This next line is for windows ssl. remove if not on windows using ssl */
/* curl_setopt($curl, CURLOPT_CAINFO, 'C:\Program Files(x86)\PHP\v5.6\extras\ssl\curl-ca-bundle.crt'); */
/* end windows using ssl */

Line 180 needs to be enabled and pointing to your .crt file if you are in a Windows hosting environment and using SSL.

Webpage Setup

Insert the scripts below before the closing tag of your webpage:

<script> var AP_BUTTONS = ['PaymentButton1']; </script>
<script src="https://widget.alternativepayments.com/v2AP/js/payment-button.js" type="text/javascript"></script>

You are required to embed the payment widget code to your page:

<form method="post">
<div
data-ap-amount="<?php echo $product_data->amount; ?>"
data-ap-button-text="Pay using Alternative Payments Widget"
data-ap-company-name="YourCompanyName"
data-ap-currency="<?php echo $product_data->currency; ?>"
data-ap-description="<?php echo $product_data->productDescription; ?>"
data-ap-extra="Additional description"
data-ap-public-key="<?php echo $AlternativePayments->getPublicKey(); ?>"
data-ap-setup="SET_FORM_VALUES"
data-ap-paymentoption="directpaymax"
id="PaymentButton1">
</div>
</form>

Using Custom UI

For custom UI, direct API call should be used:

DpMax API call

List of Institutions

In order to process DPMax transactions by using personalized UI, it is possible to retrieve a list of supported institutions with important parameters for these institutions (for example: Is PsuId required and in which format it is)

Get List of Institutions by country ISO code
curl https://api.alternativepayments.com/api/institutions/getInstitutionsForCountry/{countryIsoCode} -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X GET'

The above command returns JSON structured like this:

{
    "institutions": [
        {
            "id": 7,
            "name": "Unicajabanco",
            "code": "UCJAES2MXXX",
            "isPSUIdRequired": false
        },
        {
            "id": 7,
            "name": "CAJA DUERO",
            "code": "UCJAES2MXXX",
            "isPSUIdRequired": false
        }
    ...
  ]
}

This endpoint will return all available institutions for specific country

Processing the transaction

For processing the transaction RedirectUrl parameter from API response should be used

Preauthorization

Create preauthorization

curl https://api.alternativepayments.com/api/preauthorizations -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
   "customer":{
     "firstName":"John",
     "lastName":"Doe",
     "email":"john@doe.com",
     "country":"US"
   },
   "payment":{
     "paymentOption":"creditcard",
     "holder":"John Doe",
     "creditCardNumber":"4111111111111111",
     "creditCardType":"visa",
     "CVV2":"222",
     "expirationYear":"2019",
     "expirationMonth":"12"
   },
   "amount":1500,
   "currency":"EUR"
}'

The above command returns JSON structured like this:

{
  "id": "preauth_ee146f5315",
  "mode": "Test",
  "status": "Approved",
  "customer": {
    "id": "cus_67c05d47ed624db9b",
    "mode": "Test",
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "US",
    "created": "2016-05-19T08:20:47.771416Z"
  },
  "payment": {
    "id": "pay_d893e7074c6441349",
    "mode": "Test",
    "paymentOption": "creditcard",
    "creditCardType":"visa",
    "holder": "John Doe",
    "created": "2016-05-19T08:20:47.7549104Z",
    "creditCardNumber": "XXXXXXXXXXX1111",
    "expirationMonth": 12,
    "expirationYear": 2019
  },
  "amount": 1500,
  "currency": "EUR",
  "created": "2016-05-19T08:20:47.7679118Z"
}

For payment options that support this (like Credit Card), you can reserve the amount from the client’s credit card, and later execute sale transaction itself. First, you will need to create preauth transaction, and after receiving transaction.approved event from that preauth transaction, capture full amount of that preauthorized transaction.

PAYMENT OBJECT

Parameter Type Description Requirement
paymentOption string Payment Option Mandatory
holder string Customer’s First and Last Name Mandatory
creditCardNumber string Customer’s CC number Mandatory
CVV2 string Credit Card CVV2 number Mandatory
expirationYear integer Expiry year of the credit card Mandatory
expirationMonth integer Expiry month of the credit card Mandatory
creditCardType string Type of credit card Mandatory

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Customer’s First Name Mandatory
lastName string Customer’s Last Name Mandatory
email string Customer’s Email Mandatory
address string Customer’s address - Street Name Optional
address2 string Customer’s address - Street Number Optional
city string Customer’s city Optional
zip string Customer’s city Postal Code Optional
state string Customer’s state - 2 letter code Optional
country string Customer’s country - ISO1 country Code Mandatory
birthday date Customer’s birthday - MM/DD/YYYY Optional
phone string Customer’s phone Number Optional

Capturing preauthorization


curl https://api.alternativepayments.com/api/transactions -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
   "customer":{
      "firstName":"John",
      "lastName":"Doe",
      "email":"john@doe.com",
      "country":"US"
   },
   "Preauthorization": "preauth_ee146f5315",
   "amount":1500,
   "currency":"EUR"
}'

The above command returns JSON structured like this:

{
  "id": "trn_f7cb2b6631",
  "mode": "Test",
  "status": "Funded",
  "customer": {
    "id": "cus_ecaec09a0776434ea",
    "mode": "Test",
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "US",
    "created": "2016-05-19T08:18:51.1610893Z"
  },
  "payment": {
    "id": "pay_b8bc6359ef1b4e4da",
    "mode": "Test",
    "paymentOption": "creditcard",
    "holder": "John Doe",
    "created": "2016-05-19T08:18:51.1298382Z",
    "creditCardNumber": "XXXXXXXXXXX1111",
    "expirationMonth": 12,
    "expirationYear": 2019
  },
  "amount": 1500,
  "currency": "EUR",
  "created": "2016-05-19T08:18:51.1610893Z",
  "preauthorization": "preauth_ee146f5315"
}

When preauthorization transaction is made, you must use its id to capture amount previously reserved. For preauthorization transaction, you will receive transaction.approved event to indicate when the amount can be captured.

CUSTOMER OBJECT

Parameter Type Description Requirement
firstName string Customer’s First Name Mandatory
lastName string Customer’s Last Name Mandatory
email string Customer’s Email Mandatory
address string Customer’s address - Street Name Optional
address2 string Customer’s address - Street Number Optional
city string Customer’s city Optional
zip string Customer’s city Postal Code Optional
state string Customer’s state - 2 letter code Optional
country string Customer’s country - ISO1 country Code Mandatory
birthday date Customer’s birthday - MM/DD/YYYY Optional
phone string Customer’s phone Number Optional

Tokens

If you want to process transactions or collect personally identifiable information without having to store locally sensitive data on your server, you can use the tokenization process. If you’re accepting credit cards, tokenization must be used to be PCI compliant.

You can create tokens using your Public API key. They should not be stored, and they can not be re-used. To re-use payment information, please see Payment Object section.

Create Token

curl https://api.alternativepayments.com/api/tokens -u \
<WEBSITE_PUBLIC_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
  "paymentOption":"creditcard",
  "holder":"John Doe",
  "creditCardNumber":"4111111111111111",
  "CVV2":"222",
  "creditCardType":"visa",
  "expirationYear":"2019",
  "expirationMonth":"12"
}

The above command returns JSON structured like this:

{
  "token": "VCtKKZza00g/3JjExts6S72GrVDxPfYG",
  "created": "2016-09-12T07:35:39.7618727Z"
}

Creates a single-use token that wraps the details of a payment information, and can be used only once.

Parameter Type Description Requirement
paymentOption string Payment Option Mandatory
holder string Customer’s First and Last Name Mandatory
CC number, cvv2, IBAN, etc. string payment/bank information - depending on paymentOption Mandatory

Creating Transaction

curl https://api.alternativepayments.com/api/transactions -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
   "customer":{
      "firstName":"John",
      "lastName":"Doe",
      "email":"john@doe.com",
      "country":"US"
   },
   "amount":1500,
   "currency":"EUR",
   "ipaddress": "123.01.1",
   "token": "VCtKKZza00g/3JjExts6S72GrVDxPfYG"
}

The above command returns JSON structured like this:

{
  "id": "trn_b0d0c2716215",
  "mode": "Test",
  "status": "Funded",
  "customer": {
    "id": "cus_fec53db887ef402ba",
    "mode": "Test",
    "firstName": "John",
    "lastName": "Doe",
    "email": "john@doe.com",
    "country": "US",
    "created": "2016-09-11T23:35:24.4821996Z"
  },
  "payment": {
    "id": "pay_56510f9a22634ae08",
    "mode": "Test",
    "paymentOption": "creditcard",
    "holder": "John Doe",
    "created": "2016-09-11T23:35:24.3981701Z",
    "creditCardType": "visa",
    "creditCardNumber": "XXXXXXXXXXX1111",
    "expirationMonth": 12,
    "expirationYear": 2019,
    "cvV2": "222"
  },
  "amount": 1500,
  "currency": "EUR",
  "created": "2016-09-11T23:35:24.445176Z",
  "token": "VCtKKZza00g/3JjExts6S72GrVDxPfYG",
  "ipAddress": "123.01.1"
}

To create a transaction using a token, you must send customer object, amount, currency and token that was received.

Parameter Type Description Requirement
customer Customer object Customer object Mandatory
holder string Customer’s First and Last Name Mandatory
currency string ISO 4217 formatted currency code Mandatory
amount integer The used amount (calculated in cents) Mandatory
token string Payment token Mandatory

Customers

Create a Customer

curl https://api.alternativepayments.com/api/customers -u \
<WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X POST -d '
{
  "firstName": "John",
  "lastName": "Doe",
  "email": "john@doe.com",
  "address": "Rutledge Ave 409",
  "city": "Folsom",
  "zip": "19033",
  "country": "US",
  "state":"PA",
  "phone": "55555555555"
}
$customer = new \AlternativePayments\Model\Customer();
$customer->setEmail("testsdfsd@gmail.com");
$customer->setcountry("DE");
$customer->setFirstName("Steve");
$customer->setLastName("McManaman");
$customer->setIp("192.168.100.100");
$res = Customer :: post($customer);
AlternativePayments.ApiUrl = _apiUrl;

Customer c = new Customer()
{
    FirstName = "Tname1",
    LastName = "Lname1",
    Email = "mymail1@email.com",
    Ip = "123.01.1",
    state = "DE"
};

var result = AlternativePayments.Post<Customer>(c).Result;

The above command returns JSON structured like this:

{
  "id": "cus_bd838e3611d34d598",
  "mode": "Test",
  "firstName": "John",
  "lastName": "Doe",
  "email": "john@doe.com",
  "address": "Rutledge Ave 409",
  "city": "Folsom",
  "zip": "19033",
  "country": "US",
  "state": "PA",
  "phone": "55555555555",
  "created": "2016-03-24T15:19:10.7800694Z"
}

Customers can be created individually by you or they will be automatically generated with the transaction if there is no customer ID transmitted.

Attributes

Parameter Type Description Requirement
firstName string First name Mandatory
lastName string Last name Mandatory
email string Email Mandatory
address string address Optional
city string city Optional
zip string city ZIP code Optional
country string country Optional
state string state Optional
phone string phone number Optional

Retrieve a Customer

Retrieves the details of an existing customer.

curl https://api.alternativepayments.com/api/customers/{id} \
-u <WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X GET -d '
$res = Customer :: get("cus_123456aaa");
AlternativePayments.ApiUrl = _apiUrl;

var result = AlternativePayments.Get<Customer>("cus_nonprofitaaa").Result;

The above command returns JSON structured like this:

{
  "id": "cus_bd838e3611d34d598",
  "mode": "Test",
  "firstName": "John",
  "lastName": "Doe",
  "email": "john@doe.com",
  "address": "Rutledge Ave 409",
  "city": "Folsom",
  "zip": "19033",
  "country": "US",
  "state": "PA",
  "phone": "55555555555",
  "created": "2016-03-24T15:19:10.7800694Z"
}

Attributes

Parameter Type Description Requirement
id string Customer’s id Mandatory

List Customers

Returns a list of your customers.

curl https://api.alternativepayments.com/api/customers \
-u <WEBSITE_SECRET_KEY>:  -H "Content-Type:application/json" -X GET -d
$res = Customer :: getAll();
AlternativePayments.ApiUrl = _apiUrl;
var result = AlternativePayments.GetAll<Customer>().Result;

The above command returns JSON structured like this:

{
    "customers": [
        {
            "id": "cus_7f0724f3b1d745d49",
            "mode": "Test",
            "firstName": "Jane",
            "lastName": "Doe",
            "email": "jane@doe.com",
            "country": "DE",
            "created": "2015-06-24T11:46:35.303Z"
        },
        {
            "id": "cus_15b154da474247dbb",
            "mode": "Test",
            "firstName": "John",
            "lastName": "Doe",
            "email": "john@doe.com",
            "address": "Rutledge Ave 409",
            "city": "Folsom",
            "zip": "19033",
            "country": "US",
            "phone": "55555555555",
            "created": "2015-06-24T12:28:06.527Z"
        }
    ]
}

Errors

Attributes

type Description
invalid_parameter_error Invalid paremeter was sent
payment_error Transaction failed to be created due to payment issue
api_error API errors

List of errors for invalid_paremeter_error

Code Message Status Code
api_keys_not_provided API keys are not provided 401
invalid_api_keys Invalid API key %s 401
invalid_object_sent Object is not sent or invalid object is sent 400
missing_required_parameter Missing required parameter %s 400
invalid_parameter_error Invalid parameter %s 400
disabled_website Disabled website 400
invalid_website Invalid website 400
invalid_transaction_id Invalid transaction 400
invalid_original_transaction_id Invalid transaction 400
invalid_payment_id Invalid payment id 400
invalid_customer_id Invalid customer id 400
invalid_reason Invalid reason 400
provide_payment_or_token Provide either payment object or token 400
provide_customer_or_customerid Provide either customer object or customerid 400
invalid_payment_option Invalid payment option 400
invalid_iban Invalid IBAN 400
invalid_bic Invalid BIC 400
invalid_currency Invalid currency 400
negative_number Must be positive number 400
pin_not_sent Pin must be sent 400
email_domain_black_listed Email domain is found on the black list 400
information_on_black_list Information sent on the transaction are found on the blacklist 400
customer_black_listed Customer is found on the black list 400
number_of_transaction_exceeded_limit Number of the transactions exceeded limit 400
volume_of_transaction_exceeded_limit Volume of the transactions exceeded limit 400
max_transaction_amount Volume of the transactions is higher then maximum limit 400
min_transaction_amount Volume of the transactions is lower then minimum limit 400
invalid_country Invalid country 400
parameter_can_have_100_characters_maximum Parameter %s can have 100 characters maximum. 400
payment_option_is_not_active Payment option is not active. 503
cpf_name_and_birthdate_do_not_match CPF does not belong to the person making the payment. 400
customer_reached_payment_limit Customer reached the payment limit for the period. 400
currency_is_not_active_in_system Currency is not active in the system. 400
currency_is_not_active_in_system Currency is not active in the system. 400

List of errors for payment_error

Code Message Status Code
void_not_supported Void is not supported 402
refund_not_supported Refund is not supported 402
transaction_can_not_be_refunded The transaction can not be refunded 402
refund_already_sent Refund already sent 402
void_already_sent Void already sent 402
transaction_can_not_be_voided Transaction can not be voided 402
customer_must_be_at_least_16_years_old Customer must be at least 16 years old 402
bank_unknown Bank unknown. 400
transaction_timeout Timeout 408
transaction_aborted Transaction aborted by user. 400

List of errors for api_error

Code Message Status Code
api_error API Error 402
acquirer_down Acquirer Down 402
statuscode Description
200 OK - Everything worked as expected.
400 Bad Request - Usually missing a required parameter.
401 Unauthorized - No valid API key provided.
402 Request Failed - Parameters were valid but request failed.
404 Not Found - The requested item doesn’t exist.
500 Server errors - internal server error.