Important: This is not the same as SubscriptionsThink of who’s in control of recurrence:
- Stored Credentials: You control recurrence and are responsible for sending each transaction according to your own schedule and recurrence logic.
- Subscription API: Yuno controls it. You provide instructions once, then Yuno automatically sends transactions on your behalf. See Subscriptions.
- Categorization
- General considerations
- Create a payment
- Subscription agreement ID
- Network transaction ID
Categorization
| Category | Customer-initiated transactions (CIT) | Merchant-initiated transactions (MIT) |
|---|---|---|
| Definition | Transactions initiated by the customer, such as online and in-store purchases, or ATM withdrawals. | Transactions initiated by the merchant or service provider without the customer’s active involvement. |
| Examples | Includes online purchases, in-store purchases, and ATM withdrawals. | Includes recurring payments, automatic subscription renewals, and recurring billing. |
| Authentication | Typically requires cardholder authentication to ensure security. | Requires initial customer authentication to set up, with potential additional authentication based on security regulations and card issuer policies for subsequent transactions. |
General considerations
- Responsibility: In the context of strong customer authentication (SCA) under PSD2 regulation in the European Union, CIT generally requires higher authentication compared to MIT.
- Frequency: MIT transactions are often recurring and periodic, while CIT are more ad hoc events based on customer actions.
Create a payment with processing type
To specify a payment with a processing type, use thestored_credentials structure inside the payment_method.detail.card when creating a payment.
| Parameter | Type | Description |
|---|---|---|
reason | enum | Indicates the reason for storing credentials for the transaction. CARD_ON_FILE SUBSCRIPTION UNSCHEDULED_CARD_ON_FILE |
usage | enum | A credit card can be stored with or without an initial payment. This field indicates if this is the first time the vaulted_token/network_token is used or reused. FIRST USED |
subscription_agreement_id | string | The ID of the agreement with the customer, mandatory for certain markets (e.g., MX). |
network_transaction_id | string | The ID provided by Visa/Mastercard in the response of the initial payment, which is highly recommended for future use in merchant-initiated transactions (MIT). |
Critical: Complete All Required Fields
- When working with CIT and MIT transactions, it’s essential to correctly populate the
usage,reason, andnetwork_transaction_idfields. Failing to complete these fields properly can result in decreased approval rates and loss of chargeback disputes. - Some providers (e.g., Adyen) require that the
reasonfield remains consistent across the transaction lifecycle. If your first transaction (usage=FIRST) usesreason=SUBSCRIPTION, all subsequent transactions (usage=USED) must also usereason=SUBSCRIPTION.
| Reason | Description |
|---|---|
CARD_ON_FILE | A customer-initiated payment using a previously enrolled credit card where the cardholder is present. Allows customers one-click payment for a frictionless payment experience. |
SUBSCRIPTION | Used for merchant-initiated payments as part of a subscription. This does not create a new subscription - use the Subscription API for automated recurring billing. |
UNSCHEDULED_CARD_ON_FILE | A merchant-initiated payment using stored credit card details that is not related to a subscription schedule or amount. Payment can occur at any given time. |
Request example
Request (cURL)
Subscription agreement
For certain markets (MX for example) and payment processors, when a subscription-related payment is made, the ID of the agreement with the customer needs to be specified in the payment request to ensure correct processing. To facilitate this, we have enabled thesubscription_agreement_id field inside the stored_credentials struct, allowing you to share the agreement made with the customer.
NoteThe
subscription_agreement_id and network_transaction_id are independent fields. Including a subscription_agreement_id does not replace the need for a network_transaction_id. Both should be provided when applicable to ensure optimal approval rates and chargeback protection.Network transaction ID
A network transaction ID is a unique identifier assigned to a transaction by the card network. It is used to track and reference specific transactions, particularly in recurring payment scenarios, ensuring consistency and traceability across the payment lifecycle. If the transaction is customer-initiated (CIT), the network transaction reference will be available in thecard.stored_credentials.network_transaction_id field. This field represents the transaction ID for Visa and the trace ID for Mastercard, which are recommended for future subscription payments.
Use
We associate thenetwork_transaction_id with the vaulted_token for future transactions, so you don’t have to manage the logic for each case. We will perform the association when a payment is created with:
- Payment method:
- A card
vaulted_token, or - Card data with
vault_on_successset totrue
- A card
- Stored credentials:
usageset toFIRST
network_transaction_id for the card, you can include it in the payment in the corresponding field. If not, for MIT payments (with stored_credentials.usage=USED), we will send the network_transaction_id associated with the vaulted_token to the provider.
Remember to specify the
usage in the stored_credentials section, as we trigger the network_transaction_id logic based on those fields.