API Test Keys
Customise Payment Methods - Options and Config Parameters
POST
/v1/payment_links
Click to copy
You can configure the payment methods of your choice on the Checkout section of the Payment Links to provide a highly personalised experience for your customers.
You can use the options
and config
parameters for greater control over display of specific payment methods or instruments on the Checkout section of Payment Link. For example, you can remove a certain bank from Netbanking or highlight a specific wallet.
These parameters must be passed along with the options
and checkout
parameters mentioned in the Request Parameters section below, along with the
Depending on the use cases that you might have, Razorpay allows you to create configuration of the payment methods:
For example, Google Pay could be displayed outside the UPI block as a separate payment method. HDFC Netbanking could come out of the Netbanking container as a separate payment method.
Restricting a particular card or banking network, issuer, BIN and card type, different properties of the card, to accept payments.
For example, you can choose to accept payments only from "HDFC Visa Debit cards" on the Checkout.
For example, Freecharge can be removed as a payment method from wallets. The entire Netbanking block or a certain bank in Netbanking can be removed from the Checkout.
You can choose to arrange UPI as the first section instead of Cards on the Checkout. Within the UPI block, you can again order the PSPs, according to your need.
Is this page helpful?
1Use this API endpoint for HDFC Netbanking.23curl -u [YOUR_KEY_ID]:[YOUR_KEY_SECRET] \4-X POST https://api.razorpay.com/v1/payment_links/ \5-H 'Content-type: application/json' \6-d '{7"amount": 1000,8"currency": "INR",9"accept_partial": true,10"first_min_partial_amount": 100,11"reference_id": "#21132",12"description": "Payment for policy no #23456",13"customer": {14"name": "Gaurav Kumar",15"contact": "+919000090000",16"email": "gaurav.kumar@example.com"17},18"notify": {19"sms": true,20"email": true21},22"reminder_enable": true,23"options": {24"checkout": {25"config": {26"display": {27"blocks": {28"banks": {29"name": "Pay using HDFC",30"instruments": [31{32"method": "netbanking",33"banks": [34"HDFC"35]36}37]38}39},40"sequence": [41"block.banks"42],43"preferences": {44"show_default_blocks": false45}46}47}48}49}50}'5152Use this API endpoint for Reordered Payment Methods.5354curl -u [YOUR_KEY_ID]:[YOUR_KEY_SECRET] \55-X POST https://api.razorpay.com/v1/payment_links/ \56-H 'Content-type: application/json' \57-d '{58"amount": 1000,59"currency": "INR",60"accept_partial": true,61"first_min_partial_amount": 100,62"reference_id": "#21132",63"description": "Payment for policy no #23456",64"customer": {65"name": "Gaurav Kumar",66"contact": "+919000090000",67"email": "gaurav.kumar@example.com"68},69"notify": {70"sms": true,71"email": true72},73"reminder_enable": true,74"options": {75"checkout": {76"config": {77"display": {78"blocks": {79"banks": {80"name": "All Payment Methods",81"instruments": [82{83"method": "upi"84},85{86"method": "netbanking"87},88{89"method": "card"90},91{92"method": "wallet"93}94]95}96},97"sequence": [98"block.banks"99],100"preferences": {101"show_default_blocks": false102}103}104}105}106}107}'
Success
1{2"accept_partial": true,3"amount": 1000,4"amount_paid": 0,5"callback_method": "",6"callback_url": "",7"cancelled_at": 0,8"created_at": 1596188911,9"currency": "INR",10"customer": {11"contact": "+919000090000",12"email": "gaurav.kumar@example.com",13"name": "Gaurav Kumar"14},15"deleted_at": 0,16"description": "Payment for policy no #23456",17"expire_by": 0,18"expired_at": 0,19"first_min_partial_amount": 100,20"id": "plink_FL3i7DFZwKOaCu",21"notes": null,22"notify": {23"email": true,24"sms": true25},26"payments": null,27"reference_id": "#21132",28"reminder_enable": true,29"reminders": [],30"short_url": "https://rzp.io/i/l3IB1Sc",31"source": "",32"source_id": "",33"status": "created",34"updated_at": 1596188911,35"user_id": ""36}
1{2"accept_partial": true,3"amount": 1000,4"amount_paid": 0,5"callback_method": "",6"callback_url": "",7"cancelled_at": 0,8"created_at": 1596188765,9"currency": "INR",10"customer": {11"contact": "+919000090000",12"email": "gaurav.kumar@example.com",13"name": "Gaurav Kumar"14},15"deleted_at": 0,16"description": "Payment for policy no #23456",17"expire_by": 0,18"expired_at": 0,19"first_min_partial_amount": 100,20"id": "plink_FL3fYRliPWPv9e",21"notes": null,22"notify": {23"email": true,24"sms": true25},26"payments": null,27"reference_id": "#21132",28"reminder_enable": true,29"reminders": [],30"short_url": "https://rzp.io/i/0Uw9Kow",31"source": "",32"source_id": "",33"status": "created",34"updated_at": 1596188765,35"user_id": ""36}
Request Parameters
amount
*
integer
Amount to be paid using the Payment Link. Must be in the smallest unit of the currency. For example, if you want to receive a payment of ₹300.00, you must enter the value 30000
. In the case of three decimal currencies, such as KWD, BHD and OMR, to refund a payment of 295.991, pass the value as 295990. And in the case of zero decimal currencies such as JPY, to refund a payment of 295, pass the value as 295.
Watch Out!
As per payment guidelines, you should pass the last decimal number as 0 for three decimal currency payments. For example, if you want to refund a customer 99.991 KD for a transaction, you should pass the value for the amount parameter as 99990
and not 99991
.
currency
string
A three-letter ISO code for the currency in which you want to accept the payment. For example, INR. Refer to the list of
.Handy Tips
Razorpay has added support for zero decimal currencies, such as JPY, and three decimal currencies, such as KWD, BHD, and OMR, allowing businesses to accept international payments in these currencies. Know more about
(May 2024).accept_partial
boolean
Indicates whether customers can make
using the Payment Link. Possible values:true
: Customer can make partial payments.false
: (default): Customer cannot make partial payments.
first_min_partial_amount
integer
Minimum amount, in currency subunits, that must be paid by the customer as the first partial payment. Default value is 100
. Default currency is INR
. For example, if an amount of ₹700.00 is to be received from the customer in two installments of #1 - ₹500.00, #2 - ₹200.00, then you can set this value as 500000
. Must be passed along with accept_partial
parameter.
upi_link
boolean
Must be set to true
for creating UPI Payment Link. If the upi_link
parameter is not passed or passed with value as false, a Standard Payment Link will be created.
description
string
A brief description of the Payment Link. The maximum character limit supported is 2048.
reference_id
string
Reference number tagged to a Payment Link. Must be a unique number for each Payment Link. The maximum character limit supported is 40.
customer
string
Customer details
Show child parameters (3)
expire_by
integer
Timestamp, in Unix, at which the Payment Link will expire. By default, a Payment Link will be valid for six months from the date of creation. Please note that the expire by date cannot exceed more than six months from the date of creation.
notify
array
Defines who handles Payment Link notification.
Show child parameters (2)
notes
json object
Key-value pair that can be used to store additional information about the entity. Maximum 15 key-value pairs, 256 characters (maximum) each. For example, "note_key": "Payment Link for Groceries.”
.
callback_url
string
If specified, adds a redirect URL to the Payment Link. Once customers completes the payment, they are redirected to the specified URL.
If the
callback_url
is passed, it should be passed in the correct format. That is, it should contain a URL. callback_method
string
If callback_url
parameter is passed, callback_method must be passed with the value get
.
reminder_enable
boolean
Used to send
for the Payment Link. Possible values:true
: To send reminders.false
: To disable reminders.
options
*
array
Options to display or hide payment methods on the Checkout section. Parent parameter under which the checkout
child parameters must be passed.
Show child parameters (1)
Response Parameters
accept_partial
boolean
Indicates whether customers can make
using the Payment Link. Possible values:true
: Customer can make partial payments.false
: (default): Customer cannot make partial payments.
amount
integer
Amount to be paid using the Payment Link. Must be in the smallest unit of the currency. For example, if you want to receive a payment of ₹300.00, you must enter the value 30000
. In the case of three decimal currencies, such as KWD, BHD and OMR, to refund a payment of 295.991, pass the value as 295990. And in the case of zero decimal currencies such as JPY, to refund a payment of 295, pass the value as 295.
Watch Out!
As per payment guidelines, you should pass the last decimal number as 0 for three decimal currency payments. For example, if you want to refund a customer 99.991 KD for a transaction, you should pass the value for the amount parameter as 99990
and not 99991
.
amount_paid
integer
Amount paid by the customer.
callback_url
string
If specified, adds a redirect URL to the Payment Link. Once the customer completes the payment, they are redirected to the specified URL.
callback_method
string
If callback_url
parameter is passed, callback_method
must be passed with the value get
.
cancelled_at
integer
Timestamp, in Unix, at which the Payment Link was cancelled by you.
created_at
integer
Timestamp, in Unix, indicating when the Payment Link was created.
currency
string
Defaults to INR. We accept payments in
Handy Tips
Razorpay has added support for zero decimal currencies, such as JPY, and three decimal currencies, such as KWD, BHD, and OMR, allowing businesses to accept international payments in these currencies. Know more about
(May 2024).customer
string
Customer details.
Show child parameters (3)
description
string
A brief description of the Payment Link.
expire_by
integer
Timestamp, in Unix, when the Payment Link will expire. By default, a Payment Link will be valid for six months from the date of creation. Please note that the expire by date cannot exceed more than six months from the date of creation.
expired_at
integer
Timestamp, in Unix, at which the Payment Link expired.
first_min_partial_amount
integer
Minimum amount that must be paid by the customer as the first partial payment. For example, if an amount of ₹700.00 is to be received from the customer in two installments of #1 - ₹500.00, #2 - ₹200.00, then you can set this value as 500000
.
id
string
Unique identifier of the Payment Link. For example, plink_ERgihyaAAC0VNW
.
upi_link
boolean
Indicates whether the Payment Link is a UPI Payment Link.
true
: A UPI Payment Link has been created.false
: It is a Standard Payment Link.
notes
object
Set of key-value pairs that you can use to store additional information. You (Businesses) can enter a maximum of 15 key-value pairs, with each value having a maximum limit of 256 characters.
notify
array
Defines who handles Payment Link notification.
Show child parameters (2)
payments
array
Payment details such as amount, payment id, Payment Link id and more. This array is populated only after a payment is made by the customer or if the payment fails. Until then, the value is null
.
Show child parameters (7)
reference_id
string
Reference number tagged to a Payment Link. Must be a unique number for each Payment Link. The maximum character limit supported is 40.
short_url
string
The unique short URL generated for the Payment Link.
status
string
Displays the current state of the Payment Link. Possible values:
created
partially_paid
expired
cancelled
paid
updated_at
integer
Timestamp, in Unix, indicating when the Payment Link was updated.
reminder_enable
boolean
Used to send
for the Payment Link. Possible values:true
: To send reminders.false
: To disable reminders.
user_id
string
A unique identifier for the user role through which the Payment Link was created. For example, HD1JAKCCPGDfRx
.
Customise Payment Methods - Options and Config Parameters
POST
/v1/payment_links
Click to copy
You can configure the payment methods of your choice on the Checkout section of the Payment Links to provide a highly personalised experience for your customers.
You can use the options
and config
parameters for greater control over display of specific payment methods or instruments on the Checkout section of Payment Link. For example, you can remove a certain bank from Netbanking or highlight a specific wallet.
These parameters must be passed along with the options
and checkout
parameters mentioned in the Request Parameters section below, along with the
Depending on the use cases that you might have, Razorpay allows you to create configuration of the payment methods:
For example, Google Pay could be displayed outside the UPI block as a separate payment method. HDFC Netbanking could come out of the Netbanking container as a separate payment method.
Restricting a particular card or banking network, issuer, BIN and card type, different properties of the card, to accept payments.
For example, you can choose to accept payments only from "HDFC Visa Debit cards" on the Checkout.
For example, Freecharge can be removed as a payment method from wallets. The entire Netbanking block or a certain bank in Netbanking can be removed from the Checkout.
You can choose to arrange UPI as the first section instead of Cards on the Checkout. Within the UPI block, you can again order the PSPs, according to your need.
Is this page helpful?
Request Parameters
amount
*
integer
Amount to be paid using the Payment Link. Must be in the smallest unit of the currency. For example, if you want to receive a payment of ₹300.00, you must enter the value 30000
. In the case of three decimal currencies, such as KWD, BHD and OMR, to refund a payment of 295.991, pass the value as 295990. And in the case of zero decimal currencies such as JPY, to refund a payment of 295, pass the value as 295.
Watch Out!
As per payment guidelines, you should pass the last decimal number as 0 for three decimal currency payments. For example, if you want to refund a customer 99.991 KD for a transaction, you should pass the value for the amount parameter as 99990
and not 99991
.
currency
string
A three-letter ISO code for the currency in which you want to accept the payment. For example, INR. Refer to the list of
.Handy Tips
Razorpay has added support for zero decimal currencies, such as JPY, and three decimal currencies, such as KWD, BHD, and OMR, allowing businesses to accept international payments in these currencies. Know more about
(May 2024).accept_partial
boolean
Indicates whether customers can make
using the Payment Link. Possible values:true
: Customer can make partial payments.false
: (default): Customer cannot make partial payments.
first_min_partial_amount
integer
Minimum amount, in currency subunits, that must be paid by the customer as the first partial payment. Default value is 100
. Default currency is INR
. For example, if an amount of ₹700.00 is to be received from the customer in two installments of #1 - ₹500.00, #2 - ₹200.00, then you can set this value as 500000
. Must be passed along with accept_partial
parameter.
upi_link
boolean
Must be set to true
for creating UPI Payment Link. If the upi_link
parameter is not passed or passed with value as false, a Standard Payment Link will be created.
description
string
A brief description of the Payment Link. The maximum character limit supported is 2048.
reference_id
string
Reference number tagged to a Payment Link. Must be a unique number for each Payment Link. The maximum character limit supported is 40.
customer
string
Customer details
Show child parameters (3)
expire_by
integer
Timestamp, in Unix, at which the Payment Link will expire. By default, a Payment Link will be valid for six months from the date of creation. Please note that the expire by date cannot exceed more than six months from the date of creation.
notify
array
Defines who handles Payment Link notification.
Show child parameters (2)
notes
json object
Key-value pair that can be used to store additional information about the entity. Maximum 15 key-value pairs, 256 characters (maximum) each. For example, "note_key": "Payment Link for Groceries.”
.
callback_url
string
If specified, adds a redirect URL to the Payment Link. Once customers completes the payment, they are redirected to the specified URL.
If the
callback_url
is passed, it should be passed in the correct format. That is, it should contain a URL. callback_method
string
If callback_url
parameter is passed, callback_method must be passed with the value get
.
reminder_enable
boolean
Used to send
for the Payment Link. Possible values:true
: To send reminders.false
: To disable reminders.
options
*
array
Options to display or hide payment methods on the Checkout section. Parent parameter under which the checkout
child parameters must be passed.
Show child parameters (1)
Response Parameters
accept_partial
boolean
Indicates whether customers can make
using the Payment Link. Possible values:true
: Customer can make partial payments.false
: (default): Customer cannot make partial payments.
amount
integer
Amount to be paid using the Payment Link. Must be in the smallest unit of the currency. For example, if you want to receive a payment of ₹300.00, you must enter the value 30000
. In the case of three decimal currencies, such as KWD, BHD and OMR, to refund a payment of 295.991, pass the value as 295990. And in the case of zero decimal currencies such as JPY, to refund a payment of 295, pass the value as 295.
Watch Out!
As per payment guidelines, you should pass the last decimal number as 0 for three decimal currency payments. For example, if you want to refund a customer 99.991 KD for a transaction, you should pass the value for the amount parameter as 99990
and not 99991
.
amount_paid
integer
Amount paid by the customer.
callback_url
string
If specified, adds a redirect URL to the Payment Link. Once the customer completes the payment, they are redirected to the specified URL.
callback_method
string
If callback_url
parameter is passed, callback_method
must be passed with the value get
.
cancelled_at
integer
Timestamp, in Unix, at which the Payment Link was cancelled by you.
created_at
integer
Timestamp, in Unix, indicating when the Payment Link was created.
currency
string
Defaults to INR. We accept payments in
Handy Tips
Razorpay has added support for zero decimal currencies, such as JPY, and three decimal currencies, such as KWD, BHD, and OMR, allowing businesses to accept international payments in these currencies. Know more about
(May 2024).customer
string
Customer details.
Show child parameters (3)
description
string
A brief description of the Payment Link.
expire_by
integer
Timestamp, in Unix, when the Payment Link will expire. By default, a Payment Link will be valid for six months from the date of creation. Please note that the expire by date cannot exceed more than six months from the date of creation.
expired_at
integer
Timestamp, in Unix, at which the Payment Link expired.
first_min_partial_amount
integer
Minimum amount that must be paid by the customer as the first partial payment. For example, if an amount of ₹700.00 is to be received from the customer in two installments of #1 - ₹500.00, #2 - ₹200.00, then you can set this value as 500000
.
id
string
Unique identifier of the Payment Link. For example, plink_ERgihyaAAC0VNW
.
upi_link
boolean
Indicates whether the Payment Link is a UPI Payment Link.
true
: A UPI Payment Link has been created.false
: It is a Standard Payment Link.
notes
object
Set of key-value pairs that you can use to store additional information. You (Businesses) can enter a maximum of 15 key-value pairs, with each value having a maximum limit of 256 characters.
notify
array
Defines who handles Payment Link notification.
Show child parameters (2)
payments
array
Payment details such as amount, payment id, Payment Link id and more. This array is populated only after a payment is made by the customer or if the payment fails. Until then, the value is null
.
Show child parameters (7)
reference_id
string
Reference number tagged to a Payment Link. Must be a unique number for each Payment Link. The maximum character limit supported is 40.
short_url
string
The unique short URL generated for the Payment Link.
status
string
Displays the current state of the Payment Link. Possible values:
created
partially_paid
expired
cancelled
paid
updated_at
integer
Timestamp, in Unix, indicating when the Payment Link was updated.
reminder_enable
boolean
Used to send
for the Payment Link. Possible values:true
: To send reminders.false
: To disable reminders.
user_id
string
A unique identifier for the user role through which the Payment Link was created. For example, HD1JAKCCPGDfRx
.
1Use this API endpoint for HDFC Netbanking.23curl -u [YOUR_KEY_ID]:[YOUR_KEY_SECRET] \4-X POST https://api.razorpay.com/v1/payment_links/ \5-H 'Content-type: application/json' \6-d '{7"amount": 1000,8"currency": "INR",9"accept_partial": true,10"first_min_partial_amount": 100,11"reference_id": "#21132",12"description": "Payment for policy no #23456",13"customer": {14"name": "Gaurav Kumar",15"contact": "+919000090000",16"email": "gaurav.kumar@example.com"17},18"notify": {19"sms": true,20"email": true21},22"reminder_enable": true,23"options": {24"checkout": {25"config": {26"display": {27"blocks": {28"banks": {29"name": "Pay using HDFC",30"instruments": [31{32"method": "netbanking",33"banks": [34"HDFC"35]36}37]38}39},40"sequence": [41"block.banks"42],43"preferences": {44"show_default_blocks": false45}46}47}48}49}50}'5152Use this API endpoint for Reordered Payment Methods.5354curl -u [YOUR_KEY_ID]:[YOUR_KEY_SECRET] \55-X POST https://api.razorpay.com/v1/payment_links/ \56-H 'Content-type: application/json' \57-d '{58"amount": 1000,59"currency": "INR",60"accept_partial": true,61"first_min_partial_amount": 100,62"reference_id": "#21132",63"description": "Payment for policy no #23456",64"customer": {65"name": "Gaurav Kumar",66"contact": "+919000090000",67"email": "gaurav.kumar@example.com"68},69"notify": {70"sms": true,71"email": true72},73"reminder_enable": true,74"options": {75"checkout": {76"config": {77"display": {78"blocks": {79"banks": {80"name": "All Payment Methods",81"instruments": [82{83"method": "upi"84},85{86"method": "netbanking"87},88{89"method": "card"90},91{92"method": "wallet"93}94]95}96},97"sequence": [98"block.banks"99],100"preferences": {101"show_default_blocks": false102}103}104}105}106}107}'
Success
1{2"accept_partial": true,3"amount": 1000,4"amount_paid": 0,5"callback_method": "",6"callback_url": "",7"cancelled_at": 0,8"created_at": 1596188911,9"currency": "INR",10"customer": {11"contact": "+919000090000",12"email": "gaurav.kumar@example.com",13"name": "Gaurav Kumar"14},15"deleted_at": 0,16"description": "Payment for policy no #23456",17"expire_by": 0,18"expired_at": 0,19"first_min_partial_amount": 100,20"id": "plink_FL3i7DFZwKOaCu",21"notes": null,22"notify": {23"email": true,24"sms": true25},26"payments": null,27"reference_id": "#21132",28"reminder_enable": true,29"reminders": [],30"short_url": "https://rzp.io/i/l3IB1Sc",31"source": "",32"source_id": "",33"status": "created",34"updated_at": 1596188911,35"user_id": ""36}
1{2"accept_partial": true,3"amount": 1000,4"amount_paid": 0,5"callback_method": "",6"callback_url": "",7"cancelled_at": 0,8"created_at": 1596188765,9"currency": "INR",10"customer": {11"contact": "+919000090000",12"email": "gaurav.kumar@example.com",13"name": "Gaurav Kumar"14},15"deleted_at": 0,16"description": "Payment for policy no #23456",17"expire_by": 0,18"expired_at": 0,19"first_min_partial_amount": 100,20"id": "plink_FL3fYRliPWPv9e",21"notes": null,22"notify": {23"email": true,24"sms": true25},26"payments": null,27"reference_id": "#21132",28"reminder_enable": true,29"reminders": [],30"short_url": "https://rzp.io/i/0Uw9Kow",31"source": "",32"source_id": "",33"status": "created",34"updated_at": 1596188765,35"user_id": ""36}