Create a Payout Link🔗
Use the below endpoint to create a payout link.
Request Parameters🔗
account_numbermandatory-
stringThe account from which you want to make the payout.
Account details can be found on the RazorpayX Dashboard. For example,7878780080316316.- Pass your virtual account number if you want money to be deducted from your virtual account.
- Pass your current account number if you want money to be deducted from your current account.
Watch Out!
This is not your contact's bank account number.
contact-
Details of the contact to whom the payout link is to be sent.
idmandatory if no other parameter in the array is usedstring
If you are using this, do not use the other parameters in the array.
The unique identifer for the contact. For example,cont_00000000000001.namemandatory if id is not usedstring
Use this only if you are not using theidparameter.
The contact's name. This field is case-sensitive. A minimum of 3 characters and a maximum of 50 characters are allowed. Name cannot end with a special character, except.. Supported characters:a-z,A-Z,0-9,space,’,-,_,/,(,)and ,.. For example,Gaurav Kumar.For example,Gaurav Kumar.contacteither contact or email mandatory if id is not usedstring
Use this only if you are not using theidparameter.
The contact's phone number. For example,9123456789.emaileither contact or email mandatory if id is not usedstring
Use this only if you are not using theidparameter.
The contact's email address. For example,gaurav.kumar@example.com.typeoptionalstring
Use this only if you are not using theidparameter.
Classification for the contact being created. For example,employee.
The following classifications are available by default:vendorcustomeremployeeselfHandy Tips
Additional classifications can be created via the Dashboard and then used in APIs. It is not possible to create new classifications via the API.
amountmandatory-
integerThe amount, in paise, to be transferred from the business account to the contact's fund account. For example, if you want to transfer ₹10000, pass1000000against this parameter. The minimum value that can be passed is100.Handy Tips
The value passed here does not include fees and tax. Fees and tax, if any, are deducted from your account balance. currencymandatory-
stringThe currency in which the payout is being made. Here, it isINR. purposemandatory-
stringThe purpose of the payout that is being created. For example,refund.
Classifications available by default:refundcashbackpayoutsalaryutility billvendor billHandy Tips
Additional purposes for payouts can be created via the Dashboard and then used in the API. However, it is not possible to create new purpose for the payout via the API.
descriptionmandatory-
stringAdd a description to communicate the context of the payout link to the recipient. For Example,Cashback for Mr. Gaurav Kumar on the purchase on Earl Grey Tea. receiptoptional-
stringA user-entered receipt number for the payout. For example,Receipt No. 1. send_sms-
booleanPossible values:true- Razorpay sends the payout link to the provided contact number via SMS.false(default) - You send the payout link to the contact.
send_email-
booleanPossible values:true- Razorpay sends the payout link to the provided email address via email.false(default) - You send the payout link to the contact.
notesoptional-
objectUser-entered notes for internal reference. This is a key-value pair. You can enter a maximum of 15 key-value pairs. For example,"note_key": "Beam me up Scotty”. expire_byoptional-
integerTimestamp, in Unix, when you want the payout link to expire.Expire Bytime must be in seconds and at least 15 minutes ahead of the current time. This field is required only when you want to set an expiry date and time for the payout link.Handy Tips
Expiry feature for Payout Links must be enabled before sending this parameter. Know more about how to enable the expiry feature.
Response Parameters🔗
id-
stringThe unique identifier of the payout link that is created. For example,poutlk_00000000000001. entity-
stringThe entity being created. Here it will bepayout_link. contact_id-
stringThe unique identifier of the contact to whom the payout link is to be sent. For example,cont_00000000000001. contact-
Details of the contact to whom the payout link is to be sent.
Use this only if you are not using thecontact_idparameter.namestringThe contact's name. For example,Gaurav Kumar.typestringClassification for the contact being created. For example,employee.contactstringThe contact's phone number. For example,9123456789.emailstringThe contact's email address. For example,gaurav.kumar@example.com.
fund_account_id-
stringThe unique identifier of the contact's fund account to which the payout will be made. This field is populated only when the payout link moves to theprocessingstate. For example,fa_00000000000001. payout_id-
stringThe unique identifier for the payout made to the contact. This field is populated only when the payout link moves to theprocessedstate. For example,pout_00000000000001. purpose-
stringThe purpose of the payout. For example,refund. status-
stringThe payout link status. Possible values:pendingissuedprocessingprocessedcancelledrejected
Refer to the Payout Life Cycle section for more details.
amount-
integerThe amount, in paise, to be transferred from the business account to the contact's fund account.Handy Tips
The value passed here does not include fees and tax. Fees and tax, if any, are deducted from your account balance. currency-
stringThe currency in which the payout is being made. Here, it isINR. description-
stringA user-entered description for the payout link. For example,Payout link for Gaurav Kumar. attempt_count-
integerThe number of attempts to complete the payout. receipt-
stringA user-entered receipt number for the payout. For example,Receipt No. 1. notes-
objectUser-entered notes for internal reference. This is a key-value pair. You can enter a maximum of 15 key-value pairs. For example,"note_key": "Beam me up Scotty”. short_url-
stringA short link for the payout link that was created. This is the link that is shared with the contact. send_sms-
booleanPossible values:true- SMS sent to the provided contact number.false- SMS could not be sent to the provided contact number. This could be because the contact number provided was wrong.
send_email-
booleanPossible values:true- Email sent to the provided email address.false- Email could not be sent to the provided email address. This could be because the email address provided was wrong.
created_at-
integerTimestamp, in Unix, when the payout link was created. cancelled_at-
integerTimestamp, in Unix, when the payout link was cancelled by you. This field is populated only when the payout link moves to thecancelledstate. expire_by-
integerTimestamp, in Unix, when the payout link was to expire. This is set at the time of creation of the payout link. This field is populated only if you have enabled expiry feature for Payout Links. Know more about how to enable the expiry feature. expired_at-
integerTimestamp, in Unix, when the payout link expired. This is set at the time of creation of the payout link.