Implement one-time payment flows for processing payments in India
This article describes how to implement one-time payment flows to process the following transactions in India:
- Local one-time and recurring transactions in Indian Rupees (INR)
See the Overview and Procedure sections. - Cross-border transactions that are not in INR
See the Recommendations for other scenarios section.
Overview
To process local one-time and recurring transactions in INR, you can configure and integrate a Payment Page 2.0 on the following types of payment gateway integrations. You need to pass in additional client parameters in the Z.render
function to support the use case of authorization amount processing or invoice processing.
Payment gateway integration | Supported payment method type | Support for recurring transactions | Gateway configuration requirement |
---|---|---|---|
BillDesk | Credit Card |
Yes To process local recurring payments in Indian Rupees (INR) in India, mandates must be established. Any recurring payments in INR without the mandate ID data will fail. You can take advantage of the one-time payment flow of adding or updating a payment method to create a recurring mandate without being required to make a payment. You can also create a recurring mandate, complete a payment, and store the details as a fully tokenized payment method. For more information about Zuora's support and suggestions for recurring payments in India, see the Recurring Payments in India article in Zuora Community. |
|
Stripe v2 | Credit Card Reference Transaction | ||
CyberSource 2.0 | Credit Card | No | The Gateway Endpoint setting on the gateway instance page must be set to CyberSource India. |
Complete the following tasks to implement a Payment Page 2.0 to support one-time payment flows:
- Review prerequisites.
- Set up a Payment Page 2.0.
- Request a signature for the Payment Page from Zuora.
- Set up your client code to integrate the Payment Page to your web page.
- Implement the callback response.
To support cross-border transactions that are not in INR, see information in the Recommendations for other scenarios section.
For the support on integrations requested through the Specialized Payment Connections service, see the article for the specific integration.
Procedure
Step 1. Review prerequisites
Prerequisites for implementing payment flows on Stripe v2
- If you want to process recurring payments in India through Zuora, the following requirements must be met to be compliant with the directive of processing e-mandate for recurring transactions issued by the Reserve Bank of India (RBI):
- Run your transactions in Indian Rupees (INR) through a local Indian entity.
- Other processing requirements from RBI are met.
- Understand that Zuora does not support saving the masked card numbers due to the RBI's regulation for storage of payment system data.
- Zuora's support for implementing payment flows for processing local recurring payments in India is currently in a joint pilot program with Stripe. To use this feature, you must request the pilot version of the feature with Stripe to avoid issues with incorrect configuration. Work with your Stripe account representative to enable the support for recurring payments on the Stripe platform.
- Ensure that the following requirements for implementing payment flows in Zuora are met:
- To support processing authorization amounts, the following features must be enabled:
- Validate Client-Side HPM Parameters. Follow the instructions in Validating client-side HPM parameters to enable it.
- Either Credit Balance or Invoice Settlement. Submit a request at Zuora Global Support to enable the feature.
- To support processing invoices, the following requirements are met:
- Validating Client-Side HPM Parameters must be enabled.
- The invoices must be posted before the invoices are paid through the one-time payment.
- To support processing authorization amounts, the following features must be enabled:
- To process the required webhook events with Stripe, enable the Stripe Real-Time Reconciliation feature. See Real-Time Reconciliation for details.
Prerequisites for implementing payment flows on BillDesk
- If you want to process recurring payments in India through Zuora, the following requirements must be met to be compliant with the directive of processing e-mandate for recurring transactions issued by the Reserve Bank of India (RBI):
- Run your transactions in Indian Rupees (INR) through a local Indian entity.
- Other processing requirements from RBI are met.
- Understand that Zuora does not support saving the masked card numbers due to the RBI's regulation for storage of payment system data.
- Ensure that the following requirements for implementing payment flows in Zuora are met:
- To support processing authorization amounts, the following features must be enabled:
- Validate Client-Side HPM Parameters. Follow the instructions in Validating client-side HPM parameters to enable it.
- Either Credit Balance or Invoice Settlement. Submit a request at Zuora Global Support to enable the feature.
- To support processing invoices, the following requirements are met:
- Validating Client-Side HPM Parameters must be enabled.
- The invoices must be posted before the invoices are paid through the one-time payment.
- To support processing authorization amounts, the following features must be enabled:
- To support recurring payments through BillDesk, the days before the invoice due date to send a pre-debit notification must be configured in Zuora. Zuora defaults it to 2 days, which is the minimum value for this setting. The contents of the notification are derived from BillDesk and not configurable in Zuora.
To update this value, navigate to Settings > Payments > Define Payment Rules > Pre-debit Notification Rules. Ensure the following requirement is met.
invoice due date - invoice date > days configured in Pre-debit Notification Rules
The invoice due date can be determined by the Payment Term, which can be defined when creating an account or creating an order.
Do not consolidate all invoices of an account for a single payment in a payment run, because every single invoice for a recurring payment requires its own pre-debit notification.
Prerequisites for implementing one-time payment flows on CyberSource 2.0
- To support processing authorization amounts, the following features must be enabled:
- Validate Client-Side HPM Parameters. Follow the instructions in Validating client-side HPM parameters to enable it.
- Either Credit Balance or Invoice Settlement. Submit a request at Zuora Global Support to enable the feature.
- To support processing invoices, the following requirements must be met:
- Validating Client-Side HPM Parameters must be enabled.
- The invoices must be posted before the invoices are paid through the one-time payment.
Step 2. Set up a Payment Page 2.0
- To understand the implementation procedure of Payment Pages 2.0 in Zuora, review Payment Pages 2.0 implementation overview.
- Set up a Payment Page 2.0:
- To set up a Credit Card Reference Payment Page 2.0 on Stripe v2, follow the instructions in Configure Credit Card Reference Payment Pages 2.0 for Stripe v2. Make sure Enable 3D Secure 2.0 is selected in the Security Information section.
- To set up a Credit Card Payment Page 2.0 on BillDesk, follow the instructions in Configure Credit Card type Payment Pages 2.0. Make sure Enable 3D Secure 2.0 is selected in the Security Information section. Note that the style of the One Time Password prompt dialog designed by Zuora cannot be altered.
- To set up a Credit Card Payment Page 2.0 on CyberSource 2.0, follow the instructions in Configure Credit Card type Payment Pages 2.0. Make sure Enable 3D Secure 2.0 is selected in the Security Information section.
- Optionally, preview the Payment Page.
- Optionally, translate and localize the Payment Page.
- Optionally, update the CSS for the Payment Page.
Step 3. Request a signature for the hosted page from Zuora
Follow the instructions in Request a signature for the Payment Page from Zuora. Because the Client-side HPM Parameter Validation feature is enabled, Zuora will validate the additional fields in the request by comparing them with the values specified in the digital signature.
Here are two request examples for the Generate RSA signature REST API operation.
{ "uri":"https://sandbox.na.zuora.com/apps/PublicHostedPageLite.do", "method":"POST", "pageId":"test808145b3bf9d0145b3c6812b0008", "paymentGateway":"Stripe2", "authroizationAmount":"100", "currency":"INR", "accountId":"test808145b3bf9d0145b3c6812b0008" }
{ "uri":"https://sandbox.na.zuora.com/apps/PublicHostedPageLite.do", "method":"POST", "pageId":"test808145b3bf9d0145b3c6812b0008", "paymentGateway":"Stripe2", "accountId":"test808145b3bf9d0145b3c6812b0008" }
Step 4. Set up your client code
Follow the instructions in Integrate Payment Pages 2.0. When rendering the Payment Page form, specify the following parameters in the Z.render
function to support the use case of authorization amount processing or invoice processing.
Parameter | Applicable use case | Description |
---|---|---|
doPayment |
Both |
Required Type: boolean Default:
If it is |
storePaymentMethod |
Both |
Type: boolean Default:
For the implementation of one-time payment flows on CyberSource 2.0, |
field_accountId |
Both |
Required The payment method will be created for the specified account. For more information about this parameter, see Client parameters for Payment Pages 2.0. |
authorizationAmount |
Authorization amount processing |
Required for authorization amount processing If If For more information about this parameter, see Client parameters for Payment Pages 2.0. |
field_currency |
Authorization amount processing |
Required for authorization amount processing The currency of the one-time payment amount. For more information about this parameter, see Client parameters for Payment Pages 2.0. |
documents | Invoice processing |
Required for invoice processing An array of invoices to be paid in this transaction, containing the following fields:
|
For the implementation of the one-time payment flow for local recurring payments in India, in addition to the fields for authorization amounts or invoices, specify the following fields to generate a mandate ID. The default value for each field is specific to the payment gateway integration.
Parameter | Description |
---|---|
cardMandateEnabled |
Required Type: boolean Default:
If |
param_gwOptions_CardMandateReference |
Optional Type: string Default: null Unique identifier for the mandate. See Client parameters for Payment Pages 2.0 for details about the Gateway Options fields. |
param_gwOptions_CardMandateDescription |
Optional Type: string Default: null A description of the mandate. See Client parameters for Payment Pages 2.0 for details about the Gateway Options fields. |
param_gwOptions_CardMandateAmountType |
Optional Type: string (enum) Default: The value can be
See Client parameters for Payment Pages 2.0 for details about the Gateway Options fields. |
param_gwOptions_CardMandateAmount |
Optional Type: number Default: Amount to be charged for future payments. See Client parameters for Payment Pages 2.0 for details about the Gateway Options fields. |
param_gwOptions_CardMandateStartDate |
Optional Type: date-time Default: Date and time when passing the parameter Start date of the mandate, such as See Client parameters for Payment Pages 2.0 for details about the Gateway Options fields. |
param_gwOptions_CardMandateEndDate |
Optional Type: date-time Default: 20 years after the mandate start date End date of the mandate, such as See Client parameters for Payment Pages 2.0 for details about the Gateway Options fields. |
param_gwOptions_CardMandateInterval |
Optional Type: string (enum) Default: Payment frequency. The value can be See Client parameters for Payment Pages 2.0 for details about the Gateway Options fields. |
param_gwOptions_CardMandateIntervalCount |
Optional Type: integer Default: null The number of intervals between payments. Up to one year interval is allowed (1 year, 12 months, or 52 weeks). This parameter is optional when See Client parameters for Payment Pages 2.0 for details about the Gateway Options fields. |
param_gwOptions_CardMandateSupportedTypes |
Optional Type: string Default: empty The mandate type supported for this payment. Currently, onlyindia is allowed. If you want to set india as the default value, submit a request at Zuora Global Support. |
In summary, to create a payment flow for processing one-time payments in INR in India, use any of the above payment gateway integrations and specify the following fields and other fields according to your use case:
doPayment:"true"
storePaymentMethod:"false"
- Other fields for processing authorization amounts or invoices according to your use case
To create a payment flow for processing local recurring payments in INR in India, use the Stripe v2 or BillDesk payment gateway integration and specify the following fields and other fields according to your use case:
doPayment:"true"
storePaymentMethod:"true"
cardMandateEnabled:"true"
- Other fields for generating the mandate ID for your needs
- Other fields for processing authorization amounts or invoices according to your use case
To create a recurring mandate without being required to make a payment, use the Stripe v2 or BillDesk payment gateway integration and specify the following fields and other fields according to your use case:
doPayment:"false"
storePaymentMethod:"true"
cardMandateEnabled:"true"
- Other fields for generating the mandate ID for your needs
Here is an example of the parameters for the payment flow for processing recurring payments on Stripe v2:
var params = { doPayment:"true", field_accountId:"testc0f87596f2f301759c29443622fa", authorizationAmount:"99", field_currency:"INR", cardMandateEnabled:"true", param_gwOptions_CardMandateReference:"sample-reference", param_gwOptions_CardMandateDescription:"sample description", param_gwOptions_CardMandateAmountType:"fixed", param_gwOptions_CardMandateAmount: "4000", param_gwOptions_CardMandateStartDate: "2021-09-14T21:56:00+08:00", param_gwOptions_CardMandateEndDate: "", param_gwOptions_CardMandateInterval: "month", param_gwOptions_CardMandateIntervalCount: "1", param_gwOptions_CardMandateSupportedTypes: "india" };
Step 5. Implement callback response
See Advanced Integration of Payment Pages 2.0 for more information.
Additional information for payment flow implementation on Stripe v2
View mandate information in Zuora
After the additional fields are passed to the gateway and the mandate ID is successfully generated, it will be stored for the payment method in Zuora. You can view the mandate information by any of the following methods:
- View the information at any of the following UI locations:
- Payment detail page > View Detail hover help next to the Payment Method field
- Account detail page > Billing and Payment Info section > View Detail hover help next to the Default Payment Method field
- Account detail page > Electronic Payment Methods section > Your Credit Card Reference Transaction record
- Retrieve the information through the Retrieve a payment method API operation.
- Retrieve the information from the Payment Method data source. See Generate a data source export for more information.
- Retrieve the information from the PaymentMethod object in Data Query. See Construct SQL Queries in Data Query for more information.
Recommendations for other scenarios
To support cross-border transactions that are not in INR currency and therefore do not require a recurring mandate to be established, Zuora recommends you implement a one-time payment flow in non-INR currency. See the following articles for instructions.
- Implement one-time payment flows on Braintree
- Implement one-time payment flows on CyberSource 2.0
- Implement one-time payment flows on Stripe v2
If Zuora’s one-time payments do not meet your needs, the following solutions are recommended. You can then push the external payments into Zuora.
- Work with your current payment gateway provider for guidance on how to implement necessary measures for your recurring payments.
- Implement Pay-By-Link flows.
- Build your own one-time payment flow.