Skip to main content
This guide shows you how to create payments using alternative payment methods (APMs) through Tonder’s unified Process Transaction endpoint. You can process local payment options like SPEI bank transfers and OXXO Pay cash payments through a single, consistent API call.
Looking for card payments?This guide covers non-card payment methods only. For credit and debit card processing, see the Card Payments Overview.

Step 1: The Core Request

All payments are created by sending a POST request to the Process Transaction endpoint. The request body must contain required fields that are common to all payment methods, plus a payment_method object with specific fields for your chosen payment method.
POST https://stage.tonder.io/api/v1/process/

Basic Request Structure

Every payment request to the Process Transaction endpoint follows this structure:
{
  "operation_type": "payment",
  "amount": 100.00,
  "currency": "MXN",
  "customer": {
    "name": "Test Customer",
    "email": "[email protected]"
  },
  "payment_method": {
    "type": "SPEI"
    // ... additional fields based on the type
  },
  "client_reference": "your-internal-order-id-123"
}
These fields are required for all payment requests:
FieldTypeDescription
operation_typestringMust be "payment" to process a payment transaction.
amountdecimalTransaction amount using a dot as decimal separator (e.g., 100.00).
currencystringTransaction currency. Currently only "MXN" (Mexican Peso) is supported.
customerobjectCustomer information containing at minimum name (string) and email (string).
payment_methodobjectPayment method configuration with a type field and method-specific parameters.
client_referencestringYour unique transaction identifier for reconciliation and tracking purposes.
Depending on the payment method you choose, additional fields may be required inside the payment_method object. For detailed information about each payment method and their specific requirements, see the Payment Methods Overview.

Step 2: Processing Different Payment Methods

To process a specific payment method, you change the type inside the payment_method object and provide any required additional fields. The examples below show how to process different payment methods.
To let a customer pay via a SPEI transfer, set the type to SPEI. The API will generate payment instructions for the customer. Here’s an example request:
SPEI Bank Transfer
{
  "operation_type": "payment",
  "amount": 500.00,
  "currency": "MXN",
  "customer": {
    "name": "Carlos Eduardo López",
    "email": "[email protected]"
  },
  "payment_method": {
    "type": "SPEI"
  },
  "client_reference": "spei-test-001"
}
A successful SPEI response will have a status of pending and includes payment instructions for the customer:
SPEI Payment Response
{
  "id": "550e8400-e29b-41d4-a716-446655440001",
  "operation_type": "payment",
  "status": "pending",
  "amount": 500.00,
  "currency": "MXN",
  "merchant_reference": "spei-test-001",
  "payment_id": 12346,
  "transaction_id": "txn_spei456",
  "provider": "spei_provider",
  "created_at": "2024-07-26T10:35:00Z",
  "status_code": 201,
  "payment_instructions": {
    "clabe": "646180157000000004",
    "reference": "7812345678",
    "expires_at": "2024-07-27T10:35:00Z",
    "bank_name": "STP"
  }
}
Display the payment_instructions to your customer so they can complete the bank transfer. The clabe is the destination account number and reference should be included in the transfer description.
To generate a voucher for a cash payment at an OXXO store, set the type to oxxopay. Here’s an example request:
OXXO Cash Payment
{
  "operation_type": "payment",
  "amount": 250.00,
  "currency": "MXN",
  "customer": {
    "name": "María Isabel Fernández",
    "email": "[email protected]"
  },
  "payment_method": {
    "type": "oxxopay"
  },
  "client_reference": "oxxopay-test-001"
}
A successful OXXO Pay response will have a status of pending and includes payment instructions with a barcode and reference for the customer:
OXXO Payment Response
{
  "id": "550e8400-e29b-41d4-a716-446655440002",
  "operation_type": "payment",
  "status": "pending",
  "amount": 250.00,
  "currency": "MXN",
  "merchant_reference": "oxxopay-test-001",
  "payment_id": 12347,
  "transaction_id": "txn_oxxo789",
  "provider": "oxxopay_provider",
  "created_at": "2024-07-26T10:40:00Z",
  "status_code": 201,
  "payment_instructions": {
    "reference": "98765432109876543210",
    "barcode": "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAA...",
    "expires_at": "2024-08-02T10:40:00Z",
    "store_name": "oxxopay"
  }
}
Display the barcode image and reference number to your customer. They can present either at any OXXO store to complete the payment. Note that OXXO payments typically have a longer expiration window (usually 7 days).
For detailed information about each payment method and their specific requirements, see the Payment Methods Overview.

Step 3: Handling the Response

After you send the request, the API will respond immediately with the initial status of the transaction. The status field can have one of the following values:
StatusDescription
pendingTransaction is being processed (common for asynchronous payments)
on_holdTransaction is temporarily held for review
processingTransaction is being processed by the payment provider
sent_to_providerTransaction has been sent to the payment provider
successTransaction completed successfully
paid_fullPayment has been fully processed and settled
in_transitFunds are in transit to your account
canceledTransaction was canceled before completion
declinedPayment was declined by the provider
rejectedTransaction was rejected
failedTransaction failed to process
expiredTransaction expired before completion
UnknownStatus is unknown or unclear
Validation of id and status fieldsFor proper payment validation, you must check:
  • id is the unique transaction identifier - store this for future reference.
  • status is the current payment state - determines next actions.
Never rely on HTTP status codes alone for payment validation.
The table below details the fields that are returned in the response:
FieldTypeDescription
idstringUnique transaction identifier
operation_typestringAlways "payment"
statusstringTransaction status
amountdecimalTransaction amount
currencystringCurrency code
client_referencestringYour reference identifier
payment_idintegerInternal payment ID
transaction_idstringProvider transaction ID
providerstringPayment provider used
created_atstringISO 8601 timestamp
status_codeintegerHTTP status code
payment_instructionsobjectInstructions for completing payment (APMs only)

Asynchronous Payment Flow

SPEI and OXXO payments are asynchronous. The initial status will always be pending because they require the customer to take further action (complete a bank transfer or visit an OXXO store). You must use Webhooks or poll the transaction status endpoint to know when the payment is completed.

Step 4: Check the Transaction Status

For asynchronous payments, or if you need to confirm the final status of any transaction, you can query the transaction status using the Get Transaction Status endpoint with the id from the payment response:
cURL
curl -X GET https://stage.tonder.io/api/v1/transactions/550e8400-e29b-41d4-a716-446655440000/ \
-H "Authorization: Token <YOUR_SANDBOX_API_KEY>"
This will return the full transaction object with its current status (e.g., success, failed, expired). Always validate both the id and status fields in the response.

Next Steps