API Reference | PHP

Intro

The Openpay API is designed on REST, therefore you’ll find that URLs are oriented to resources and that HTTP response codes are used to indicate errors in the API.

All the API responses are in JSONformat, including the errors.

In the case to use the existents Openpay API clients (Java, Php, C#, Python, Ruby, NodeJS), the responses are specifically of type defined in the clients and their respective languajes.

API Endpoints

Available resourcers

a) By Merchant

/v1/{MERCHANT_ID}/...

/fees
/fees/{FEE_ID}
/charges
/charges/{TRANSACTION_ID}
/payouts
/payouts/{TRANSACTION_ID}
/cards
/cards/{CARD_ID}
/customers
/customers/{CUSTOMER_ID}
/plans
/plans/{PLAN_ID}
​/tokens
/tokens/{TOKEN_ID}

b) By Customer

/v1/{MERCHANT_ID}/customers/{CUSTOMER_ID}/...

/cards
/cards/{CARD_ID}
/bankaccounts
/bankaccounts/{BANKACCOUNT_ID}
/charges
/charges/{TRANSACTION_ID}
/payouts
/payouts/{TRANSACTION_ID}
/transfers
/transfers/{TRANSACTION_ID}
/subscriptions
/subscriptions/{SUBSCRIPTION_ID}

The Openpay REST API has a test environment (sandbox) and a production environment. For integrating your system with Openpay, use the credentials that were generated when you signed up. Once you are ready to move to production environment and your request is approved, new credentials will be generated for accessing the production environment.

The following URIs are the basis of the endpoints for the supported environments:

  • Testing, URI base:
    Production:
  • Production, URI base:
    https://api.openpay.mx

A complete endpoint consists of the base URI of the environment, the identifier of the Merchant and the resource.

For example, if we want to create a new customer, the endpoint would be:

POST https://sandbox-api.openpay.mx/v1/mzdtln0bmtms6o3kck8f/customers

In order to create a complete request is necessary to send the right HTTP headers and the information in JSON format.

Authentication

Authentication example

<? 
//Por default se usa el ambiente de sandbox
$openpay = Openpay::getInstance('moiep6umtcnanql3jrxp', 'sk_3433941e467c4875b178ce26348b0fac'); 
?>

Production

<? 
Openpay::setProductionMode(true); 
?>

To make requests to the Openpay API, is necessary to send the API Key on all your calls to our servers. You can get the key from the dashboard.

There are 2 types of API keys:

  • Private.- For calls between servers and full access to all API operations (should never be shared).
  • Public.- should only be used in JavaScript calls. This key is only allowed to create cards or create tokens.

For API authentication you must use the basic access authentication, where the API key is the username. The password is not required and it should be left blank for purposes of simplicity

Errors

Openpay returns JSON objects in the service responses.

Error Object

Object example

{
    "category" : "request",
    "description" : "The customer with id 'm4hqp35pswl02mmc567' does not exist",
    "http_code" : 404,
    "error_code" : 1005,
    "request_id" : "1981cdb8-19cb-4bad-8256-e95d58bc035c",
    "fraud_rules": [
        "Billing <> BIN Country for VISA/MC"
    ]
}
PropertyDescription
categorystring
request: It means an error caused by data sent by the customer. For example, an invalid request, an attempt of a transaction without funds or a transfer to an account that does not exist.internal: It means an error on the Openpay side, this will occur very rarely.

gateway: It means an error during the transaction of funds from one card to the Openpay account or from the to a bank account or card.

error_codenumeric
This is the Openpay error code.
descriptionstring
Error description.
http_codestring
HTTP error code from the response.
request_idstring
Request identifier
fraud_rulesarray
Array with antifraud rules broken according to fraud detection rules.

Error codes

General

CodeHTTP ErrorCause
1000500 Internal Server ErrorAn error happened in the internal Openpay server.
1001400 Bad RequestThe request is not JSON valid format, the fields don’t have the correct format, or the request doesn’t have the required fields.
1002401 UnauthorizedThe request is not authenticated or is incorrect.
1003422 Unprocessable EntityThe operation could not be completed because the value of one or more of the parameters is incorrect.
1004503 Service UnavailableA required service is not available.
1005404 Not FoundA required resource doesn’t exist.
1006409 ConflictThere is already a transaction with the same ID order.
1007402 Payment RequiredThe funds transfer between the bank account or card and the Openpay account was rejected.
1008423 LockedOne of the required accounts is deactivated.
1009413 Request Entity too largeThe request body is too large.
1010403 ForbiddenThe public key is being used to make a request that requires the private key, or the private key is being using from Javascript.

Storage

CodeHTTP ErrorCause
2001409 ConflictThe bank account already exists.
2002409 ConflictThe card with this number is already registered on the customer.
2003409 ConflictThe external_id already exists.
2004422 Unprocessable EntityThe check digit card number is invalid according to the Luhn algorithm.
2005400 Bad RequestThe expiration date has expired.
2006400 Bad RequestThe CVV2 security code is required.
2007412 Precondition FailedThe card number is only valid in sandbox.
2008412 Precondition FailedThe consulted card is not valid for points.
2009412 Precondition FailedThe card security code (CVV2) is not valid.

Cards

CodeHTTP ErrorCause
3001402 Payment RequiredCard declined.
3002402 Payment RequiredCard is expired.
3003402 Payment RequiredCard has not enough funds.
3004402 Payment RequiredCard has been flagged as stolen.
3005402 Payment RequiredThe card has been identified as a fraudulent card.
3006412 Precondition FailedThe operation is not allowed for this customer or transaction.
3008412 Precondition FailedThe card is not supported in online transactions.
3009402 Payment RequiredCard has been flagged as lost.
3010402 Payment RequiredThe card has been restricted by the bank.
3011402 Payment RequiredThe bank has requested to hold this card. Please contact the bank.
3012412 Precondition FailedBank authorization is required to make this payment.

Accounts

CodeHTTP ErrorCause
4001412 Preconditon FailedThe Openpay account doesn’t have enough funds.

Charges

Charges can be made to cards, stores and banks. Each charge is assigned with an unique identifier in the system.

You can do card charges by using a saved card id, using a token or you can send the card information at the time of invocation.

With a card id or token

Definition

<?
Comercio
$openpay->charges->create(chargeRequest);

Cliente
$customer = $openpay->customers->get($customerId);
$customer->charges->create(chargeRequest);
?>

Merchant request example

<?
$openpay = Openpay::getInstance('mzdtln0bmtms6o3kck8f', 'sk_e568c42a6c384b7ab02cd47d2e407cab');
$customer = array(
     'name' => 'Juan',
     'last_name' => 'Vazquez Juarez',
     'phone_number' => '4423456723',
     'email' => 'juan.vazquez@empresa.com.mx');

$chargeRequest = array(
    'method' => 'card',
    'source_id' => 'kqgykn96i7bcs1wwhvgw',
    'amount' => 100,
    'currency' => 'MXN'
    'description' => 'Cargo inicial a mi merchant',
    'order_id' => 'oid-00051',
    'device_session_id' => 'kR1MiQhz2otdIuUlQkbEyitIqVMiI16f',
    'customer' => $customer);

$charge = $openpay->charges->create($chargeRequest);
?>

Response example

{
   "id":"trzjaozcik8msyqshka4",
   "amount":100.00,
   "authorization":"801585",
   "method":"card",
   "operation_type":"in",
   "transaction_type":"charge",
   "card":{
      "id":"kqgykn96i7bcs1wwhvgw",
      "type":"debit",
      "brand":"visa",
      "address":null,
      "card_number":"411111XXXXXX1111",
      "holder_name":"Juan Perez Ramirez",
      "expiration_year":"20",
      "expiration_month":"12",
      "allows_charges":true,
      "allows_payouts":true,
      "creation_date":"2014-05-26T11:02:16-05:00",
      "bank_name":"Banamex",
      "bank_code":"002"
   },
   "status":"completed",
   "currency":"USD",
   "exchange_rate" : {
      "from" : "USD",
      "date" : "2014-11-21",
      "value" : 13.61,
      "to" : "MXN"
   },
   "creation_date":"2014-05-26T11:02:45-05:00",
   "operation_date":"2014-05-26T11:02:45-05:00",
   "description":"Cargo inicial a mi cuenta",
   "error_message":null,
   "order_id":"oid-00051"
}

This type of charge requires a saved card or a previously generated token. To save cards read Create a card and to use tokens visit the Creation of tokens.

Once you have a saved card or token use the source_id property to send the identifier.

The device_session_id property must be generated using JavaScript API, see Fraud detection using device data.

Customized antifraud system
You can send extra data to Openpay in order to increase number of variables and get better results in antifraud detection for your transactions.

Request

PropertyDescription
methodstring (required)
It must contain the card value in order to specify the charge will be made from card.
source_idstring (required, length = 45)
ID of the saved card or token id created from where the funds will be withdrawn.
amountnumeric (required)
Amount of charge. Must be an amount greater than zero, with up to two decimal digits.
cvv2numeric (length = 3 or 4)
Security code as it appears on the back of the card. Usually 3 digits.
It’s used only charges with Stored Cards.
currencystring (optional)
Type of currency of charge. At the moment only two types of currencies are supported: Mexican Pesos (MXN) and American Dollars (USD).
descriptionstring (required, length = 250)
A description associated with the position.
order_idstring (required, length = 100)
Unique identifier of the position. Must be unique among all transactions.
device_session_idstring (required, length = 255)
Identifier of the device generated by the antifraud tool.
captureboolean (opcional, default = true)
Indicates whether the charge is made immediately or not , when the value is false the charge is handled as authorized (or pre-authorization) and the amount is only to be confirmed or canceled in a second call.
customerobject (required)
Customer information who is charged. You can use the same parameters used in the creation of a customer but an account for the customer will not be created.Note: This parameter can be used only by creating the charge at the merchant level

To create a customer and keep a record of their charges history refer to create a customer and do the charge at the customer level.

payment_planobject (optional)
Plan data months without interest is desired as use in the charge. Refer to PaymentPlan Object.
metadatalist(key, value) (optional)
Field list to send antifraud system, It must be according to Rules to send custom antifraud fields.
use_card_points

string (optional, default = NONE)

ONLY_POINTSCharge only with points (Card points)
MIXEDCharge with points and pesos
NONECharge only with pesos

The values that indicate points must be used only if the points_card property is true, otherwise an error will occur.

send_emailboolean (optional)
Used in redirect charges. Indicates if is need send a email that redirect to the openpay payment form.
redirect_urlstring (required)
Used in redirect charges. It indicates the url to which redirect after a successful transaction in the openpay payment form.Note: Este parámetro solo se puede utilizar si se especifica el manejo de 3D Secure.
use_3d_securestring (optional)
Used to specify if 3D Secure should be used. true para manejar 3D Secure.

Response

Returns a transaction object with the charge information or with an error response..

With redirect

Definition

<?
Comercio
$openpay->charges->create(chargeRequest);

Cliente
$customer = $openpay->customers->get($customerId);
$customer->charges->create(chargeRequest);
?>

Merchant request example

<?
$openpay = Openpay::getInstance('mzdtln0bmtms6o3kck8f', 'sk_e568c42a6c384b7ab02cd47d2e407cab');
$customer = array(
     'name' => 'Juan',
     'last_name' => 'Vazquez Juarez',
     'phone_number' => '4423456723',
     'email' => 'juan.vazquez@empresa.com.mx');

$chargeRequest = array(
    "method" : "card",
    'amount' => 100,
    'description' => 'Cargo terminal virtual a mi merchant',
    'customer' => $customer,
    'send_email' => false,
    'confirm' => false,
    'redirect_url' => 'http://www.openpay.mx/index.html')
;

$charge = $openpay->charges->create($chargeRequest);
?>

Response example


{
  "id": "trq7yrthx5vc4gtjdkwg",
  "authorization": null,
  "method": "card",
  "operation_type": "in",
  "transaction_type": "charge",
  "status": "charge_pending",
  "conciliated": false,
  "creation_date": "2016-09-09T18:52:02-05:00",
  "operation_date": "2016-09-09T18:52:02-05:00",
  "description": "Cargo desde terminal virtual de 111",
  "error_message": null,
  "amount": 100,
  "currency": "MXN",
  "payment_method": {
    "type": "redirect",
    "url": "https://sandbox-api.openpay.mx/v1/mexzhpxok3houd5lbvz1/charges/trq7yrthx5vc4gtjdkwg/card_capture"
  },
  "customer": {
    "name": "Juan",
    "last_name": "Vazquez Juarez",
    "email": "juan.vazquez@empresa.com.mx",
    "phone_number": "4423456723",
    "creation_date": "2016-09-09T18:52:02-05:00",
    "clabe": null,
    "external_id": null
  }
}

This type of charge don’t requires a saved card or a previously generated token

Request

PropertyDescription
methodstring (required in card)
It must contain the card value in order to specify the charge will be made from card.
amountnumeric (required)
Amount of charge. Must be an amount greater than zero, with up to two decimal digits.
descriptionstring (required, length = 250)
A description associated with the position.
order_idstring (required, length = 100)
Unique identifier of the position. Must be unique among all transactions.
customerobject (required)
Customer information who is charged. You can use the same parameters used in the creation of a customer but an account for the customer will not be created.Note: This parameter can be used only by creating the charge at the merchant level

To create a customer and keep a record of their charges history refer to create a customer and do the charge at the customer level.

confirmboolean (required in false)
Indicates whether the charge is made immediately or not , when the value is false the charge is handled as authorized (or pre-authorization) and the amount is only to be confirmed or canceled in a second call. false indica que se trata de un cargo con terminal virtual.
send_emailboolean (optional)
Indicates if is need send a email that redirect to the openpay payment form.
redirect_urlstring (required)
It indicates the url to which redirect after a successful transaction in the openpay payment form.

Response

Returns a transaction object with the charge information or with an error response..

Charge via store

Definition

//Customer
openpayAPI.ChargeService.Create(string customer_id, ChargeRequest request);

//Merchant
openpayAPI.ChargeService.Create(ChargeRequest request);
<?
Comercio
$openpay->charges->create(chargeRequest);

Cliente
$customer = $openpay->customers->get(customerId);
$customer->charges->create(chargeRequest;
?>

Customer request example

<?
$openpay = Openpay::getInstance('mzdtln0bmtms6o3kck8f', 'sk_e568c42a6c384b7ab02cd47d2e407cab');

$chargeRequest = array(
    'method' => 'store',
    'amount' => 100,
    'description' => 'Cargo con tienda',
    'order_id' => 'oid-00053',
    'due_date' => '2014-05-28T13:45:00');

$customer = $openpay->customers->get('ag4nktpdzebjiye1tlze');
$charge = $customer->charges->create($chargeRequest);
?>

Response example

{
   "id":"trnirkiyobo5qfex55ef",
   "amount":100.00,
   "authorization":null,
   "method":"store",
   "operation_type":"in",
   "transaction_type":"charge",
   "status":"in_progress",
   "currency":"MXN",
   "creation_date":"2014-05-26T13:48:25-05:00",
   "operation_date":"2014-05-26T13:48:25-05:00",
   "due_date":"2014-05-28T13:45:00-05:00",
   "description":"Cargo con tienda",
   "error_message":null,
   "order_id":"oid-00053",
   "customer_id":"ag4nktpdzebjiye1tlze",
   "payment_method":{
      "type":"store",
      "reference":"000020TRNIRKIYOBO5QFEX55EF0100009",
      "paybin_reference":"0101990000001065",
      "barcode_url":"https://sandbox-api.openpay.mx/barcode/000020TRNIRKIYOBO5QFEX55EF0100009?width=1&height=45&text=false",
      "barcode_paybin_url":"https://sandbox-api.openpay.mx/barcode/0101990000001065?width=1&height=45&text=false"
   }
}

For payments at a convenience store you should create a charge type request by indicating storeas method. This will generate a response with a reference number and a URL with a barcode, which you must use to create a receipt so your customer can make the payment in one of the convenience stores. The barcode is Code 128 type.

Request

PropertyDescription
methodstring (required)
It must contain the store value in order to specify you want to pay at store.
amountnumeric (required)
Amount of charge. Must be an amount greater than zero, with up to two decimal digits.
descriptionstring (required, length = 250)
A description associated with the position.
order_idstring (required, length = 100)
Unique identifier of the position. Must be unique among all transactions.
due_datedatetime (optional)
Fecha de vigencia para hacer el pago en la tienda en formato ISO 8601.Ejemplo (UTC): 2014-08-01T00:50:00Z
Note: On the server side the date will be changeg to central time

Example (Central Time): 2014-08-01T11:51:23-05:00

customerobject (required)
Customer information who is charged. You can use the same parameters used in the creation of a customer but an account for the customer will not be created.Note: This parameter can be used only by creating the charge at the merchant level

To create a customer and keep a record of their charges history refer to create a customer and do the charge at the customer level.

Response

Returns a transaction object with the charge information or with an error response..

Charge via bank

Definition

<?
Comercio
$openpay->charges->create(chargeRequest);

Cliente
$customer = $openpay->customers->get(customerId);
$customer->charges->create(chargeRequest);
?>

Customer request example

<?
$openpay = Openpay::getInstance('mzdtln0bmtms6o3kck8f', 'sk_e568c42a6c384b7ab02cd47d2e407cab');

$chargeRequest = array(
    'method' => 'bank_account',
    'amount' => 100,
    'description' => 'Cargo con banco',
    'order_id' => 'oid-00055');

$customer = $openpay->customers->get('ag4nktpdzebjiye1tlze');
$charge = $customer->charges->create($chargeRequest);
?>

Response example

{
   "id":"trnzf2xjwpupjfryyj23",
   "amount":100.00,
   "authorization":null,
   "method":"bank_account",
   "operation_type":"in",
   "transaction_type":"charge",
   "status":"in_progress",
   "currency":"MXN",
   "creation_date":"2014-05-26T13:51:25-05:00",
   "operation_date":"2014-05-26T13:51:25-05:00",
   "description":"Cargo con banco",
   "error_message":null,
   "order_id":"oid-00055",
   "customer_id":"ag4nktpdzebjiye1tlze",
   "payment_method":{
      "type":"bank_transfer",
      "agreement" : "1411217",
      "bank":"BBVA Bancomer",
      "clabe":"012914002014112176",
      "name":"11030021342311520255"
   }
}

For a charge via bank you must create a charge type request by indicating bank_accountas method. This will generate a response with a Bancomer CIE agreement number, a CLABE account number and a reference, you have to indicate these data in a receipt so your customer can do the wire transfer via SPEI.

Request

PropertyDescription
methodstring (required)
It must contain the bank_account value to specify the pay will be made with bank transfer.
amountnumeric (required)
Amount of charge. Must be an amount greater than zero, with up to two decimal digits.
descriptionstring (required, length = 250)
A description associated with the position.
order_idstring (required, length = 100)
Unique identifier of the position. Must be unique among all transactions.
due_datedatetime (optional)
Fecha de vigencia para hacer el cargo a banco en formato ISO 8601.Ejemplo (UTC): 2014-08-01T00:50:00Z
Note: On the server side the date will be changeg to central time

Example (Central Time): 2014-08-01T11:51:23-05:00

customerobject (optional)
Customer information who is charged. You can use the same parameters used in the creation of a customer but an account for the customer will not be created.Note: This parameter can be used only by creating the charge at the merchant level

To create a customer and keep a record of their charges history refer to create a customer and do the charge at the customer level.

Response

Returns a transaction object with the charge information or with an error response..

With Alipay

Definition

//Customer
openpayAPI.ChargeService.Create(string customer_id, ChargeRequest request);

//Merchant
openpayAPI.ChargeService.Create(ChargeRequest request);

Customer request example

<?
$openpay = Openpay::getInstance('mzdtln0bmtms6o3kck8f', 'sk_e568c42a6c384b7ab02cd47d2e407cab');

$chargeRequest = array(
    'method' => 'alipay',
    'amount' => 100,
    'description' => 'Cargo Alipay',
    'order_id' => 'oid-00055',
    'redirect_url' => 'http://www.example.com/myRedirectUrl');

$customer = $openpay->customers->get('ag4nktpdzebjiye1tlze');
$charge = $customer->charges->create($chargeRequest);
?>

Response example

{
    "id": "truq1dwjz0kmssvpbrlj",
    "authorization": null,
    "operation_type": "in",
    "method": "alipay",
    "transaction_type": "charge",
    "status": "charge_pending",
    "conciliated": false,
    "creation_date": "2018-06-14T12:42:11-05:00",
    "operation_date": "2018-06-14T12:42:11-05:00",
    "description": "Cargo Alipay",
    "error_message": null,
    "order_id": null,
    "due_date": "2018-06-15T12:42:11-05:00",
    "payment_method": {
        "type": "redirect",
        "url": "https://sandbox-api.openpay.mx/v1/mzdtln0bmtms6o3kck8f/charges/truq1dwjo0kmssvqbrlj/redirect/"
    },
    "amount": 2000,
    "currency": "MXN",
    "fee": {
        "amount": 2.00  ,
        "tax": 0,
        "currency": "MXN"
    }
}

To start a transaction using Alipay you should create a charge type request by indicating alipayas method. This will generate a response with an URL which will redirect the customer to the Alipay website where they can then enter their account details, or scan the QR Code in their mobile app.

Request

PropertyDescription
methodstring (required)
It must contain the alipay value in order to specify you want the customer to pay using Alipay.
amountnumeric (required)
Amount of charge. Must be an amount greater than zero, with up to two decimal digits.
descriptionstring (required, length = 250)
A description associated with the position.
order_idstring (required, length = 100)
Unique identifier of the position. Must be unique among all transactions.
due_datedatetime (optional)
Fecha de vigencia para hacer el pago en Alipay en formato ISO 8601. El usuario podría tener hasta 15 minutos adicionales después de esta fecha después de iniciar su sesión para hacer su pago.Ejemplo (UTC): 2014-08-01T00:50:00Z
Note: On the server side the date will be changeg to central time

Example (Central Time): 2014-08-01T11:51:23-05:00

customerobject
Customer information who is charged. You can use the same parameters used in the creation of a customer but an account for the customer will not be created.Note: This parameter can be used only by creating the charge at the merchant level

To create a customer and keep a record of their charges history refer to create a customer and do the charge at the customer level.

redirect_urlstring (required)
It indicates the url to which redirect after a successful transaction in the openpay payment form, when a request is receiven in this url, merchant must get id attribute to request for the transaction final result.

Response

Returns a transaction object with the charge information or with an error response..

Charge with IVR

Definition

<?
Comercio
$openpay->charges->create(chargeRequest);

Cliente
$customer = $openpay->customers->get($customerId);
$customer->charges->create(chargeRequest);
?>

Merchant request example

<?
$openpay = Openpay::getInstance('mzdtln0bmtms6o3kck8f', 'sk_e568c42a6c384b7ab02cd47d2e407cab');
$customer = array(
     'name' => 'Juan',
     'last_name' => 'Vazquez Juarez',
     'phone_number' => '4423456723',
     'email' => 'juan.vazquez@empresa.com.mx');

$chargeRequest = array(
    'method' => 'card',
    'confirm' => 'ivr',
    'amount' => 100,
    'currency' => 'MXN'
    'description' => 'Cargo IVR',
    'order_id' => 'oid-00051',
    'customer' => $customer);

$charge = $openpay->charges->create($chargeRequest);
?>

Response example

{
    "id": "tranxr78lb4i58xaliu2",
    "authorization": null,
    "operation_type": "in",
    "transaction_type": "charge",
    "status": "charge_pending",
    "conciliated": false,
    "creation_date": "2020-10-16T12:22:25-05:00",
    "operation_date": "2020-10-16T12:22:25-05:00",
    "description": "Cargo IVR",
    "error_message": null,
    "order_id": "ord-323",
    "due_date": "2020-10-17T00:59:59-05:00",
    "payment_method": {
        "type": "ivr",
        "phone_number": "525588969143",
        "ivr_key": 676105,
        "attempts": 0
    },
    "amount": 100.00,
    "currency": "MXN",
    "customer": {
        "name": "JUAN",
        "last_name": "PEREZ",
        "email": "juan.urbina@hotmail.com",
        "phone_number": "45155352828",
        "address": null,
        "creation_date": "2020-10-16T12:22:25-05:00",
        "external_id": null,
        "clabe": null
    },
    "method": "card"
}

Customized antifraud system
You can send extra data to Openpay in order to increase number of variables and get better results in antifraud detection for your transactions.

Request

PropertyDescription
methodstring (required)
It must contain the card value in order to specify the charge will be made from card.
confirmstring (required)
It must contain the ivr value in order to specify the charge will be confirm from IVR.
amountnumeric (required)
Amount of charge. Must be an amount greater than zero, with up to two decimal digits.
currencystring (optional)
Type of currency of charge. At the moment only two types of currencies are supported: Mexican Pesos (MXN) and American Dollars (USD).
descriptionstring (required, length = 250)
A description associated with the position.
order_idstring (required, length = 100)
Unique identifier of the position. Must be unique among all transactions.
customerobject (required)
Customer information who is charged. You can use the same parameters used in the creation of a customer but an account for the customer will not be created.Note: This parameter can be used only by creating the charge at the merchant level

To create a customer and keep a record of their charges history refer to create a customer and do the charge at the customer level.

metadatalist(key, value) (optional)
Field list to send antifraud system, It must be according to Rules to send custom antifraud fields.
send_emailboolean (optional)
Used in redirect charges. Indicates if is need send a email that redirect to the openpay payment form.

Response

Returns a transaction object with the charge information or with an error response..

Confirming a charge

Definition

<?
Comercio
$charge = $openpay->charges->get(transactionId);
$charge->capture(captureData);

Cliente
$customer = $openpay->customers->get(customerId);
$charge = $customer->charges->get(transactionId);
$charge->capture(captureData);
?>

Customer request example

<?
$openpay = Openpay::getInstance('mzdtln0bmtms6o3kck8f', 'sk_e568c42a6c384b7ab02cd47d2e407cab');

$captureData = array('amount' => 100.00);

$customer = $openpay->customers->get('ag4nktpdzebjiye1tlze');
$charge = $customer->charges->get('tryqihxac3msedn4yxed');
$charge->capture($captureData);
?>

Response example

{
   "id":"tryqihxac3msedn4yxed",
   "amount":100.00,
   "authorization":"801585",
   "method":"card",
   "operation_type":"in",
   "transaction_type":"charge",
   "card":{
      "type":"debit",
      "brand":"visa",
      "address":null,
      "card_number":"411111XXXXXX1111",
      "holder_name":"Juan Perez Ramirez",
      "expiration_year":"20",
      "expiration_month":"12",
      "allows_charges":true,
      "allows_payouts":true,
      "bank_name":"Banamex",
      "bank_code":"002"
   },
   "status":"completed",
   "currency":"MXN",
   "creation_date":"2014-05-26T14:00:17-05:00",
   "operation_date":"2014-05-26T14:00:17-05:00",
   "description":"Cargo inicial a mi cuenta",
   "error_message":null,
   "order_id":null,
   "customer_id":"ag4nktpdzebjiye1tlze"
}

Confirm a charge created with the capture = "false"property, this method is the second part of the create a charge with a card (id or token) and it can confirm the amount captured on the first call or a lesser amount.

Request

PropertyDescription
amountnumeric (optional)
Amount to confirm. It can be less than or equal to the amount given with up to two decimal digits

Response

Returns a transaction object with the charge information or with an error response..

Refunding a charge

Definition

<?
Comercio
$charge = $openpay->charges->get(transactionId);
$charge->refund(refundData);

Cliente
$customer = $openpay->customers->get(customerId);
$charge = $customer->charges->get(transactionId);
$charge->refund(refundData);
?>

Customer request example

<?
$openpay = Openpay::getInstance('mzdtln0bmtms6o3kck8f', 'sk_e568c42a6c384b7ab02cd47d2e407cab');

$refundData = array(
    'description' => 'devolución',
    'amount' => 100);

$customer = $openpay->customers->get('ag4nktpdzebjiye1tlze');
$charge = $customer->charges->get('tr6cxbcefzatd10guvvw');
$charge->refund($refundData);
?>

Response example

{
   "id":"tr6cxbcefzatd10guvvw",
   "amount":100.00,
   "authorization":"801585",
   "method":"card",
   "operation_type":"in",
   "transaction_type":"charge",
   "card":{
      "type":"debit",
      "brand":"visa",
      "address":null,
      "card_number":"411111XXXXXX1111",
      "holder_name":"Juan Perez Ramirez",
      "expiration_year":"20",
      "expiration_month":"12",
      "allows_charges":true,
      "allows_payouts":true,
      "bank_name":"Banamex",
      "bank_code":"002"
   },
   "status":"completed",
   "refund":{
      "id":"trcbsmjkroqmjobxqhpb",
      "amount":100.00,
      "authorization":"801585",
      "method":"card",
      "operation_type":"out",
      "transaction_type":"refund",
      "status":"completed",
      "currency":"MXN",
      "creation_date":"2014-05-26T13:56:21-05:00",
      "operation_date":"2014-05-26T13:56:21-05:00",
      "description":"devolucion",
      "error_message":null,
      "order_id":null,
      "customer_id":"ag4nktpdzebjiye1tlze"
   },
   "currency":"MXN",
   "creation_date":"2014-05-26T11:56:25-05:00",
   "operation_date":"2014-05-26T11:56:25-05:00",
   "description":"Cargo inicial a mi cuenta",
   "error_message":null,
   "order_id":"oid-00052",
   "customer_id":"ag4nktpdzebjiye1tlze"
}

You can use this method if you want to make a charge refund to a card. The amount to be returned will be the total charge or a lower amount. Note that the refund may be delayed in the statement of your customer for 1-3 business days.

Request

PropertyDescription
descriptionstring (optional, length = 250)
Text to describe the refund reason.
amountnumeric (optional)
Amount to refund. Must be an amount greater than zero and lesser or equal than the original amount, with up to two decimal digits.

Response

Returns a transaction object with the charge information or with an error response..

Obtener un cargo

Definition

<?
Comercio
$charge = $openpay->charges->get(transactionId);

Cliente
$customer = $openpay->customers->get(customerId);
$charge = $customer->charges->get(transactionId);
?>

Customer request example

<?
$openpay = Openpay::getInstance('mzdtln0bmtms6o3kck8f', 'sk_e568c42a6c384b7ab02cd47d2e407cab');

$customer = $openpay->customers->get('ag4nktpdzebjiye1tlze');
$charge = $customer->charges->get('tr6cxbcefzatd10guvvw');
?>

Response example

{
   "id":"tr6cxbcefzatd10guvvw",
   "amount":100.00,
   "authorization":"801585",
   "method":"card",
   "operation_type":"in",
   "transaction_type":"charge",
   "card":{
      "type":"debit",
      "brand":"visa",
      "address":null,
      "card_number":"411111XXXXXX1111",
      "holder_name":"Juan Perez Ramirez",
      "expiration_year":"20",
      "expiration_month":"12",
      "allows_charges":true,
      "allows_payouts":true,
      "bank_name":"Banamex",
      "bank_code":"002"
   },
   "status":"completed",
   "refund":{
      "id":"trcbsmjkroqmjobxqhpb",
      "amount":100.00,
      "authorization":"801585",
      "method":"card",
      "operation_type":"out",
      "transaction_type":"refund",
      "status":"completed",
      "currency":"MXN",
      "creation_date":"2014-05-26T13:56:21-05:00",
      "operation_date":"2014-05-26T13:56:21-05:00",
      "description":"devolucion",
      "error_message":null,
      "order_id":null,
      "customer_id":"ag4nktpdzebjiye1tlze"
   },
   "currency":"MXN",
   "creation_date":"2014-05-26T11:56:25-05:00",
   "operation_date":"2014-05-26T11:56:25-05:00",
   "description":"Cargo inicial a mi cuenta",
   "error_message":null,
   "order_id":"oid-00052",
   "customer_id":"ag4nktpdzebjiye1tlze"
}

Returns a transaction object with the charge information or with an error response.

Request

PropertyDescription
transaction_idstring (required, length = 45)
Charge Id.

Response

Returns a transaction object with the charge information or with an error response..

List of charges

Definition

<?
Comercio
$chargeList = $openpay->charges->getList(searchParams);

Cliente
$customer = $openpay->customers->get(customerId);
$chargeList = $customer->charges->getList(searchParams);
?>

Customer request example

<?
$openpay = Openpay::getInstance('mzdtln0bmtms6o3kck8f', 'sk_e568c42a6c384b7ab02cd47d2e407cab');

$searchParams = array(
    'creation[gte]' => '2013-11-01',
    'creation[lte]' => '2014-11-01',
    'offset' => 0,
    'limit' => 2);

$customer = $openpay->customers->get('ag4nktpdzebjiye1tlze');
$chargeList = $customer->charges->getList($searchParams);
?>

Response example

[
   {
      "id":"tryqihxac3msedn4yxed",
      "amount":100.00,
      "authorization":"801585",
      "method":"card",
      "operation_type":"in",
      "transaction_type":"charge",
      "card":{
         "type":"debit",
         "brand":"visa",
         "address":null,
         "card_number":"411111XXXXXX1111",
         "holder_name":"Juan Perez Ramirez",
         "expiration_year":"20",
         "expiration_month":"12",
         "allows_charges":true,
         "allows_payouts":true,
         "bank_name":"Banamex",
         "bank_code":"002"
      },
      "status":"completed",
      "currency":"MXN",
      "creation_date":"2014-05-26T14:00:17-05:00",
      "operation_date":"2014-05-26T14:00:17-05:00",
      "description":"Cargo inicial a mi cuenta",
      "error_message":null,
      "order_id":null,
      "customer_id":"ag4nktpdzebjiye1tlze"
   },
   {
      "id":"trnzf2xjwpupjfryyj23",
      "amount":100.00,
      "authorization":null,
      "method":"bank_account",
      "operation_type":"in",
      "transaction_type":"charge",
      "status":"in_progress",
      "currency":"MXN",
      "creation_date":"2014-05-26T13:51:25-05:00",
      "operation_date":"2014-05-26T13:51:25-05:00",
      "description":"Cargo con banco",
      "error_message":null,
      "order_id":"oid-00055",
      "customer_id":"ag4nktpdzebjiye1tlze",
      "payment_method":{
         "type":"bank_transfer",
         "agreement" : "1411217",
         "bank":"BBVA Bancomer",
         "clabe":"012914002014112176",
         "name":"11030021342311520255"
      }
   }
]

Gets a list of the charges made by Merchant or customer.

Request

You can search using the following parameters as filters.

PropertyDescription
order_idstring
Unique order id generated by the merchant and associated to the transaction by the order_id field of the charge request.
creationdate
Same as creation date. Format yyyy-mm-dd
creation[gte]date
After the creation date. Format yyyy-mm-dd
creation[lte]date
Before the creation date. Format yyyy-mm-dd
offsetnumeric
Number of records to skip at the beginning, default 0.
limitnumeric
Number of required records, default 10.
amountnumeric
Same as the amount.
amount[gte]numeric
Greater than or equal to the amount.
amount[lte]numeric
Less than or equal to the amount.
statusTransactionStatus
Estado de la transacción (IN_PROGRESS,COMPLETED,REFUNDED,CHARGEBACK_PENDING,CHARGEBACK_ACCEPTED,CHARGEBACK_ADJUSTMENT,CHARGE_PENDING,CANCELLED,FAILED).

Response

Returns an array of transaction objects charges in descending order by creation date.

Payouts or withdrawals

A payout is the transaction that allows to extract funds from a Openpay account and send the funds to a bank account. Payouts can be made from the accounts of the customers or from the Merchant account.

Payout to a registered id

Definition

<?
Cliente
$customer = $openpay->customers->get(customerId);
$payout = $customer->payouts->create(payoutRequest);

Comercio
$payout = $openpay->payouts->create(payoutRequest);
?>

Customer request example

<?
$openpay = Openpay::getInstance('mzdtln0bmtms6o3kck8f', 'sk_e568c42a6c384b7ab02cd47d2e407cab');

$payoutRequest = array(
    'method' => 'bank_account',
    'destination_id' => 'a3d54sd3mdjf75udjfvoc',
    'amount' => 1000,
    'description' => 'Retiro de saldo semanal',
    'order_id' => 'ORDEN-00021');

$customer = $openpay->customers->get('ag4nktpdzebjiye1tlze');
$payout = $customer->payouts->create($payoutRequest);
?>

Response example

{
   "amount":10.5,
   "authorization":null,
   "method":"bank_account",
   "currency":"MXN",
   "operation_type":"out",
   "transaction_type":"payout",
   "bank_account":{
      "id":"b3d54sd3mdjf75udjfvoc",
      "clabe":"012XXXXXXXXXX24616",
      "bank_code":"012",
      "bank_name":"BANCOMER",
      "alias":null,
      "holder_name":"Mi empresa"
   },
   "status":"in_progress",
   "id":"tm50pl40gf6awvalw1ei",
   "creation_date":"2013-11-15T13:42:00-06:00",
   "description":"Retiro de saldo semanal",
   "error_message":null,
   "order_id":"oid-00021",
   "customer_id":"aayr5jjb1fln44yautef"
}

Sends a payout to a previously registered bank account. Refer to create a bank account

Request

PropertyDescription
methodstring (required)
It must contain the bank_account.
destination_idstring (required, length = 45)
ID of the registered bank account.
amountnumeric (required)
Amount of charge. Must be an amount greater than zero, with up to two decimal digits.
descriptionstring (required, length = 250)
A description associated with the position.
order_idstring (required, length = 100)
Unique identifier of the position. Must be unique among all transactions.

Response

Returns a transaction object with the payout information or with an error response..

Payment to a bank account

Definition

<?
Cliente
$customer = $openpay->customers->get(customerId);
$payout = $customer->payouts->create(payoutRequest);

Comercio
$payout = $openpay->payouts->create(payoutRequest);
?>

Customer request example

<?
$openpay = Openpay::getInstance('mzdtln0bmtms6o3kck8f', 'sk_e568c42a6c384b7ab02cd47d2e407cab');

$payoutRequest = array(
    'method' => 'bank_account',
    'bank_account' => array(
        'clabe' => '012298026516924616',
        'holder_name' => 'Mi empresa'),
    'amount' => 100.00,
    'description' => 'Retiro de saldo semanal',
    'order_id' => 'ORDEN-00021');

$customer = $openpay->customers->get('asynwirguzkgq2bizogo');
$payout = $customer->payouts->create($payoutRequest);
?>

Response example

{
   "id":"tr4f2atubqchinw71vfs",
   "amount":10.50,
   "authorization":null,
   "method":"bank_account",
   "operation_type":"out",
   "transaction_type":"payout",
   "status":"in_progress",
   "currency":"MXN",
   "creation_date":"2014-05-26T17:23:03-05:00",
   "operation_date":"2014-05-26T17:23:03-05:00",
   "description":"Retiro de saldo semanal",
   "error_message":null,
   "order_id":"oid-1110011",
   "bank_account":{
      "clabe":"012XXXXXXXXXX24616",
      "bank_code":"012",
      "bank_name":"BANCOMER",
      "alias":null,
      "holder_name":"Mi empresa"
   },
   "customer_id":"asynwirguzkgq2bizogo"
}

Sends a payment to a bank account.

Request

PropertyDescription
methodstring (required)
It must contain the bank_account.
bank_accountobject (required)
Data of the bank account where the funds will be sent.clabe.- CLABE account number where the funds will be sent.
holder_name.- Name of the account owner .
amountnumeric (required)
Amount of charge. Must be an amount greater than zero, with up to two decimal digits.
descriptionstring (required, length = 250)
A description associated with the position.
order_idstring (required, length = 100)
Unique identifier of the position. Must be unique among all transactions.

Response

Returns a transaction object with the payout information or with an error response..

Get a payout

Definition

<?
Comercio
$payout = $openpay->payouts->get(transactionId);

Cliente
$customer = $openpay->customers->get(customerId);
$payout = $customer->payouts->get(transactionId);
?>

Customer request example

<?
$openpay = Openpay::getInstance('mzdtln0bmtms6o3kck8f', 'sk_e568c42a6c384b7ab02cd47d2e407cab');

$customer = $openpay->customers->get('asynwirguzkgq2bizogo');
$payout = $customer->payouts->get('trwpxhrgfeub9eqdyvqz');
?>

Response example

{
   "id":"trwpxhrgfeub9eqdyvqz",
   "amount":10.50,
   "authorization":"TRWPXHRGFEUB9EQDYVQZ",
   "method":"bank_account",
   "operation_type":"out",
   "transaction_type":"payout",
   "bank_account":{
      "clabe":"012XXXXXXXXXX24616",
      "bank_code":"012",
      "bank_name":"BANCOMER",
      "alias":null,
      "holder_name":"Mi empresa"
   },
   "status":"completed",
   "currency":"MXN",
   "creation_date":"2014-05-26T17:04:26-05:00",
   "operation_date":"2014-05-26T17:06:28-05:00",
   "description":"Retiro de saldo semanal",
   "error_message":null,
   "order_id":"oid-00021",
   "customer_id":"asynwirguzkgq2bizogo"
}

Returns de information of the payout. You must know the payout id.

Request

PropertyDescription
transaction_idstring (required, length = 45)
Id of the payout you want to get.

Response

Returns a transaction object with the payout information or with an error response..

Cancel a payout

Definition

<?
Comercio
$payout = $openpay->payouts->delete(transactionId);

Cliente
$customer = $openpay->customers->get(customerId);
$payout = $customer->payouts->delete(transactionId);
?>

Customer request example

<?
$openpay = Openpay::getInstance('mzdtln0bmtms6o3kck8f', 'sk_e568c42a6c384b7ab02cd47d2e407cab');

$customer = $openpay->customers->get('asynwirguzkgq2bizogo');
$payout = $customer->payouts->delete('trozeipf364jqrsbt3ej');
?>

Response example

{
   "id":"trozeipf364jqrsbt3ej",
   "amount":10.50,
   "authorization":"TROZEIPF364JQRSBT3EJ",
   "method":"bank_account",
   "operation_type":"out",
   "transaction_type":"payout",
   "bank_account":{
      "clabe":"012XXXXXXXXXX24616",
      "bank_code":"012",
      "bank_name":"BANCOMER",
      "alias":null,
      "holder_name":"Mi empresa"
   },
   "status":"cancelled",
   "currency":"MXN",
   "creation_date":"2014-05-26T17:04:26-05:00",
   "operation_date":"2014-05-26T17:06:28-05:00",
   "description":"Retiro de saldo semanal",
   "error_message":null,
   "order_id":"oid-00021",
   "customer_id":"asynwirguzkgq2bizogo"
}

Cancels a payout in in_progress status, it means not yet completed. You must know the payout id.

Request

PropertyDescription
transaction_idstring (required, length = 45)
Payout Id you want to cancel.

Response

Returns a transaction object with the cancelled payout or with an error response..

List of payouts

Definition

<?
Comercio
$payoutList = $openpay->payouts->getList(searchParams);

Cliente
$customer = $openpay->customers->get(customerId);
$payoutList = $customer->payouts->getList(searchParams);
?>

Request example

<?
$openpay = Openpay::getInstance('mzdtln0bmtms6o3kck8f', 'sk_e568c42a6c384b7ab02cd47d2e407cab');

$searchParams = array(
    'creation[gte]' => '2013-11-01',
    'creation[lte]' => '2017-12-31',
    'payout_type' => 'AUTOMATIC',
    'offset' => 0,
    'limit' => 2);

$customer = $openpay->customers->get('asynwirguzkgq2bizogo');
$payoutList = $customer->payouts->getList($searchParams);
?>

Response example

[
   {
      "id":"tr4f2atubqchinw71vfs",
      "amount":10.50,
      "authorization":"TR4F2ATUBQCHINW71VFS",
      "method":"bank_account",
      "operation_type":"out",
      "transaction_type":"payout",
      "status":"completed",
      "currency":"MXN",
      "creation_date":"2014-05-26T17:23:03-05:00",
      "operation_date":"2014-05-26T17:26:27-05:00",
      "description":"Retiro de saldo semanal",
      "error_message":null,
      "order_id":"oid-1110011",
      "bank_account":{
         "clabe":"012XXXXXXXXXX24616",
         "bank_code":"012",
         "bank_name":"BANCOMER",
         "alias":null,
         "holder_name":"Mi empresa"
      },
      "customer_id":"asynwirguzkgq2bizogo"
   },
   {
      "id":"trwpxhrgfeub9eqdyvqz",
      "amount":10.50,
      "authorization":"TRWPXHRGFEUB9EQDYVQZ",
      "method":"bank_account",
      "operation_type":"out",
      "transaction_type":"payout",
      "bank_account":{
         "clabe":"012XXXXXXXXXX24616",
         "bank_code":"012",
         "bank_name":"BANCOMER",
         "alias":null,
         "holder_name":"Mi empresa"
      },
      "status":"completed",
      "currency":"MXN",
      "creation_date":"2014-05-26T17:04:26-05:00",
      "operation_date":"2014-05-26T17:06:28-05:00",
      "description":"Retiro de saldo semanal",
      "error_message":null,
      "order_id":"oid-00021",
      "customer_id":"asynwirguzkgq2bizogo"
   }
]

Gets a list of payouts made at Merchant or customer level.

Request

You can search using the following parameters as filters.

PropertyDescription
creationdate
Same as creation date. Format yyyy-mm-dd
creation[gte]date
After the creation date. Format yyyy-mm-dd
creation[lte]date
Before the creation date. Format yyyy-mm-dd
offsetnumeric
Number of records to skip at the beginning, default 0.
limitnumeric
Number of required records, default 10.
amountnumeric
Same as the amount.
amount[gte]numeric
Greater than or equal to the amount.
amount[lte]numeric
Less than or equal to the amount.
payout_typestring (opcional, ALL, AUTOMATIC o MANUAL)
Payout type used to filter the transactions

Response

Returns a list of transaction objects payouts in descending order by creation date.

Summary Payouts

Definition

<?
$transactionsPayout = $openpay->transactionsPayout->get(transactionId);
?>

Request example

<?
$openpay = Openpay::getInstance('mzdtln0bmtms6o3kck8f', 'sk_e568c42a6c384b7ab02cd47d2e407cab');

$payout = $openpay->transactionsPayout->get('trwpxhrgfeub9eqdyvqz');
?>

Response example

{
  "in": 2700,
  "out": 2400,
  "charged_adjustments": 0,
  "refunded_adjustments": 0
}

Return the summary of the payout. You must know the payout id.

Request

PropertyDescription
transaction_idstring (required, length = 45)
Id of the payout you want to get.

Response

Returns a summary payouts object with the summary of the payout or a error response..

Summary Payout Object

Object example

{
   "in":2700,
   "out":2400,
   "charged_adjustments":0,
   "refunded_adjustments":0
}
PropertyDescription
innumeric
Total amount in, Must be an amount with up to two decimal digits.
outnumeric
Total amount out, Must be an amount with up to two decimal digits.
charged_adjustmentsnumeric
Total amount of adjustment charges, Must be an amount with up to two decimal digits.
refunded_adjustmentsnumeric
Total amount of refund charges, Must be an amount with up to two decimal digits.

Payout Detail

Definition

<?
$transactionsPayout = $openpay->transactionsPayout->getDetails(transactionId, searchParams);
?>

Request example

<?
$openpay = Openpay::getInstance('mzdtln0bmtms6o3kck8f', 'sk_e568c42a6c384b7ab02cd47d2e407cab');

$searchParams = array(
    'payout_type' => 'IN',
    'offset' => 0,
    'limit' => 100);

$payout = $openpay->transactionsPayout->getDetails('trwpxhrgfeub9eqdyvqz', $searchParams);
?>

Response example

[
  {
    "id": "trqcwapqeilg596zwrvr",
    "authorization": "7BXqDL1fjb",
    "method": "bank_account",
    "operation_type": "in",
    "transaction_type": "charge",
    "status": "completed",
    "conciliated": true,
    "creation_date": "2016-09-13T12:57:34-05:00",
    "operation_date": "2016-09-13T12:57:34-05:00",
    "description": "mexzhpxok3houd5lbvz1",
    "error_message": null,
    "order_id": null,
    "bank_account": {
      "clabe": "113XXXXXXXXXX09568",
      "bank_code": "113",
      "bank_name": "VE POR MAS",
      "rfc": "OPE130906HN4",
      "holder_name": "persona003"
    },
    "amount": 700,
    "currency": "MXN"
  },
  {
    "id": "tru6lsl6xpvseqp87vjd",
    "authorization": "FPVYiN4nyw",
    "method": "card",
    "operation_type": "in",
    "transaction_type": "charge",
    "card": {
      "type": "debit",
      "brand": "mastercard",
      "address": null,
      "card_number": "555555XXXXXX4444",
      "holder_name": "persona003",
      "expiration_year": null,
      "expiration_month": null,
      "allows_charges": false,
      "allows_payouts": false,
      "bank_name": "MASARI",
      "bank_code": "602"
    },
    "status": "completed",
    "conciliated": true,
    "creation_date": "2016-09-13T12:57:16-05:00",
    "operation_date": "2016-09-13T12:57:16-05:00",
    "description": "mexzhpxok3houd5lbvz1",
    "error_message": null,
    "order_id": null,
    "amount": 2000,
    "currency": "MXN"
  }
]

Returns a list of the transactions involved in a payout. You must know the payout id.

Request

PropertyDescription
transaction_idstring (required, length = 45)
Id of the payout you want to get.
detail_typestring (IN, OUT, CHARGED_ADJUSTMENTS, REFUNDED_ADJUSTMENTS)
The detail type.
offsetnumeric
Number of records to skip at the beginning, default 0.
limitnumeric
Number of required records, default 10.

Response

Returns a list of transaction objects or a error response..

Customers

Customers are Openpay resources that are handled within the Merchant account and can represent users, customers or partners according to the type of Merchant.

You can add cards and bank accounts to the customers so you can make transactions like Charges, Transfers or Payouts.

Customer object

Object example

{
   "id":"cz4nkhrlcu9k7qd4lwqx",
   "creation_date":"2013-11-08T12:04:46-06:00",
   "name":"Rodrigo",
   "last_name":"Velazco Perez",
   "email":"rodrigo.velazco@payments.com", 
   "phone_number":"4425667045",
   "external_id":"cliente1",
   "status":"active",
   "balance":103,
   "address":{
      "line1":"Av. 5 de febrero No. 1080 int Roble 207",
      "line2":"Carrillo puerto",
      "line3":"Zona industrial carrillo puerto",
      "postal_code":"06500",
      "state":"Querétaro",
      "city":"Querétaro",
      "country_code":"MX"
   },
   "store": {
       "reference": "OPENPAY02DQ35YOY7",
       "barcode_url": "https://sandbox-api.openpay.mx/barcode/OPENPAY02DQ35YOY7?width=1&height=45&text=false"
   },
   "clabe": "646180109400423323"
}
PropertyDescription
idstring
Customer unique identifier.
creation_datedatetime
Date and time when the customer was created in ISO 8601 format.
namestring
Name of the customer.
last_namestring
Customer's last name.
emailstring
Last name of the customer.
phone_numbernumeric
Customer's telephone number.
statusstring
Account status of the customer can be active or deleted. If the account is on deleted status, no transaction is allowed.
balancenumeric
Account balance with two decimal digits.
clabenumeric
CLABE account used to receive funds by transfer from any bank in Mexico.
addressobject
Address of the customer. It is usually used as shipping address.
storeobject
Contains reference string to go to Store and make deposits, the url to generate barcode is contained too.

Create a new customer

Definition

<?
$customer = $openpay->customers->add(customerData);
?>

Request example

<?
$openpay = Openpay::getInstance('mzdtln0bmtms6o3kck8f', 'sk_e568c42a6c384b7ab02cd47d2e407cab');

$customerData = array(
     'external_id' => '',
     'name' => 'customer name',
     'last_name' => '',
     'email' => 'customer_email@me.com',
     'requires_account' => false,
     'phone_number' => '44209087654',
     'address' => array(
         'line1' => 'Calle 10',
         'line2' => 'col. san pablo',
         'line3' => 'entre la calle 1 y la 2',
         'state' => 'Queretaro',
         'city' => 'Queretaro',
         'postal_code' => '76000',
         'country_code' => 'MX'
      )
   );

$customer = $openpay->customers->add($customerData);
?>

Response example

{
   "id":"anbnldwgni1way3yp2dw",
   "name":"customer name",
   "last_name":null,
   "email":"customer_email@me.com",
   "phone_number":null,
   "address":null,
   "creation_date":"2014-05-20T16:47:47-05:00",
   "external_id":null,
   "store": {
       "reference": "OPENPAY02DQ35YOY7",
       "barcode_url": "https://sandbox-api.openpay.mx/barcode/OPENPAY02DQ35YOY7?width=1&height=45&text=false"
   },
   "clabe": "646180109400423323"
}

Create a customer object.

Request

PropertyDescription
external_idstring (required, length = 100)
Unique external identifier of the customer assigned for the Merchant.
namestring (required, length = 100)
Customer's name(s).
last_namestring (required, length = 100)
Customer's last name.
emailstring (required, length = 100)
Customer's email.
requires_accountboolean (opcional, default = false)
Send it with true value if you need to create the customer with an account to manage the balance.
phone_numberstring (required, length = 100)
Customer's telephone number.
addressobject (optional)
Address of the customer. It is usually used as shipping address.

Response

Returns a object customer when all the data were sent correctly, or returns an error response. if an error occurred during the creation.

Update a customer

Definition

<?
$customer = $openpay->customers->get(customerId);
$customer->save();
?>

Request example

<?
$openpay = Openpay::getInstance('moiep6umtcnanql3jrxp', 'sk_3433941e467c1055b178ce26348b0fac');

$customer = $openpay->customers->get('a9ualumwnrcxkl42l6mh');
$customer->name = 'Juan';
$customer->last_name = 'Godinez';
$customer->save();
?>

Response example

{
   "id":"anbnldwgni1way3yp2dw",
   "name":"customer name",
   "last_name":null,
   "email":"customer_email@me.com",
   "phone_number":"44209087654",
   "address":{
      "line1":"Calle 10",
      "line2":"col. san pablo",
      "line3":"entre la calle 1 y la 2",
      "state":"Queretaro",
      "city":"Queretaro",
      "postal_code":"76000",
      "country_code":"MX"
   },
   "store": {
       "reference": "OPENPAY02DQ35YOY7",
       "barcode_url": "https://sandbox-api.openpay.mx/barcode/OPENPAY02DQ35YOY7?width=1&height=45&text=false"
   },
   "clabe": "646180109400423323",
   "creation_date":"2014-05-20T16:47:47-05:00",
   "external_id":null
}

Updates one or more data of the customer.

Request

PropertyDescription
namestring (required, length = 100)
Customer's name(s).
last_namestring (required, length = 100)
Customer's last name.
emailstring (required, length = 100)
Customer's email.
phone_numberstring (required, length = 100)
Customer's telephone number.
addressobject
Address of the customer. It is usually used as shipping address.

Response

Returns a object customer with the updated info, or returns an error response. if a problem happened while updating.

Get an existing customer

Definition

<?
$customer = $openpay->customers->get(customerId);
?>

Request example

<?
$openpay = Openpay::getInstance('moiep6umtcnanql3jrxp', 'sk_3433941e467c1055b178ce26348b0fac');

$customer = $openpay->customers->get('a9ualumwnrcxkl42l6mh');
?>

Response example

{
   "id":"anbnldwgni1way3yp2dw",
   "name":"customer name",
   "last_name":null,
   "email":"customer_email@me.com",
   "phone_number":"44209087654",
   "address":{
      "line1":"Calle 10",
      "line2":"col. san pablo",
      "line3":"entre la calle 1 y la 2",
      "state":"Queretaro",
      "city":"Queretaro",
      "postal_code":"76000",
      "country_code":"MX"
   },
   "store": {
       "reference": "OPENPAY02DQ35YOY7",
       "barcode_url": "https://sandbox-api.openpay.mx/barcode/OPENPAY02DQ35YOY7?width=1&height=45&text=false"
   },
   "clabe": "646180109400423323",
   "creation_date":"2014-05-20T16:47:47-05:00",
   "external_id":null
}

Gets the current information of an existing customer. You only need to specify the id returned when creating the customer.

Request

PropertyDescription
idstring (required, length = 45)
Unique identifier of the customer.

Response

If the identifier exists, it returns a object customer with the customer information.

Delete a customer

Definition

<?
$customer = $openpay->customers->get(customerId);
$customer->delete();
?>

Request example

<?
$openpay = Openpay::getInstance('moiep6umtcnanql3jrxp', 'sk_3433941e467c1055b178ce26348b0fac');

$customer = $openpay->customers->get('a9ualumwnrcxkl42l6mh');
$customer->delete();
?>

Deletes a customer permanently. All the related subscriptions will be canceled. Openpay keeps the operations records.

Request

PropertyDescription
idstring (required, length = 45)
Unique identifier of the customer you want to delete.

Response

If the customer is deleted correctly, it returns an empty response, if the customer can not be deleted it returns a error object explaining the reason.

List of customers

Definition

<?
$customerList = $openpay->customers->getList(findDataRequest);
?>

Request example

<?
$openpay = Openpay::getInstance('moiep6umtcnanql3jrxp', 'sk_3433941e467c1055b178ce26348b0fac');

$findDataRequest = array(
    'creation[gte]' => '2013-01-01',
    'creation[lte]' => '2013-12-31',
    'offset' => 0,
    'limit' => 5);

$customerList = $openpay->customers->getList($findDataRequest);
?>

Response example

[{
   "id":"cpjdhf754ythr65yu9k7q",
   "creation_date":"2013-11-08T12:04:46-06:00",
   "name":"Rodrigo",
   "last_name":"Velazco Perez",
   "email":"rodrigo.velazco@payments.com",
   "phone_number":"4425667045",
   "status":"active",
   "balance":142.5,
   "store": {
       "reference": "OPENPAY02DQ35YOY7",
       "barcode_url": "https://sandbox-api.openpay.mx/barcode/OPENPAY02DQ35YOY7?width=1&height=45&text=false"
   },
   "clabe": "646180109400423323"
}, {
   "id":"cz4nkhrlcu9k7qd4lwqx",
   "creation_date":"2013-11-07T14:54:46-06:00",
   "name":"Eriberto",
   "last_name":"Rodriguez Lopez",
   "email":"eriberto.rodriguez@payments.com",
   "phone_number":"442",
   "status":"active",
   "balance":103,
   "store": {
       "reference": "OPENPAY02DQWERWJ3",
       "barcode_url": "https://sandbox-api.openpay.mx/barcode/OPENPAY02DQWERWJ3?width=1&height=45&text=false"
   },
   "clabe": "646180109400423323"
}]

Returns a list of registered customers, if you want to delimit the result you may use filters.

Request

You can search using the following parameters as filters.

PropertyDescription
external_idstring
Unique customer id generated by the merchant and associated to the customer by the external_id field of the create customer request
creationdate
Same as the customer creation date. Format yyyy-mm-dd
creation[gte]date
After the customer creation date .Format yyyy-mm-dd
creation[lte]date
Before the customer creation date.Format yyyy-mm-dd
offsetnumeric
Number of records to skip at the beginning, default 0.
limitnumeric
Number of required records, default 10.

Response

Returns an array of customer object.

Wire transfers

The transfers allow to send funds between accounts of your customers.

Transfers between customers

Definition

<?
$customer = $openpay->customers->get(customerId);
$transfer = $customer->transfers->create(transferDataRequest);
?>

Request example

<?
$openpay = Openpay::getInstance('moiep6umtcnanql3jrxp', 'sk_3433941e467c1055b178ce26348b0fac');

$transferDataRequest = array(
    'customer_id' => 'aqedin0owpu0kexr2eor',
    'amount' => 12.50,
    'description' => 'Cobro de Comisión',
    'order_id' => 'ORDEN-00061');

$customer = $openpay->customers->get('a9ualumwnrcxkl42l6mh');
$transfer = $customer->transfers->create($transferDataRequest);
?>

Response example

{
   "amount":12.50,
   "authorization":null,
   "method":"customer",
   "operation_type":"out",
   "currency":"MXN",
   "transaction_type":"transfer",
   "status":"completed",
   "id":"twpmbike2jejex3pahzd",
   "creation_date":"2013-11-15T10:33:19-06:00",
   "description":"Transferencia entre cuentas",
   "error_message":null,
   "order_id":"oid-1245",
   "customer_id":"a9pvykxz4g5rg0fplze0",
   "store": {
       "reference": "OPENPAY02DQ35YOY7",
       "barcode_url": "https://sandbox-api.openpay.mx/barcode/OPENPAY02DQ35YOY7?width=1&height=45&text=false"
   },
   "clabe": "646180109400423323"
}

Makes the transfer of funds from one account of the customer to another. The funds will be charged to an origin account and added to a destination account, which will create two transactions.

Request

PropertyDescription
customer_idstring (required, length = 45)
The Openpay ID of the customer you want to send the funds.
amountnumeric (required)
Amount to transfer. It must be an amount greater than one peso with up to two decimal digits.
descriptionstring (required, length = 250)
A description associated to the transfer.
order_idstring (required, length = 100)
Unique identifier of the transfer. It will be assigned to the withdrawal transaction.

Response

If the transaction is successful, the response will contain a transaction object. This object represents the withdrawal of the account of the current customer. On error, the error object will be returned.

Get a transfer

Definition

<?
$customer = $openpay->customers->get(customerId);
$transfer = $customer->transfers->get(transactionId);
?>

Request example

<?
$openpay = Openpay::getInstance('moiep6umtcnanql3jrxp', 'sk_3433941e467c1055b178ce26348b0fac');

$customer = $openpay->customers->get('a9ualumwnrcxkl42l6mh');
$transfer = $customer->transfers->get('tyxesptjtx1bodfdjmlb');
?>

Response example

{
   "amount":12.50,
   "authorization":null,
   "method":"customer",
   "operation_type":"out",
   "currency":"MXN",
   "transaction_type":"transfer",
   "status":"completed",
   "id":"twpmbike2jejex3pahzd",
   "creation_date":"2013-11-15T10:33:19-06:00",
   "description":"Transferencia entre cuentas",
   "error_message":null,
   "order_id":"oid-1245",
   "customer_id":"dvocf97jd20es3tw5laz"
}

With the customer identifier and the transfer identifier, you can get the details of the transaction. The output transaction will be on the customer from which the transfer was made, and the entry transaction will be on the customer that received the amount.

Request

PropertyDescription
customer_idstring (required, length = 45)
Identifier of the customer.
transaction_idstring (required, length = 45)
Identifier of the transfer.

Response

Returns a transaction object

List of transfers

Definition

<?
$customer = $openpay->customers->get(customerId);
$transferList = $customer->transfers->getList(findDataRequest);
?>

Request example

<?
$openpay = Openpay::getInstance('moiep6umtcnanql3jrxp', 'sk_3433941e467c1055b178ce26348b0fac');

$findDataRequest = array(
    'creation[gte]' => '2013-01-01',
    'creation[lte]' => '2013-12-31',
    'offset' => 0,
    'limit' => 5);

$customer = $openpay->customers->get('a9ualumwnrcxkl42l6mh');
$transferList = $customer->transfers->getList($findDataRequest);
?>

Response example

[
   {
      "amount":130.00,
      "authorization":null,
      "method":"customer",
      "currency":"MXN",
      "operation_type":"out",
      "transaction_type":"transfer",
      "status":"completed",
      "id":"a74mbe4e2j5gc6gfahzd",
      "creation_date":"2013-09-18T00:31:19-06:00",
      "description":"Una descripcion",
      "error_message":null,
      "order_id":"20131115103317",
      "customer_id":"afk4csrazjp1udezj1po"
   },
   {
      "amount":130.00,
      "authorization":null,
      "method":"customer",
      "currency":"MXN",
      "operation_type":"in",
      "transaction_type":"transfer",
      "status":"completed",
      "id":"a74mbe4e2j5gc6gfahzd",
      "creation_date":"2013-09-18T00:31:19-06:00",
      "description":"Una descripcion",
      "error_message":null,
      "order_id":null,
      "customer_id":"agdn58ngcnogqmzruz1i"
   }
]

It allows to consult the entry and output transactions of a customer.

Request

You can search using the following parameters as filters.

PropertyDescription
creationdate
Same as creation date. Format yyyy-mm-dd
creation[gte]date
After the creation date. Format yyyy-mm-dd
creation[lte]date
Before the creation date. Format yyyy-mm-dd
offsetnumeric
Number of records to skip at the beginning, default 0.
limitnumeric
Number of required records, default 10.

Response

List of transaction objects of the transfers made, each one with the identifier of the customer that made it. The transactions will be listed in descending order by creation date.

Cards

Within the Openpay platform you can add cards to the customer’s account, delete them, recover some in specific and list them.

You can store multiple debit and / or credit cards at Merchant or customer level for making charges later without the need to enter the information again.

Card Object

Object example

{
   "type":"debit",
   "brand":"mastercard",
   "address":{
      "line1":"Av 5 de Febrero",
      "line2":"Roble 207",
      "line3":"col carrillo",
      "state":"Queretaro",
      "city":"Querétaro",
      "postal_code":"76900",
      "country_code":"MX"
   },
   "id":"kgipbqixvjg3gbzowl7l",
   "card_number":"1111",
   "holder_name":"Juan Perez Ramirez",
   "expiration_year":"20",
   "expiration_month":"12",
   "allows_charges":true,
   "allows_payouts":false,
   "creation_date":"2013-12-12T17:50:00-06:00",
   "bank_name":"DESCONOCIDO",
   "bank_code":"000",
   "customer_id":"a2b79p8xmzeyvmolqfja",
   "points_card":true
}
PropertyDescription
idstring
Unique identifier of the card.
creation_datedatetime
Date and time when the card was created in ISO 8601 format.
holder_namestring
Name of the cardholder.
card_numbernumeric
Card Number, it can be 16 or 19 digits.
cvv2numeric
Security code as it appears on the back of the card. Usually 3 digits.
expiration_monthnumeric
Expiration month as it appears on the card.
expiration_yearnumeric
Expiration year as it appears on the card.
addressobject
Billing address of cardholder.
allows_chargesboolean
It allows to know if you can make charges to the card.
allows_payoutsboolean
It allows to know if you can send payments to the card.
brandstring
Card brand: visa, mastercard, carnet or american express.
typestring
Card Type: debit, credit, cash, etc.
bank_namestring
Name of the issuing bank.
bank_codestring
Code of the issuing bank.
customer_idstring
Customer identifier to which the card belongs. If the card is at Merchant level this value is null.
points_cardboolean
Indicates whether the card allows the use of reward points.

Create a card

Definition

<?
//Cliente
$customer = $openpay->customers->get(customerId);
$card = $customer->cards->add(cardDataRequest);

//Comercio
$card = $openpay->cards->add(cardDataRequest);
?>

Customer request example

<?
$openpay = Openpay::getInstance('moiep6umtcnanql3jrxp', 'sk_3433941e467c1055b178ce26348b0fac');

$cardDataRequest = array(
    'holder_name' => 'Teofilo Velazco',
    'card_number' => '4916394462033681',
    'cvv2' => '123',
    'expiration_month' => '12',
    'expiration_year' => '15',
    'device_session_id' => 'kR1MiQhz2otdIuUlQkbEyitIqVMiI16f',
    'address' => array(
            'line1' => 'Privada Rio No. 12',
            'line2' => 'Co. El Tintero',
            'line3' => '',
            'postal_code' => '76920',
            'state' => 'Querétaro',
            'city' => 'Querétaro.',
            'country_code' => 'MX'));

$customer = $openpay->customers->get('a9ualumwnrcxkl42l6mh');
$card = $customer->cards->add($cardDataRequest);
?>

Response example

{
   "id":"ktrpvymgatocelsciak7",
   "type":"debit",
   "brand":"visa",
   "card_number":"411111XXXXXX1111",
   "holder_name":"Juan Perez Ramirez",
   "expiration_year":"20",
   "expiration_month":"12",
   "allows_charges":true,
   "allows_payouts":true,
   "creation_date":"2014-05-21T17:31:01-05:00",
   "bank_name":"Banamex",
   "customer_id":"ag4nktpdzebjiye1tlze",
   "bank_code":"002"
}

When a card is created the customer must be specified, if the customer is not specified the card will be registered for the Merchant account. Once the card is saved, it can not obtain the number and security code.

When saving a card, an ID will be created which can be used to make card charges, payouts to a card or just for getting the not sensitive card information.

You can use the antifraud system implementation. The device_session_id property must be generated using JavaScript API, see Fraud detection using device data.

Request

PropertyDescription
holder_namestring (required, length = 80)
Name of the cardholder.
card_numbernumeric (required)
Card Number, it can be 16 or 19 digits.
cvv2numeric (required)
Security code as it appears on the back of the card. Usually 3 digits.
expiration_monthnumeric (required)
Expiration month as it appears on the card.
expiration_yearnumeric (required)
Expiration year as it appears on the card.
device_session_idstring (optional, length = 255)
Device identifier generated by antifraud tool.
addressobject
Billing address of cardholder.

Response

Returns a card object when it is created correctly or returns an error response. if an error occurred during the creation.

Create a card with token

Definition

<?
//Cliente
$customer = $openpay->customers->get(customerId);
$card = $customer->cards->add(cardDataRequest);

//Comercio
$card = $openpay->cards->add(cardDataRequest);
?>

Customer request example

<?
$openpay = Openpay::getInstance('moiep6umtcnanql3jrxp', 'sk_3433941e467c1055b178ce26348b0fac');

$cardDataRequest = array(
    'token_id' => 'tokgslwpdcrkhlgxqi9a',
    'device_session_id' => '8VIoXj0hN5dswYHQ9X1mVCiB72M7FY9o'
    );

$customer = $openpay->customers->get('a9ualumwnrcxkl42l6mh');
$card = $customer->cards->add($cardDataRequest);
?>

Response example

{
   "type":"credit",
   "brand":"visa",
   "id":"kso4st83wxaibffyt6su",
   "card_number":"4242",
   "holder_name":"Juan Perez Ramirez",
   "expiration_year":"15",
   "expiration_month":"12",
   "allows_charges":true,
   "allows_payouts":false,
   "creation_date":"2014-02-12T10:57:09-06:00",
   "bank_name":"BANCOMER",
   "bank_code":"012",
   "customer_id":"a2b79p8xmzeyvmolqfja"
}

Creates a card from a token obtained from the browser or from the customer’s device. This way prevents the sensitive card information passes through your servers.

Request

PropertyDescription
token_idstring (required, length = 45)
Token identifier generated in the the browser or in the customer’s device.
device_session_idstring (required, length = 255)
Identifier of the device generated by the antifraud tool.

Response

Returns a card object

Get a card

Definition

<?
//Cliente
$customer = $openpay->customers->get(customerId);
$card = $customer->cards->get(cardId);

//Comercio
$card = $openpay->cards->get(cardId);
?>

Customer request example

<?
$openpay = Openpay::getInstance('moiep6umtcnanql3jrxp', 'sk_3433941e467c1055b178ce26348b0fac');

$customer = $openpay->customers->get('a9ualumwnrcxkl42l6mh');
$card = $customer->cards->get('k9pn8qtsvr7k7gxoq1r5');
?>

Response example

{
   "id":"ktrpvymgatocelsciak7",
   "type":"debit",
   "brand":"visa",
   "card_number":"411111XXXXXX1111",
   "holder_name":"Juan Perez Ramirez",
   "expiration_year":"20",
   "expiration_month":"12",
   "allows_charges":true,
   "allows_payouts":true,
   "creation_date":"2014-05-21T17:31:01-05:00",
   "bank_name":"Banamex",
   "customer_id":"ag4nktpdzebjiye1tlze",
   "bank_code":"002"
}

It obtains the details of the card by using its id.

Request

PropertyDescription
idstring (required, length = 45)
Card unique identifier.

Response

Returns a card object

Card points

Definition

<?
//Clientes
$customer = $openpay->customers->get(customerId);
$pointsBalance = $customer->cards->get(cardId)->get("points");
//Comercio
$pointsBalance = $openpay->cards->get(cardId)->get("points");
//Token
$pointsBalance = $openpay->get("tokens")->get(tokenId)->get("points");
?>

Customer request example

<?
$openpay = Openpay::getInstance('moiep6umtcnanql3jrxp', 'sk_3433941e467c1055b178ce26348b0fac');
$cardId =  'tfghdfghtertdfbsd';
$customer = $openpay->customers->get('a9ualumwnrcxkl42l6mh');
$pointsBalance = $customer->cards->get(cardId)->get("points");
?>

Response example

[
   {
      "points_type": "santander",
      "remaining_points":"300",
      "remaining_mxn":"22.5"
   }
]

Returns the card point balance. Is applicable only for Santander, Scotiabank and Bancomer points.

Request

You can get the card points of a merchant or customer using the card id.

PropertyDescription
idstring (required, length = 45)
Card unique identifier.

Also you can get the card points of a merchant using the token.

PropertyDescription
idstring (required, length = 45)
Identifier token

Response

PropertyDescription
points_typePoints type accepted by the card (Santander, Scotiabank or Bancomer)
remaining_pointsNumber of remaining points
remaining_mxnBalance remaining points in pesos

Delete a card

Definition

<?
//Cliente
$customer = $openpay->customers->get(customerId);
$card = $customer->cards->get(cardId);
$card->delete();

//Comercio
$card = $openpay->cards->get(cardId);
$card->delete();
?>

Customer request example

<?
$openpay = Openpay::getInstance('moiep6umtcnanql3jrxp', 'sk_3433941e467c1055b178ce26348b0fac');

$customer = $openpay->customers->get('a9ualumwnrcxkl42l6mh');
$card = $customer->cards->get('k9pn8qtsvr7k7gxoq1r5');
$card->delete();
?>

Deletes a card of the customer or Merchant. After deleting it won’t be possible to make movements with that card, however, all records of the transactions you have made will be kept and will be available on the dashboard.

To remove it is only necessary to provide the card identifier.

Request

PropertyDescription
idstring (required, length = 45)
Card unique identifier.

Response

If the card is removed correctly the answer is empty, if it can not be deleted a error object explaining the reason.

List of cards

Definition

<?
//Clientes
$customer = $openpay->customers->get(customerId);
$cardList = $customer->cards->getList(findDataRequest);

//Comercio
$cardList = $openpay->cards->getList(findDataRequest);
?>

Customer request example

<?
$openpay = Openpay::getInstance('moiep6umtcnanql3jrxp', 'sk_3433941e467c1055b178ce26348b0fac');

$findDataRequest = array(
    'creation[gte]' => '2013-01-01',
    'creation[lte]' => '2013-12-31',
    'offset' => 0,
    'limit' => 5);

$customer = $openpay->customers->get('a9ualumwnrcxkl42l6mh');
$cardList = $customer->cards->getList($findDataRequest);
?>

Response example

[
   {
      "id":"kxq1rpdymlcpxekvjsxm",
      "card_number":"1118",
      "holder_name":"Pedro Paramo",
      "expiration_year":"15",
      "expiration_month":"12",
      "allows_charges":true,
      "allows_payouts":true,
      "creation_date":"2013-11-20T09:22:25-06:00",
      "bank_name":"BBVA BANCOMER",
      "bank_code":"012",
      "type":"debit",
      "brand":"mastercard"
   },
   {
      "id":"kgjy0jiami01kkpdoywr",
      "card_number":"1111",
      "holder_name":"Pedro Paramo",
      "expiration_year":"15",
      "expiration_month":"12",
      "allows_charges":true,
      "allows_payouts":true,
      "creation_date":"2013-11-19T13:26:12-06:00",
      "bank_name":"BBVA BANCOMER",
      "bank_code":"012",
      "type":"debit",
      "brand":"mastercard"
   }
]

Returns a list of registered Merchant or customer cards, if you want to narrow the result you can use filters.

Request

You can search using the following parameters as filters.

PropertyDescription
creationdate
Same as creation date. Format yyyy-mm-dd
creation[gte]date
After the creation date. Format yyyy-mm-dd
creation[lte]date
Before the creation date. Format yyyy-mm-dd
offsetnumeric
Number of records to skip at the beginning, default 0.
limitnumeric
Number of required records, default 10.

Response

List of card objects registered according to the parameters provided, sorted by creation date in descending order.

Updating a card

Definition

Merchant
PUT https://sandbox-api.openpay.mx/v1/{MERCHANT_ID}/cards/{CARD_ID}

Customer
PUT https://sandbox-api.openpay.mx/v1/{MERCHANT_ID}/customers/{CUSTOMER_ID}/cards/{CARD_ID}

Customer request example

Response example

{
}

Updates the card data from the browser or from the customer’s device. It also allows to send a cvv2 code that will be used in the next transaction done with this card. This prevents sensitive information from passing through your servers.

Request

PropertyDescription
holder_namestring (optional)
Name of the cardholder.
cvv2string (optional)
Security code as it appears on the back of the card. Usually 3 digits.
expiration_monthnumeric (optional)
Expiration month as it appears on the card.
expiration_yearnumeric (optional)
Expiration year as it appears on the card.
merchant_idstring (conditional)
Merchant ID to use to validate this card. Required when using a merchant group.

Response

Returns an empty JSON object. Please consider that this response may be extended in the future.

Bank Accounts

You can store multiple bank accounts by Merchant or customer for withdraw funds later.

Bank account object

Object example

{
   "id":"brppwl9nwmruogk2do0j",
   "clabe":"032180000118359719",
   "bank_code":"032",
   "bank_name":"IXE",
   "alias":null,
   "holder_name":"Juan Hernández Sánchez",
   "creation_date":"2013-11-14T12:29:18-06shell00"
}
PropertyDescription
idstring
ID of the bank account.
holder_namestring
Holder’s full name.
aliasstring
Name by which the bank account is identified.
clabestring
CLABE number assigned to the account.
bank_namestring
Abbreviated name of the bank where the account resides, based on the following catalog of Bank codes.
bank_codestring
Bank code where the account resides, based on the following catalog Bank codes.
creation_datedatetime
Date and time when the bank account was created in ISO 8601 format.

Create a bank account

Definition

<?
$customer = $openpay->customers->get(customerId);
$bankaccount = $customer->bankaccounts->add(bankDataRequest);
?>

Customer request example

<?
$openpay = Openpay::getInstance('moiep6umtcnanql3jrxp', 'sk_3433941e467c1055b178ce26348b0fac');

$bankDataRequest = array(
    'clabe' => '072910007380090615',
    'alias' => 'Cuenta principal',
    'holder_name' => 'Teofilo Velazco');

$customer = $openpay->customers->get('a9ualumwnrcxkl42l6mh');
$bankaccount = $customer->bankaccounts->add($bankDataRequest);
?>

Response example

{
   "id":"buyj4apkwilpp2jfxr9r",
   "clabe":"032XXXXXXXXXX59719",
   "bank_code":"032",
   "bank_name":"IXE",
   "alias":"Cuenta principal",
   "holder_name":"Juan Hernández Sánchez",
   "creation_date":"2014-05-22T11:02:10-05:00"
}

Creates and assigns a bank account to a specific customer.

Request

PropertyDescription
holder_namestring (required, length = 80)
Holder’s full name.
aliasstring (optional, length = 45)
Name by which the bank account is identified.
clabestring (required, length = 45)
CLABE number assigned to the account.

Response

Returns a bank account object or an error when a there is a problem.

Get a bank account

Definition

<?
$customer = $openpay->customers->get(customerId);
$bankaccount = $customer->bankaccounts->get(bankAccountId);
?>

Customer request example

<?
$openpay = Openpay::getInstance('moiep6umtcnanql3jrxp', 'sk_3433941e467c1055b178ce26348b0fac');

$customer = $openpay->customers->get('a9ualumwnrcxkl42l6mh');
$bankaccount = $customer->bankaccounts->get('b4vcouaavwuvkpufh0so');
?>

Response example

{
   "id":"buyj4apkwilpp2jfxr9r",
   "clabe":"032XXXXXXXXXX59719",
   "bank_code":"032",
   "bank_name":"IXE",
   "alias":"Cuenta principal",
   "holder_name":"Juan Hernández Sánchez",
   "creation_date":"2014-05-22T11:02:10-05:00"
}

It obtains the details of the bank account assigned to a customer.

Request

PropertyDescription
idstring (required, length = 45)
Unique identifier of the bank account.

Response

Returns a bank account object

Delete a bank account

Definition

<?
$customer = $openpay->customers->get(customerId);
$bankaccount = $customer->bankaccounts->get(bankAccountId);
$bankaccount->delete();
?>

Customer request example

<?
$openpay = Openpay::getInstance('moiep6umtcnanql3jrxp', 'sk_3433941e467c1055b178ce26348b0fac');

$customer = $openpay->customers->get('a9ualumwnrcxkl42l6mh');
$bankaccount = $customer->bankaccounts->get('b4vcouaavwuvkpufh0so');
$bankaccount->delete();
?>

Deletes the bank account associated with the customer. The transactions that are associated with this account are unchanged and will continue for you to consult them.

Request

PropertyDescription
idstring (required, length = 45)
Unique identifier of the bank account.

Response

If the bank account is removed correctly the answer is empty, if it can not be deleted a error object explaining the reason.

List of bank accounts

Definition

<?
$customer = $openpay->customers->get(customerId);
$bankaccountList = $customer->bankaccounts->getList(findDataRequest);
?>

Customer request example

<?
$openpay = Openpay::getInstance('moiep6umtcnanql3jrxp', 'sk_3433941e467c1055b178ce26348b0fac');

$findDataRequest = array(
    'creation[gte]' => '2013-01-01',
    'creation[lte]' => '2013-12-31',
    'offset' => 0,
    'limit' => 5);

$customer = $openpay->customers->get('a9ualumwnrcxkl42l6mh');
$bankaccountList = $customer->bankaccounts->getList($findDataRequest);
?>

Response example

[{
   "id":"brppwl9nwmruogk2do0j",
   "clabe":"032180000118359719",
   "bank_code":"032",
   "bank_name":"IXE",
   "alias":null,
   "holder_name":"Juan Hernández Sánchez",
   "creation_date":"2013-11-14T12:29:18-06:00"
},
{
   "id":"bb0zt72rxoyiwz9jzzai",
   "clabe":"012680012426485980",
   "bank_code":"012",
   "bank_name":"BANCOMER",
   "alias":null,
   "holder_name":"Juan Hernández Sánchez",
   "creation_date":"2013-11-14T18:07:45-06:00"
}]

Returns the details of all the bank accounts of the customer specified on the request.

Request

You can search using the following parameters as filters.

PropertyDescription
creationdate
Same as creation date. Format yyyy-mm-dd
creation[gte]date
After the creation date. Format yyyy-mm-dd
creation[lte]date
Before the creation date. Format yyyy-mm-dd
offsetnumeric
Number of records to skip at the beginning, default 0.
limitnumeric
Number of required records, default 10.

Response

List of objetos cuenta bancaria registered according to the parameters provided, sorted by creation date in descending order.

Plans

Plans are an Openpay resource that allows create templates for subscriptions. Using plans you can define the amount and frequency of recurrent charges.

Plan Object

Object example

{
    "name": "Curso de ingles",
    "status": "active",
    "amount": 150,
    "currency": "MXN",
    "id": "patpflacwilazguj6bem",
    "creation_date": "2013-12-13T09:43:52-06:00",
    "repeat_every": 1,
    "repeat_unit": "month",
    "retry_times": 2,
    "status_after_retry": "cancelled",
    "trial_days": 30
}
PropertyDescription
idstring
Unique plan identifier.
creation_datedatetime
Date and time in which the plan was created in ISO 8601 format.
namestring
Plan name.
amountnumeric
Amount that will be applied once the subscription is charged. It has to be more than zero and it can have up to two decimal places.
currencystring
Currency used in the operation, by default is MXN (Mexican pesos).
repeat_everynumeric
Time units in which the subscription will be charged. For example, repeat_unit=month and repeat_every=2 indicates that it will be charged every 2 months.
repeat_unitstring
Describes the charge unit frequency. It can be weekly(week), monthly(month) or yearly (year).
retry_timesnumeric
Number of attempts to try to charge the subscription. When the attempts have been exhausted, the status field is determined by the field status_after_retry.
statusstring
Plan status can be active or deleted. If the plan is in deleted state it doesn’t allow to register new subscriptions under this plan but existing subscriptions will be charged.
status_after_retrystring
This field indicates the status in which the subscription will be set once all the charge attempts have been exhausted. It can be unpaid or cancelled.
trial_daysnumeric
Number of trial days this subscription will have by default.

Create a new Plan

Definition

<?
$plan = $openpay->plans->add(planDataRequest);
?>

Request example

<?
$openpay = Openpay::getInstance('moiep6umtcnanql3jrxp', 'sk_3433941e467c1055b178ce26348b0fac');

$planDataRequest = array(
    'amount' => 150.00,
    'status_after_retry' => 'cancelled',
    'retry_times' => 2,
    'name' => 'Plan Curso Verano',
    'repeat_unit' => 'month',
    'trial_days' => '30',
    'repeat_every' => '1',
    'currency' => 'MXN');

$plan = $openpay->plans->add($planDataRequest);
?>

Response example

{
   "id":"p8e6x3hafqqsbmnoevrt",
   "name":"Curso de ingles",
   "status":"active",
   "amount":150.00,
   "currency":"MXN",
   "creation_date":"2014-05-22T12:29:31-05:00",
   "repeat_every":1,
   "repeat_unit":"month",
   "retry_times":2,
   "status_after_retry":"cancelled",
   "trial_days":30
}

Creates a new plan for allowing customers to subscribe.

Request

PropertyDescription
namestring (required, length = 255)
Plan name.
amountnumeric (required)
Amount that will be applied once the subscription is charged. It has to be more than zero and it can have up to two decimal places.
repeat_everynumeric (required)
Time units in which the subscription will be charged. For example, repeat_unit=month and repeat_every=2 indicates that it will be charged every 2 months.
repeat_unitnumeric (required)
Describes the charge unit frequency. It can be weekly(week), monthly(month) or yearly (year).
retry_timesnumeric (optional)
Number of attempts to try to charge the subscription. When the attempts have been exhausted, the status field is determined by the field status_after_retry.
status_after_retrystring (requerido, valores = “UNPAID/CANCELLED”)
This field indicates the status in which the subscription will be set once all the charge attempts have been exhausted. It can be unpaid or cancelled.
trial_daysnumeric (required)
Number of trial days this subscription will have by default.

Response

Returns a plan object or an error when a there is a problem.

Update existing plans.

Definition

<?
$plan = $openpay->plans->get(planId);
$plan->save();
?>

Request example

<?
$openpay = Openpay::getInstance('moiep6umtcnanql3jrxp', 'sk_3433941e467c1055b178ce26348b0fac');

$plan = $openpay->plans->get('pduar9iitv4enjftuwyl');
$plan->name = 'Plan Curso de Verano 2014';
$plan->save();
?>

Response example

{
   "id":"p8e6x3hafqqsbmnoevrt",
   "name":"Curso de aleman",
   "status":"active",
   "amount":150.00,
   "currency":"MXN",
   "creation_date":"2014-05-22T12:29:31-05:00",
   "repeat_every":1,
   "repeat_unit":"month",
   "retry_times":2,
   "status_after_retry":"cancelled",
   "trial_days":60
}

Updates the plan information. It requires a plan id and only certain fields can be updated.

Request

PropertyDescription
namestring (optional, length = 80)
Plan name.
trial_daysnumeric (optional)
Number of trial days this subscription will have by default.

Response

Returns a plan object with the updated information or an error response. if a problem happened while updating.

Get a plan

Definition

<?
$plan = $openpay->plans->get(planId);
?>

Request example

<?
$openpay = Openpay::getInstance('moiep6umtcnanql3jrxp', 'sk_3433941e467c1055b178ce26348b0fac');

$plan = $openpay->plans->get('pduar9iitv4enjftuwyl');
?>

Response example

{
   "id":"p8e6x3hafqqsbmnoevrt",
   "name":"Curso de aleman",
   "status":"active",
   "amount":150.00,
   "currency":"MXN",
   "creation_date":"2014-05-22T12:29:31-05:00",
   "repeat_every":1,
   "repeat_unit":"month",
   "retry_times":2,
   "status_after_retry":"cancelled",
   "trial_days":60
}

It gets the plan details.

Request

PropertyDescription
idstring (required, length = 45)
Plan identifier.

Response

Returns a plan object

Delete a plan

Definition

<?
$customer = $openpay->customers->get(customerId);
$plan = $openpay->plans->get(planId);
$plan->delete();
?>

Request example

<?
$openpay = Openpay::getInstance('moiep6umtcnanql3jrxp', 'sk_3433941e467c1055b178ce26348b0fac');

$customer = $openpay->customers->get('a9ualumwnrcxkl42l6mh');
$plan = $openpay->plans->get('pduar9iitv4enjftuwyl');
$plan->delete();
?>

When a plan is deleted it won’t allow to create more subscriptions associated with it, however the subscriptions already associated will continue to be charged.

Request

PropertyDescription
idstring (required, length = 45)
Identifier of the plan that will be deleted.

Response

If the plan is deleted correctly the response will be empty, if it cannot be deleted an error object explaining the reason.

Plan list

Definition

<?
$planList = $openpay->plans->getList(findDataRequest);
?>

Request example

<?
$openpay = Openpay::getInstance('moiep6umtcnanql3jrxp', 'sk_3433941e467c1055b178ce26348b0fac');

$findDataRequest = array(
    'creation[gte]' => '2013-01-01',
    'creation[lte]' => '2013-12-31',
    'offset' => 0,
    'limit' => 5);

$planList = $openpay->plans->getList($findDataRequest);
?>

Response example

[
    {
        "name": "Curso de aleman",
        "status": "active",
        "amount": 150,
        "currency": "MXN",
        "id": "patpflacwilazguj6bem",
        "creation_date": "2013-12-13T09:43:52-06:00",
        "repeat_every": 1,
        "repeat_unit": "month",
        "retry_times": 2,
        "status_after_retry": "cancelled",
        "trial_days": 60
    },
    {
        "name": "Curso de ingles",
        "status": "active",
        "amount": 150,
        "currency": "MXN",
        "id": "pjl7wfryrrd1tznr0fnl",
        "creation_date": "2013-12-13T11:36:40-06:00",
        "repeat_every": 1,
        "repeat_unit": "month",
        "retry_times": 2,
        "status_after_retry": "cancelled",
        "trial_days": 30
    }
]

Returns the details of all active plans.

Request

You can search using the following parameters:

PropertyDescription
creationdate
Same as creation date. Format yyyy-mm-dd
creation[gte]date
After the creation date. Format yyyy-mm-dd
creation[lte]date
Before the creation date. Format yyyy-mm-dd
offsetnumeric
Number of records to skip at the beginning, default 0.
limitnumeric
Number of required records, default 10.

Response

List of plan objects registered according to the parameters provided, sorted by creation date in descending order.

Subscriptions

Subscriptions allow you to associate a customer and a card so that recurring charges can be made.

In order to subscribe a client it is necessary to first create a plan.

Subscription object

Object example

{
    "status": "trial",
    "card": {
        "type": "debit",
        "brand": "mastercard",
        "card_number": "1111",
        "holder_name": "Juan Perez Ramirez",
        "expiration_year": "20",
        "expiration_month": "12",
        "allows_charges": true,
        "allows_payouts": false,
        "creation_date": "2013-12-13T12:39:46-06:00",
        "bank_name": "DESCONOCIDO",
        "customer_id": null,
        "bank_code": "000"
    },
    "id": "svxdm1suclzipbi4pavm",
    "cancel_at_period_end": false,
    "charge_date": "2014-01-12",
    "creation_date": "2013-12-13T12:39:46-06:00",
    "current_period_number": 0,
    "period_end_date": "2014-01-11",
    "trial_end_date": "2014-01-11",
    "plan_id": "pjl7wfryrrd1tznr0fnl",
    "customer_id": "a2b79p8xmzeyvmolqfja"
}
PropertyDescription
idstring
Unique plan identifier.
creation_datedatetime
Date and time in which the subscription was created using ISO 8601 format.
cancel_at_period_endstring
Indicates if the subscription has been canceled at the end of the period.
charge_datenumeric
Date in which the subscription will be charged.
current_period_numberstring
Indicates the current period to be charged.
period_end_datenumeric
Date in which the current period ends, it’s one day before the next charge.
trial_end_datestring
Date in which the trial period ends. One day after this date the first charge is applied.
plan_idnumeric
Plan identifier in which this subscription will be created.
statusstring
Subscription status, it can be active, trial, past_due, unpaid or cancelled. If the subscription has a trial period, the trial period is applied, if it doesn’t have or when the trial period ends and the first payment is executed it changes to active. When the charge was unable to be completed it changes to past_due. When all the charge tries has been completed according to the plan configuration it can change to unpaid or cancelled. When it’s marked as unpaid and the subscription wants to be reactivated it’s required to update the subscription payment method(card). In any other case, the status is set to cancelled.
customer_idstring
Customer identifier for the subscription owner.
cardobject
Payment method for the subscription. See card object

Create a new Subscription

Definition

<?
$customer = $openpay->customers->get(customerId);
$subscription = $customer->subscriptions->add(subscriptionDataRequest);
?>

Request example

<?
$openpay = Openpay::getInstance('moiep6umtcnanql3jrxp', 'sk_3433941e467c1055b178ce26348b0fac');

$subscriptionDataRequest = array(
    'trial_end_date' => '2014-01-01', 
    'plan_id' => 'pbi4kb8hpb64x0uud2eb',
    'card' => array(
         'card_number' => '4111111111111111',
         'holder_name' => 'Juan Perez Ramirez',
         'expiration_year' => '20',
         'expiration_month' => '12',
         'cvv2' => '110',
         'device_session_id' => 'kR1MiQhz2otdIuUlQkbEyitIqVMiI16f'));

$customer = $openpay->customers->get('a9ualumwnrcxkl42l6mh');
$subscription = $customer->subscriptions->add($subscriptionDataRequest);
?>

Response example

{
   "id":"s0gmyor4yqtyv1miqwr0",
   "status":"trial",
   "card":{
      "type":"debit",
      "brand":"visa",
      "address":null,
      "card_number":"411111XXXXXX1111",
      "holder_name":"Juan Perez Ramirez",
      "expiration_year":"20",
      "expiration_month":"12",
      "allows_charges":true,
      "allows_payouts":true,
      "bank_name":"Banamex",
      "bank_code":"002"
   },
   "cancel_at_period_end":false,
   "charge_date":"2014-06-21",
   "creation_date":"2014-05-22T15:56:18-05:00",
   "current_period_number":0,
   "period_end_date":"2014-06-20",
   "trial_end_date":"2014-06-20",
   "plan_id":"pbi4kb8hpb64x0uud2eb",
   "customer_id":"ag4nktpdzebjiye1tlze"
}

Create a new subscription for an existing customer. You can use an existing card or you can send the info of the card where the charges will be made, in these you can include the property device_session_id to use the antifraud tool, see Fraud detection using device data.

Request

PropertyDescription
plan_idstring (required, length = 45)
Plan identifier in which this subscription will be created.
trial_end_datestring (optional, length = 10)
Indicates the customer trial end date. If it’s not indicated the plan will be used to calculate it. If the date is in the past it will be interpreted as a subscription with no trial. Format: yyyy-mm-dd.
source_idstring (required if the card is not sent, length = 45)
Card token identifier, or the customer registered card which will be used to charge the subscription.
cardobject (required if the source_id is not present)
Payment method for the subscription. See card object

Response

Returns the created subscription object or an error response. if an error occurred during the creation.

Updating a Subscription

Definition

<?
$customer = $openpay->customers->get(customerId);
$subscription = $customer->subscriptions->get(subscriptionId);
$subscription->save();
?>

Request example

<?
$openpay = Openpay::getInstance('moiep6umtcnanql3jrxp', 'sk_3433941e467c1055b178ce26348b0fac');

$customer = $openpay->customers->get('a9ualumwnrcxkl42l6mh');
$subscription = $customer->subscriptions->get('s7ri24srbldoqqlfo4vp');
$subscription->trial_end_date = '2014-12-31';
$subscription->save();
?>

Response example

{
   "id":"s0gmyor4yqtyv1miqwr0",
   "status":"trial",
   "card":{
      "type":"credit",
      "brand":"american_express",
      "address":null,
      "card_number":"343434XXXXX4343",
      "holder_name":"Juan Perez Ramirez",
      "expiration_year":"20",
      "expiration_month":"12",
      "allows_charges":true,
      "allows_payouts":false,
      "bank_name":"AMERICAN EXPRESS",
      "bank_code":"103"
   },
   "cancel_at_period_end":false,
   "charge_date":"2016-01-12",
   "creation_date":"2014-05-22T15:56:18-05:00",
   "current_period_number":0,
   "period_end_date":"2016-01-11",
   "trial_end_date":"2016-01-11",
   "plan_id":"pbi4kb8hpb64x0uud2eb",
   "customer_id":"ag4nktpdzebjiye1tlze"
}

Updates the information of an active subscription.

Request

PropertyDescription
cancel_at_period_endbooelan (optional)
Indicates if the subscription has been canceled at the end of the period.
trial_end_datestring (optional, length = 10)
Indicates the customer trial end date. If it’s not indicated the plan will be used to calculate it. If the date is in the past it will be interpreted as a subscription with no trial. Format: yyyy-mm-dd.
source_idstring (optional, length = 45)
Card token identifier, or the customer registered card which will be used to charge the subscription.
cardobject (optional)
Payment method for the subscription. See card object

Response

Returns the created subscription object actualizado o una error response. if a problem happened while updating.

Get a Subscription

Definition

<?
$customer = $openpay->customers->get(customerId);
$subscription = $customer->subscriptions->get(subscriptionId);
?>

Request example

<?
$openpay = Openpay::getInstance('moiep6umtcnanql3jrxp', 'sk_3433941e467c1055b178ce26348b0fac');

$customer = $openpay->customers->get('a9ualumwnrcxkl42l6mh');
$subscription = $customer->subscriptions->get('s7ri24srbldoqqlfo4vp');
?>

Response example

{
   "id":"s0gmyor4yqtyv1miqwr0",
   "status":"trial",
   "card":{
      "type":"credit",
      "brand":"american_express",
      "address":null,
      "card_number":"343434XXXXX4343",
      "holder_name":"Juan Perez Ramirez",
      "expiration_year":"20",
      "expiration_month":"12",
      "allows_charges":true,
      "allows_payouts":false,
      "bank_name":"AMERICAN EXPRESS",
      "bank_code":"103"
   },
   "cancel_at_period_end":false,
   "charge_date":"2016-01-12",
   "creation_date":"2014-05-22T15:56:18-05:00",
   "current_period_number":0,
   "period_end_date":"2016-01-11",
   "trial_end_date":"2016-01-11",
   "plan_id":"pbi4kb8hpb64x0uud2eb",
   "customer_id":"ag4nktpdzebjiye1tlze"
}

Gets the details of a customer subscription.

Request

PropertyDescription
idstring (required, length = 45)
Subscription identifier.

Response

Returns a subscription object

Cancel a Subscription

Definition

<?
$customer = $openpay->customers->get(customerId);
$subscription = $customer->subscriptions->get(subscriptionId);
$subscription->delete();
?>

Request example

<?
$openpay = Openpay::getInstance('moiep6umtcnanql3jrxp', 'sk_3433941e467c1055b178ce26348b0fac');

$customer = $openpay->customers->get('a9ualumwnrcxkl42l6mh');
$subscription = $customer->subscriptions->get('s7ri24srbldoqqlfo4vp');
$subscription->delete();
?>

Immediately cancels a customer subscription. No more charges will be made to the card and all pending charges will be cancelled.

Request

PropertyDescription
idstring (required, length = 45)
Identifier of the plan that will be deleted.

Response

If the response was successfully cancelled the response will be empty. Otherwise an error object explaining the reason.

Subscription list

Definition

<?
$customer = $openpay->customers->get(customerId);
$subscriptionList = $customer->subscriptions->getList(findDataRequest);
?>

Request example

<?
$openpay = Openpay::getInstance('moiep6umtcnanql3jrxp', 'sk_3433941e467c1055b178ce26348b0fac');

$findData = array(
    'creation[gte]' => '2013-01-01',
    'creation[lte]' => '2013-12-31',
    'offset' => 0,
    'limit' => 5);

$customer = $openpay->customers->get('a9ualumwnrcxkl42l6mh');
$subscriptionList = $customer->subscriptions->getList($findData);
?>

Response example

[
   {
      "id":"s0gmyor4yqtyv1miqwr0",
      "status":"trial",
      "card":{
         "type":"credit",
         "brand":"american_express",
         "address":null,
         "card_number":"343434XXXXX4343",
         "holder_name":"Juan Perez Ramirez",
         "expiration_year":"20",
         "expiration_month":"12",
         "allows_charges":true,
         "allows_payouts":false,
         "bank_name":"AMERICAN EXPRESS",
         "bank_code":"103"
      },
      "cancel_at_period_end":false,
      "charge_date":"2016-01-12",
      "creation_date":"2014-05-22T15:56:18-05:00",
      "current_period_number":0,
      "period_end_date":"2016-01-11",
      "trial_end_date":"2016-01-11",
      "plan_id":"pbi4kb8hpb64x0uud2eb",
      "customer_id":"ag4nktpdzebjiye1tlze"
   }
]

Returns all the subscriptions active for an specific customer.

Request

You can search using the following parameters:

PropertyDescription
creationdate
Same as creation date. Format yyyy-mm-dd
creation[gte]date
After the creation date. Format yyyy-mm-dd
creation[lte]date
Before the creation date. Format yyyy-mm-dd
offsetnumeric
Number of records to skip at the beginning, default 0.
limitnumeric
Number of required records, default 10.

Response

List of subscription objects for a customer. Sort by creation date in descending order.

Fees

If the customer accounts were created to handle their own balance, a fee can be charged which will be shown in the Merchant account.

Charging a Fee

Definition

<?
$fee = $openpay->fees->create(feeDataRequest);
?>

Request example

<?
$openpay = Openpay::getInstance('moiep6umtcnanql3jrxp', 'sk_3433941e467c1055b178ce26348b0fac');

$feeDataRequest = array(
    'customer_id' => 'a9ualumwnrcxkl42l6mh',
    'amount' => 12.50,
    'description' => 'Cobro de Comisión',
    'order_id' => 'ORDEN-00063');

$fee = $openpay->fees->create($feeDataRequest);
?>

Response example

{
   "amount":12.50,
   "authorization":null,
   "method":"customer",
   "operation_type":"out",
   "currency":"MXN",
   "transaction_type":"fee",
   "status":"completed",
   "id":"th8tafyrkakdbyry3kxi",
   "creation_date":"2013-11-18T10:33:03-06:00",
   "description":"Cobro de comisión",
   "error_message":null,
   "order_id":"oid-1245",
   "customer_id":"dvocf97jd20es3tw5laz"
}

Charge a fee to the customer account.

Request

PropertyDescription
customer_idstring (required, length = 45)
The unique identifier of the customer that you want to charge the fee.
amountnumeric (required)
Amount of charge. Must be an amount greater than zero, with up to two decimal digits.
descriptionstring (required, length = 250)
A description associated with the fee charge.
order_idstring (required, length = 100)
Unique fee identifier. It has to be unique among all the transactions.

Response

The transaction object of the fee including the creation date and id or an error response..

Refund Fee

Definition

<?
$fee = $openpay->fees->get(transactionId);
$fee->refund(refundData);
?>

Request example

<?
$openpay = Openpay::getInstance('moiep6umtcnanql3jrxp', 'sk_3433941e467c1055b178ce26348b0fac');

$refundData = array(
    'description' => 'Devolución de Comisión'
    );

$fee = $openpay->fees->get("trzjaozcik8msyqshka4");
$fee->refund($refundData);
?>

Response example

{
  "id": "th8tafyrkakdbyry3kxi",
  "authorization": null,
  "method": "customer",
  "operation_type": "in",
  "transaction_type": "refund",
  "status": "completed",
  "conciliated": true,
  "creation_date": "2016-09-06T11:56:57-05:00",
  "operation_date": "2016-09-06T11:56:57-05:00",
  "description": "devolución de comisión merchant03",
  "error_message": null,
  "order_id": null,
  "customer_id": "ar2btmquidjhykdaztp6",
  "amount": 11.11,
  "currency": "MXN"
}

Refund a fee to the customer account.

Request

PropertyDescription
descriptionstring (optional, length = 250)
A description associated with the fee charge.

Response

The transaction object of the refund including the creation date and id or an error response..

Fee list

Definition

<?
$feeList = $openpay->fees->getList(findDataRequest);
?>

Request example

<?
$openpay = Openpay::getInstance('moiep6umtcnanql3jrxp', 'sk_3433941e467c1055b178ce26348b0fac');

$findData = array(
    'creation[gte]' => '2013-01-01',
    'creation[lte]' => '2013-12-31',
    'offset' => 0,
    'limit' => 5);

$feeList = $openpay->fees->getList($findDataRequest);
?>

Response example

[
   {
      "amount":30.00,
      "authorization":null,
      "method":"customer",
      "operation_type":"out",
      "currency":"MXN",
      "transaction_type":"fee",
      "status":"completed",
      "id":"th8tafyrkakdbyry3kxi",
      "creation_date":"2013-11-18T10:33:03-06:00",
      "description":"Cobro de comisión",
      "error_message":null,
      "order_id":"oid-1367",
      "customer_id":"dvocf97jd20es3tw5laz"
   },
   {
      "amount":12.00,
      "authorization":null,
      "method":"customer",
      "operation_type":"out",
      "currency":"MXN",
      "transaction_type":"fee",
      "status":"completed",
      "id":"tdzottaaohuhosf4cdv9",
      "creation_date":"2013-11-17T05:35:00-06:00",
      "description":"Cobro de comisión",
      "error_message":null,
      "order_id":"oid-1366",
      "customer_id":"afk4csrazjp1udezj1po"
   }
]

Returns the details of every fee charged by the Merchant.

Request

It can be done using the following parameters:

PropertyDescription
creationdate
Same as creation date. Format yyyy-mm-dd
creation[gte]date
After the creation date. Format yyyy-mm-dd
creation[lte]date
Before the creation date. Format yyyy-mm-dd
offsetnumeric
Number of records to skip at the beginning, default 0.
limitnumeric
Number of required records, default 10.

Response

Returns an array of transaction objects for the charged fees in descending order, each one with the identifier of the customer to whom it was made.

Webhooks

Weebhooks allow to notify a Merchant party when an event has occurred in the platform, so the Merchant can take the corresponding actions.

Webhook Object

Object example

  {
    "id" : "wxvanstudf4ssme8khmc",
    "url" : "http://requestb.in/11vxrsf1",
    "user" : "juanito",
    "password" : "passjuanito",
    "event_types" : [
      "charge.refunded",
      "charge.failed",
      "charge.cancelled",
      "charge.created",
      "chargeback.accepted"
    ],
    "status":"verified"
}
PropertyDescription
idstring
Unique webhook identifier number.
urlstring
Webhook
userstring
User name used for webhook’s basic authentication.
passwordstring
Password for webhook’s basic authentication.
event_typesarray[string]
List of events where the webhook will be triggered.
statusstring
Webhook status, it indicates if it’s verified or not (unverified).
EventCategoryDescription
charge.refundedChargesReports when there is a charge refund.
charge.failedChargesReports when a charge failed and it wasn’t applied.
charge.cancelledChargesReports when a charge is cancelled.
charge.createdChargesReports when a charge is scheduled.
charge.succeededChargesReports when a charge is applied.
charge.rescored.to.declineChargesReports when a charge’ score is recalculated and is declined.
subscription.charge.failedSuscripciónReports when the charge to a subscription fails.
payout.createdPaymentsReports when a payout has been scheduled for the next day.
payout.succeededPaymentsReports when a payout has been applied.
payout.failedPaymentsReports when a payout has failed.
transfer.succeededWire transfersReports when a transfer has been performed between to Openpay accounts.
fee.succeededFeesReports when a fee is charged successfully to a customer.
fee.refund.succeededFeesReports when a fee has been successfully refunded to a customer.
spei.receivedSPEIReports when a payout has been received by SPEI for adding funds to the account.
chargeback.createdChargebacksReports when a chargeback of a transaction was receive and a transaction has been initiated.
chargeback.rejectedChargebacksReports when a chargeback has been rejected.
chargeback.acceptedChargebacksReports when a chargeback has been accepted.
order.createdOrderReports when an order is created an scheduled.
order.activatedOrderReports when an order is activated.
order.payment.receivedOrderReports when an order is received.
order.completedOrderReports when an order is completed.
order.expiredOrderReports when an order has expired.
order.cancelledOrderReports when an order is canceled.
order.payment.cancelledOrderReports when a payment order is canceled.

Valid Webhook service features

  • Endpoint: Domains only (No IPs). example: https://notifications.merchant.com
  • Port: 443/TCP, 1518/TCP, 1519/TCP, 8443/TCP y 10443/TCP
  • Protocol: HTTPS/TLS_1.2
  • Certificate: Valid (Signed by public CA and match with domain).

Webhook Creation

Definition

<?
$webhook = $openpay->webhooks->add(webhook);
?>

Request example

<?
$openpay = Openpay::getInstance('moiep6umtcnanql3jrxp', 'sk_3433941e467c1055b178ce26348b0fac');

$webhook = array(
    'url' => 'http://requestb.in/11vxrsf1',
    'user' => 'juanito',
    'password' => 'passjuanito',
    'event_types' => array(
      'charge.refunded',
      'charge.failed',
      'charge.cancelled',
      'charge.created',
      'chargeback.accepted'
    )
    );

$webhook = $openpay->webhooks->add($webhook);
?>

Response example

{
  "id" : "wkn0t30zfxpmhr5usgfa",
  "url" : "http://requestb.in/qt3bq0qt",
  "user" : "juanito",
  "event_types" : [
    "charge.succeeded",
    "charge.created",
    "charge.cancelled",
    "charge.failed"
  ],
  "status" : "verified"
}

When you save webhooks an ID will be generated that can be used to eliminate it or simply get not sensitive webhook information.

At the time of saving the webhook, an id will be generated that can be used to eliminate or simply obtain the non-sensitive information from the webhook.

Request

PropertyDescription
urlstring
Webhook
userstring
User name used for webhook’s basic authentication.
passwordstring
Password for webhook’s basic authentication.
event_typesarray[string]
List of events where the webhook will be triggered.

Response

Returns a webhook object when it was successfully created or an error response if there was an error on creation.

Get a Webhook

Definition

<?
$webhook = $openpay->webhooks->get(webhookId);
?>

Request example

<?
$openpay = Openpay::getInstance('moiep6umtcnanql3jrxp', 'sk_3433941e467c1055b178ce26348b0fac');

$webhook = $openpay->webhooks->get('wxvanstudf4ssme8khmc');
?>

Response example

  {
    "id" : "wxvanstudf4ssme8khmc",
    "url" : "http://requestb.in/11vxrsf1",
    "user" : "juanito",
    "event_types" : [
      "verification",
      "charge.refunded",
      "charge.failed",
      "charge.cancelled",
      "charge.created",
      "charge.succeeded",
      "subscription.charge.failed",
      "payout.created",
      "payout.succeeded",
      "payout.failed",
      "transfer.succeeded",
      "fee.succeeded",
      "spei.received",
      "chargeback.created",
      "chargeback.rejected",
      "chargeback.accepted"
    ],
    "status" : "verified"
  }

Get a list of the webhook details by ID.

Request

PropertyDescription
idstring (required, length = 45)
Unique webhook identifier

Response

Returns a webhook object

Delete a Webhook

Definition

<?
$webhook = $openpay->webhooks->get(webhookId);
$webhook->delete();
?>

Customer request example

<?
$openpay = Openpay::getInstance('moiep6umtcnanql3jrxp', 'sk_3433941e467c1055b178ce26348b0fac');

$webhook = $openpay->webhooks->get('wxvanstudf4ssme8khmc');
$webhook->delete();
?>

Delete a webhook from the merchant.

To delete a webhook you only need to provide the ID.

Request

PropertyDescription
idstring (required, length = 45)
Unique webhook identifier

Response

If the webhook was deleted correctly the response will be empty, if the webhook cannot be deleted an error object explaining the reason.

Webhook list

Definition

<?
$webhookList = $openpay->webhooks->getList();
?>

Request example

<?
$openpay = Openpay::getInstance('moiep6umtcnanql3jrxp', 'sk_3433941e467c1055b178ce26348b0fac');

$webhookList = $openpay->webhooks->getList();
?>

Response example

[
  {
    "id" : "wDashboard185",
    "event_types" : [
      "verification",
      "charge.refunded",
      "charge.failed",
      "charge.cancelled",
      "charge.created",
      "charge.succeeded",
      "subscription.charge.failed",
      "payout.created",
      "payout.succeeded",
      "payout.failed",
      "transfer.succeeded",
      "fee.succeeded",
      "spei.received",
      "chargeback.created",
      "chargeback.rejected",
      "chargeback.accepted"
    ],
    "url" : "http://requestb.in/11vxrsf1",
    "status" : "verified"
  },
  {
    "id" : "wDashboard186",
    "event_types" : [
      "verification",
      "charge.refunded",
      "charge.failed",
      "charge.cancelled",
      "charge.created",
      "charge.succeeded",
      "subscription.charge.failed"
    ],
    "url" : "http://requestb.in/1fhpiog1",
    "status" : "verified"
  }
]

Returns a list registered by the merchant.

Request

Response

The list of webhook object registered according to the given parameters.

Tokens

The objective is to created tokens from the user browser or device to capture the card information so this doesn’t go through your server and you can avoid or reduce the PCI certification process.

To use this API functionality we recommend using our JavaScript library for your Web application and our Android and iOS SDK for mobile apps.

Features

  • Tokens are created at Merchant level.
  • Tokens are not link to any customer.
  • After a token has been created it can only be use once to make a charge.

Token Object

Object example

{
      "id":"tokfa4swch8gr4icy2ma",
      "card":{
         "card_number":"1111",
         "holder_name":"Juan Perez Ramirez",
         "expiration_year":"20",
         "expiration_month":"04",
         "address":{
            "line1":"Av 5 de febrero",
            "line2":"Roble 207",
            "line3":"Queretaro",
            "state":"Queretaro",
            "city":"Queretaro",
            "postal_code":"76900",
            "country_code":"MX"
         },
         "creation_date":"2014-01-30T13:53:11-06:00",
         "brand":"visa",
         "points_card":false
      }
   }
PropertyDescription
idstring
Token identifier. This is the ID that you should use to perform operations.
cardobject
Card associated with the token. See card object

Create a new token

Definition

POST https://sandbox-api.openpay.mx/v1/{MERCHANT_ID}/tokens

Request example

Response example

{
   "id":"k1n0mscnjwhxqia8q7cm",
   "card":{
      "card_number":"411111XXXXXX1111",
      "holder_name":"Juan Perez Ramirez",
      "expiration_year":"20",
      "expiration_month":"12",
      "address":{
         "line1":"Av 5 de Febrero",
         "line2":"Roble 207",
         "line3":"col carrillo",
         "state":"Queretaro",
         "city":"Querétaro",
         "postal_code":"76900",
         "country_code":"MX"
      },
      "creation_date":null,
      "brand":"visa"
   }
}

To create a token using Openpay you need to send the object with the info that will be stored. Once the token it’s stored, you can’t get the number and secutirty code because this information is encrypted.

Request

PropertyDescription
holder_namestring (required)
Name of the cardholder.
card_numbernumeric (required)
Card Number, it can be 16 or 19 digits.
cvv2numeric (required)
Security code as it appears on the back of the card. Usually 3 digits.
expiration_monthnumeric (required)
Expiration month as it appears on the card.
expiration_yearnumeric (required)
Expiration year as it appears on the card.
addressobject (optional)
Billing address of cardholder.

Repuesta

Returns the created token object or an error response. if an error occurred during the creation.

Get a Token

Definition

GET https://sandbox-api.openpay.mx/v1/{MERCHANT_ID}/tokens/{TOKEN_ID}

Request example

Response example

{
   "id":"k1n0mscnjwhxqia8q7cm",
   "card":{
      "card_number":"411111XXXXXX1111",
      "holder_name":"Juan Perez Ramirez",
      "expiration_year":"20",
      "expiration_month":"12",
      "address":{
         "line1":"Av 5 de Febrero",
         "line2":"Roble 207",
         "line3":"col carrillo",
         "state":"Queretaro",
         "city":"Querétaro",
         "postal_code":"76900",
         "country_code":"MX"
      },
      "creation_date":null,
      "brand":"visa"
   }
}

Gets the token details. The ID is required.

Request

PropertyDescription
idstring (required, length = 45)
Token ID

Response

Returns a token object

Merchant

The merchant object allows you to query info related to your account using the API,

Merchant Object

Object example:

{ 
   "id": "m9lrykwsmljagrfb38rs", 
   "creationDate": "2013-11-13T16:58:40-06:00", 
   "name": "Promociones en linea", 
   "email": "contacto@enlinea.com.mx", 
   "phone": "(321) 222-2222", 
   "status": "active", 
   "balance": 1000, 
   "clabe": "646180109400000542" 
} 
PropertyDescription
idstring
Unique identifier assigned on creation.
creation_datedatetime
Creation date of the transaction in format ISO 8601.
namestring
Registered merchant name.
emailstring
Email account registered for the merchant.
phonestring
Phone number registered for the merchant.
statusstring
Merchant account status, it can be active or deleted. If the account is in deletate status no transactions are allowed.
balancenumeric
Account balance with two decimal digits.
clabenumeric
Linked CLABE account where funds can be received from any bank in Mexico using SPEI.

Request a Merchant Object

Definition

<?
// =============================
// Funcionalidad no implementada
// =============================
?>

Request example

Response example

{
   "name":"Demo Openpay",
   "email":"demo@openpay.mx",
   "phone":"(442) 258-1039",
   "status":"active",
   "balance":218.73,
   "clabe":"646180109400135624",
   "id":"mzdtln0bmtms6o3kck8f",
   "creation_date":"2014-01-23T10:45:53-06:00"
}

Returns the merchant account details. Only the unique merchant identifier is required.

Request

PropertyDescription
idstring (required, length = 45)
unique merchant identifier.

Response

If the identifier is correct it will return a merchant object.

Stores

The object represents a convenience store

Store object

Object example:

{
    "id_store": 4913,
    "id": 115,
    "name": "0503 SAN PABLO -QRO",
    "last_update": "2016-02-04T00:52:16-06:00",
    "status": "active",
    "geolocation": {
      "lng": -100.421865,
      "lat": 20.618171,
      "place_id": "ChIJwSN2wpNa04URsDryLW517lg"
    },
    "address": {
      "line1": "AV. 5 DE FEBRERO KM 7.5 NO 1341",
      "line2": "SAN PABLO",
      "line3": null,
      "state": "QUERETARO",
      "city": "QUERETARO",
      "postal_code": "76030",
      "country_code": "MX"
    },
    "paynet_chain": {
      "name": "EXTRA",
      "logo": "http://www.openpay.mx/logotipos/extra.png",
      "thumb": "http://www.openpay.mx/thumb/extra.png",
      "max_amount": 99999.99
    }
  }
PropertyDescription
id_storestring
Unique identifier assigned on creation.
idstring
Unique identifier by chain.
namedatetime
Store name.
last_updatestring
Last date of update in format ISO 8601.
geolocationobject
Store geographical representation by coordinates, latitude and longitude.
addressobject
Store address.
paynet_chainobject
Paynet chain to which it belongs.

Get list of shops by location

Definition

<?
// =============================
// Funcionalidad no implementada
// =============================
?>

Request example

Response example

[
  {
    "id_store": 4913,
    "id": 115,
    "name": "0503 SAN PABLO -QRO",
    "last_update": "2016-02-04T00:52:16-06:00",
    "status": "active",
    "geolocation": {
      "lng": -100.421865,
      "lat": 20.618171,
      "place_id": "ChIJwSN2wpNa04URsDryLW517lg"
    },
    "address": {
      "line1": "AV. 5 DE FEBRERO KM 7.5 NO 1341",
      "line2": "SAN PABLO",
      "line3": null,
      "state": "QUERETARO",
      "city": "QUERETARO",
      "postal_code": "76030",
      "country_code": "MX"
    },
    "paynet_chain": {
      "name": "EXTRA",
      "logo": "http://www.openpay.mx/logotipos/extra.png",
      "thumb": "http://www.openpay.mx/thumb/extra.png",
      "max_amount": 99999.99
    }
  },
  {
    "id_store": 4726,
    "id": 68,
    "name": "ASTURIANO TECNOLOGICO",
    "last_update": "2016-02-04T00:52:16-06:00",
    "status": "active",
    "geolocation": {
      "lng": -100.410136,
      "lat": 20.61632,
      "place_id": "EktQcm9sIFRlY25vbMOzZ2ljbyBOdGUgOTk5LCBTYW4gUGFibG8sIFNhbnRpYWdvIGRlIFF1ZXLDqXRhcm8sIFFyby4sIE3DqXhpY28"
    },
    "address": {
      "line1": "PROLONGACION TECNOLOGICO NORTE #999",
      "line2": "SAN PABLO",
      "line3": null,
      "state": "QUERETARO",
      "city": "QUERETARO",
      "postal_code": "76159",
      "country_code": "MX"
    },
    "paynet_chain": {
      "name": "EL ASTURIANO",
      "logo": "http://www.openpay.mx/logotipos/asturiano.png",
      "thumb": "http://www.openpay.mx/thumb/asturiano.png",
      "max_amount": 99999.99
    }
  }
]

Gets the trade account details. Only it required to indicate the unique id of trade to be obtained.

Request

PropertyDescription
latitudnumeric (required)
Latitude of geographical location Store
longitudnumeric (required)
Longitud of geographical location Store
kilometersnumeric (required)
Radius distance in kilometers search
amountnumeric (required)
Purchase amount

Response

If there are stores close range a settlement with stores found it is returned.

Common Objects

Information for objects shared in request and response.

Transaction Object

Object example:

{
   "id":"trehwr2zarltvae56vxl",
   "authorization":null,
   "transaction_type":"payout",
   "operation_type":"out",
   "currency":"MXN",
   "method":"bank",
   "creation_date":"2013-11-14T18:29:35-06:00",
   "order_id":"000001",
   "status":"in_progress",
   "amount":500,
   "description":"Pago de ganancias",
   "error_message":null,
   "customer_id":"afk4csrazjp1udezj1po",
   "bank_account":{
      "rfc":ONE316015PM1,
      "mobile":null,
      "alias":null,
      "bank_name":"BANCOMER",
      "creation_date":"2013-11-14T18:29:34-06:00",
      "clabe":"012XXXXXXXXXX24616",
      "holder_name":"Juan Tapia Trejo",
      "bank_code":"012"
   }
}
PropertyDescription
idstring
Unique identifier assigned by Openpay at the moment of creation.
authorizationstring
Authorization number created by the processor entity.
transaction_typestring
Transaction type: fee, charge, payout, transfer.
operation_typestring
Operation type in the account: in, out.
methodstring
Transaction method type: card, bank o customer.
creation_datedatetime
Creation date of the transaction in format ISO 8601.
order_idstring
Unique transaction and reference number.
statusstring
Current transaction status. Possible values: completed, in_progress, failed.
amountnumeric
Transaction full amount, including two decimal places.
descriptionstring
Transaction description.
error_messagestring
If the transaction is in failed status, this field will include the error message.
customer_idstring
Unique identifier for the customer who this transaction belongs. If the value is null the transaction belongs to Merchant account.
currencystring
Currency used in the operation by default is MXN (Mexican pesos).
bank_accountobject
Bank account data used for the transaction. See the BankAccount object.
cardobject
Credit card data used in the transaction. See the Card object.
card_pointsobject
Contains information about the reward points used for payment, if they were used. See the CardPoints object

Address Object

Object example:

{
   "line1":"Av 5 de Febrero",
   "line2":"Roble 207",
   "line3":"col carrillo",
   "state":"Queretaro",
   "city":"Querétaro",
   "postal_code":"76900",
   "country_code":"MX" 
}
PropertyDescription
line1string (required)
The first line is the card owner address. It’s commonly used to indicate street address and number.
line2string
Second addres line, commonly use to indicate interior number, suite number or county.
line3string
Third address line, commonly use to to indicate the neighborhood.
postal_codestring (required)
Zip code
statestring (required)
State
citystring (required)
City
country_codestring (required)
Country code, in the two character format: ISO_3166-1.

Store object

Object example:

{
   "reference":"OPENPAY02DQ35YOY7",
   "barcode_url":"https://sandbox-api.openpay.mx/barcode/OPENPAY02DQ35YOY7?width=1&height=45&text=false",
   "paybin_reference":"0101990000001065",
   "barcode_paybin_url":"https://sandbox-api.openpay.mx/barcode/0101990000001065?width=1&height=45&text=false"
}
PropertyDescription
referencestring
Payment reference to go stores and make deposits to Openpay account
barcode_urlstring
It is the url that generates the bar code of reference.
paybin_referencestring
Paybin reference to go store and make deposits to Openpay
barcode_paybin_urlstring
It is the url that generates the bar code of paybin reference.

PaymentPlan Object

Object example:

{
   "payments":"6"
}
PropertyDescription
paymentsnumeric
Plan data months without interest is desired as use in the charge (3, 6, 9, 12, 18).

Cardpoints Object

Object example:

{
    "used": 134,
    "remaining": 300,
    "caption": "TRANSACCION APROBADA. ME OBLIGO EN LOS TERMINOS Y CONDICIONES DEL PROGRAMA RECOMPENSAS SANTANDER. PARA CUALQUIER DUDA O ACLARACION LLAME AL 01800 RECOMPE (73-266-73).",
    "amount": 10
}
PropertyDescription
usednumeric
Amount of points used in the payment.
remainingnumeric
Amount of points remaining in the card after the payment.
amountnumeric
Transaction amount paid using points.
captionstring (optional)
A message to be shown to the customer in their ticket or receipt.

Object Geolocation

Object example:

{
  "lng": -100.421865,
  "lat": 20.618171,
  "place_id": "ChIJwSN2wpNa04URsDryLW517lg"
}
PropertyDescription
lngnumeric
Longitud, geographical coordinate.
latnumeric
Latitud, geographical coordinate.
place_idstring
Unique identifier of google maps

Object PaynetChain

Object example:

{
      "name": "EXTRA",
      "logo": "http://www.openpay.mx/logotipos/extra.png",
      "thumb": "http://www.openpay.mx/thumb/extra.png",
      "max_amount": 99999.99
    }
PropertyDescription
namestring
Chain name.
logostring
URL logo image chain.
thumbstring
URL thumbnail image chain.
max_amountnumeric
Maximum payment amount that accept chain stores

Object Transaction Status

ValueDescription
IN_PROGRESSTransaction is in progress
COMPLETEDTransaction was succesfully completed
REFUNDEDTransaction that has been refunded
CHARGEBACK_PENDINGTransaction that has a pending chargeback
CHARGEBACK_ACCEPTEDTransaction that has an accepted chargeback
CHARGEBACK_ADJUSTMENTTransaction that has an ajust for chargeback
CHARGE_PENDINGTransaction that is waiting to be paid
CANCELLEDTransaction that was not paid and has been cancelled
FAILEDTransaction that was paid but ocurred an error

Electronic Invoice

Generation of CFDI Object

FieldDescription
openpay_transaction_idOptional
Id of the transaction in openpay
invoice_idRequired
Invoice identifier / trade purchase order
tipo_comprobanteOptional (default (I) income)
Voucher Type Object.
serieOptional (1-25 Alphanumeric)
series invoice in case of handling
folioOptional payment (1-40 Alphanumeric)
Folio of the invoice in case of handling
totalRequired (Decimal)
Total invoice
subtotalRequired (Decimal)
Subtotal of the invoice
forma_pagoRequired
Way to pay
Only the payment code corresponding to the payment method must be sent.
Form of Payment Object.
metodo_pagoRequired
Payment method
Payment Method Object.
lugar_expedicionRequired (5 digits)
Postal Code of the Place of Expedition
descuentoOptional (Decimal)
Discount amount.
observacionesOpcional (Alfanumérico)
Observations
total_trasladadosOptional (Decimal)
Total taxes transferred if they exist
total_retenidosOptional (Decimal)
Total taxes withheld if there are
monedaRequired (3 Alphanumeric)
Currency in which the sale was made in case it is different from MXN. (ISO 4217)
tipo_de_cambioRequired (Decimal)
Exchange rate of the currency in which the sale was made. 1.00 in case the currency is MXN.
receptorRequired (Receiver Object)
Node that contains the data of the recipient of the invoice
conceptosRequired (Arrangement of Concept Object)
Arrangement of concepts included in the invoice
cfdi_relacionadosOptional (Objeto Relacionados)
Related invoices
complementsOptional (Complements Object)
Complements

Voucher Type Object

Tax receipt typeFiscal Document
(I) entry
  • Invoice.
  • Fee.
  • Charge note.
  • Donations.
  • Lease.
(E) egress
  • Credit note.
  • Note of refund.
  • paysheet.
  • Assimilables.
(T) transfer
  • Letter porte.
(N) paysheet
  • paysheet.
(P) Payment
  • Payment.

Form of Payment Object

KeyDescription
01Cash.
02Cheque nominative.
03Electronic funds transfer.
04Credit card.
05Electronic Wallet.
06Electronic Money.
08Pantry vouchers.
12Dation in payment.
13Payment by subrogation.
14Payment by consignment.
15Condonation.
17Compensation.
23Novation.
24Confusion.
25Debt remittance.
26Prescription or expiration.
27To the satisfaction of the creditor.
28Debit Card.
29Service Card.
30Application of advances.
99Others.

Payment Method Object

KeyDescription
PUEPayment only exhibition
PPDPartial or deferred payments

DoctoRelacionado Object

KeyDescription
id_documentoRequired (16-36 Alphanumeric)
Document identifier (uuid).
serieOptional (1-25 Alphanumeric)
Document series.
folioOptional (1-40 Alphanumeric)
Folio of the document.
moneda_d_rRequired (3 Alphabetical)
Currency Code (ISO 4217).
tipo_cambio_d_rOptional (Decimal)
Exchange rate.
metodo_de_pago_d_rOptional
Payment method.
num_parcialidadOptional
Partiality number.
imp_saldo_antOptional (Decimal)
Amount of the previous balance.
imp_pagadoOptional (Decimal)
Amount paid.
imp_saldo_insolutoOptional (Decimal)
Amount of the outstanding balance.

Concept Object

KeyDescription
IdentificadorRequired (1-100 Alphanumeric)
Concept identifier.
cantidadRequired (Decimal)
Amount of the concept.
unidadOptional (1-20 Alphanumeric)
Unit of the concept.
clave_unidadRequired (Alphanumeric, Key Unit Catalog)
Unit key.
descripcionRequired (1-1000 Alphanumeric)
Description of the concept.
valor_unitarioRequired (Decimal)
Unit value of the concept.
importeRequired (Decimal)
Amount of the transferred tax.
claveRequired (1-10 Numérico)
Key of the product.
descuentoOptional (Decimal)
Discount amount.
trasladosOptional (Arrangement Tax Object)
Transfer tax list.
retencionesOptional (Arrangement Tax Object)
Retention tax list.

Tax Object

KeyDescription
impuestoRequired
Tax
Tax Type Object.
tipo_factorRequired
Type of factor
Codes:
  • Rate
  • Quota
  • Excento
tasaRequired
Decimal
Rate that will be used to calculate the tax
importeRequired
Tax amount calculated
baseOptional
Amount on which the Tax will be applied

Tax Type Object

CodeDescription
001ISR
002IVA
003IEPS

Receiver Object

FieldDescription
nombreRequired (1-254 Alphanumeric)
Name of the recipient of the invoice.
rfcRequired
RFC of the invoice recipient.
emailOptional
Invoice recipient’s email.
residencia_fiscalOptional
Postal code of the fiscal residence.
uso_cfdiRequired (3 Alphanumeric)
Object Use of CFDI.
paisOptional (3 Alphanumeric)
Country code (ISO 3166-1 alpha-3). It should not be sent if the RFC is registered with the SAT or is a national generic RFC.

Object Use of CFDI

CodeDescription
G01Acquisition of merchandise.
G02Returns, discounts or bonuses.
G03Expenses in general.
I01Buildings.
I02Office furniture and equipment for investments.
I03Transportation equipment.
I04Computer equipment and accessories.
I05Dices, dies, molds, matrices and tooling.
I06Telephone communications.
I07Satellite communications.
I08Other machinery and equipment.
D01Medical and dental fees and hospital expenses.
D02Medical expenses due to disability or disability.
D03Funeral expenses.
D04Donations.
D05Real interest actually paid for mortgage credits (house room).
D06Voluntary contributions to SAR.
D07Premiums for medical expenses insurance.
D08Mandatory school transportation expenses.
D09Deposits in accounts for savings, premiums based on pension plans.
D10Payments for educational services (tuition fees).
P01To define.

Related Object

FieldDescription
tipo_relacionRequired
Type relationship
Object Type of Relationship.
relacionadosRequired (Object arrangement CfdiRelacionado)
CFDI Object Related.

Object Type of Relationship

CodeDescription
01Credit note of related documents.
02Debit note of related documents.
03Return of merchandise on previous invoices or transfers.
04Replacement of previous CFDIs.
05Goods transfers previously invoiced.
06Invoice generated by previous transfers.
07CFDI by advance payment.

CFDI Object Related

FieldDescription
uuidRequired (36 Alphanumeric)
UUID of the related invoice

Complements Object

FieldDescription
aerolineasOptional (Complement Airlines Object)
Complement for Airline.
payoutsOptional (Complement Payment Object)
Complement of payments.
donatariasOptional (Complement Donee Object)
Complement of donee.

Complement Airlines Object

FieldDescription
tuaRequired (Decimal)
Airport use fee
otrosCargosOptional (Arrangement Charge Airlines Object)
Complement of payments.

Charge Airlines Object

FieldDescription
codigo_cargoOptional
Charge code.
descripcion_cargoOptional
Charge description.
importeOptional (Decimal)
Charge amount.

Complement Payment Object

FieldDescription
fecha_pagoRequired
Date of the operation.
forma_de_pagoRequired
Way to pay.
moneda_pRequired (Decimal)
Charge amount.
tipo_cambio_pRequired (Decimal)
Exchange rate of the currency in which the sale was made. 1.00 in case the currency is MXN.
montoRequired (Decimal)
Payment amount.
num_operacionOptional (1-100 Alphanumeric)
Payment number.
rfc_emisor_cta_ordOptional
RFC of the issuer.
nom_banco_ord_extOptional (1-300 Alphanumeric)
Name of the bank.
cta_ordenanteOptional (10-50 Alphanumeric)
Ordering account.
rfc_emisor_cta_benBeneficiary
cta_beneficiarioOptional (10-50 Alphanumeric)
Beneficiary account.
tipo_cad_pagoOptional (único valor válido 01)
Type of payment chain.
cert_pagoOptional (byte[])
Payment certificate.
sello_pagoOptional (byte[])
Payment stamp.
cad_pagoOptional (1-8192 Alphanumeric)
Chain.
docto_relacionadosOptional (Arrangement DoctoRelacionado Object).

Complement Donee Object

FieldDescription
no_autorizacionRequired
Authorization number
fecha_autorizacionRequired
Authorization date (YYYY-MM-DD)
leyendaRequired
Caption

Request Response Generation Object

FieldDescription
invoice_idIdentifier of the invoice sent in the request.
request_idRequest ID generated by Openpay.
dateDate on which the generation was requested
statusPENDING, OK, ERROR.
fiscal_statusACTIVE, CANCELLED.
messageStatus description.

Notifications Object

FieldDescription
invoice_idIdentifier of the invoice sent in the request.
serieInvoice series.
folioFolio of the invoice.
transaction_idOpenpay transaction identifier linked to the invoice.
creation_dateApplication date.
issue_dateIssue date of the invoice.
uuidUUID of the invoice.
receiver_rfcRFC of the invoice recipient.
totalTotal invoice
subtotalSubtotal of the invoice
statusPENDING, OK, ERROR.
fiscal_statusACTIVE, CANCELLED.
cancellation_dateDate of cancellation of the invoice in case it is canceled.
public_xml_linkLink to download the XML of the invoice.
public_pdf_linkLink to download the PDF of the invoice.
link_expiration_dateExpiration of the download leagues, once expired the xml / pdf can be downloaded from the dashboard.
messageDetail of the status of the invoice.

Contact

Your money is always safe

® Openpay All Rights Reserved 2021