Create a Normal Refund
POST/v1/payments/:id/refundClick to copy
Use this endpoint to create a normal refund for a payment.
Is this page helpful?
Curl
change language
change language
1curl -u [YOUR_KEY_ID]:[YOUR_KEY_SECRET] \2-X POST https://api.razorpay.com/v1/payments/pay_29QQoUBi66xm2f/refund \3-H 'Content-Type: application/json' \4-d '{5"amount": 5001006}'
Success
Failure
1{2"id": "rfnd_FP8QHiV938haTz",3"entity": "refund",4"amount": 500100,5"receipt": "Receipt No. 31",6"currency": "",7"payment_id": "pay_29QQoUBi66xm2f",8"notes": [],9"receipt": null,10"acquirer_data": {11"arn": null12},13"created_at": 1597078866,14"batch_id": null,15"status": "processed",16"speed_processed": "normal",17"speed_requested": "normal"18}
Path Parameters
id *
stringThe unique identifier of the payment which needs to be refunded.
Request Parameters
amount integerThe amount to be refunded. Amount should be in the smallest unit of the currency in which the payment was made.
speed string The speed at which the refund is to be processed. The default value is normal. Refund will be processed via the normal speed, and the customer will receive the refund within 5-7 working days.
notes json objectKey-value pairs used to store additional information. A maximum of 15 key-value pairs can be included.
receipt stringA unique identifier provided by you for your internal reference.
Response Parameters
idstring The unique identifier of the refund. For example, rfnd_FgRAHdNOM4ZVbO.
entitystring Indicates the type of entity. Here, it is refund.
amountinteger The amount to be refunded (in the smallest unit of currency).
For example, if the refund value is $30.00 it will be 3000.
currencystringThe currency of payment amount for which the refund is initiated.
payment_idstring The unique identifier of the payment for which a refund is initiated. For example, pay_FgR9UMzgmKDJRi.
created_atinteger Unix timestamp at which the refund was created. For example, 1600856650.
batch_idstring This parameter is populated if the refund was created as part of a batch upload. For example, batch_00000000000001.
notesjson object Key-value store for storing your reference data. A maximum of 15 key-value pairs can be included. For example, "note_key": "Beam me up Scotty".
receiptstringA unique identifier provided by you for your internal reference.
acquirer_dataarrayA dynamic array consisting of a unique reference number (either RRN, ARN or UTR) that is provided by the banking partner when a refund is processed. This reference number can be used by the customer to track the status of the refund with the bank.
statusstringIndicates the state of the refund. Possible values:
pending: This state indicates that Razorpay is attempting to process the refund.processed: This is the final state of the refund.failed: A refund can attain the failed state in the following scenarios:
Refund is not possible for a payment which is more than 6 months old.
speed_requestedstring The processing mode of the refund seen in the refund response.
This attribute is seen in the refund response only if the speed parameter is set in the refund request.
Possible value is normal, which indicates that the refund will be processed via the normal speed. The refund will take 5-7 working days.
speed_processedstring This is a parameter in the response which describes the mode used to process a refund.
This attribute is seen in the refund response only if the speed parameter is set in the refund request. Possible value is normal, which indicates that the refund has been processed by the payment processing partner. The refund will take 5-7 working days.
Errors
The API {key/secret} provided is invalid.
Error Status: 4xx
The API credentials passed in the API call differ from the ones generated on the Dashboard.
Solution
{Payment_id} is not a valid id.
Error Status: 400
The payment_id provided is invalid.
Solution
The requested URL was not found on the server.
Error Status: 400
Possible reasons:
- The URL is wrong or is missing something.
- A POST API is executed by GET method.
Solution
{any Extra field} is/are not required and should not be sent.
Error Status: 400
An additional or unrequired parameter is passed.
Solution
The refund amount provided is greater than amount captured.
Error Status: 400
The refund amount entered is more than the amount captured.
Solution
The amount must be atleast USD 1.00.
Error Status: 400
The refund amount entered is less than $1.00.
Solution
The payment has been fully refunded already.
Error Status: 400
The payment_id has already been refunded fully.
Solution
Create a Normal Refund
POST/v1/payments/:id/refundClick to copy
Use this endpoint to create a normal refund for a payment.
Is this page helpful?
Path Parameters
id *
stringThe unique identifier of the payment which needs to be refunded.
Request Parameters
amount integerThe amount to be refunded. Amount should be in the smallest unit of the currency in which the payment was made.
speed string The speed at which the refund is to be processed. The default value is normal. Refund will be processed via the normal speed, and the customer will receive the refund within 5-7 working days.
notes json objectKey-value pairs used to store additional information. A maximum of 15 key-value pairs can be included.
receipt stringA unique identifier provided by you for your internal reference.
Response Parameters
idstring The unique identifier of the refund. For example, rfnd_FgRAHdNOM4ZVbO.
entitystring Indicates the type of entity. Here, it is refund.
amountinteger The amount to be refunded (in the smallest unit of currency).
For example, if the refund value is $30.00 it will be 3000.
currencystringThe currency of payment amount for which the refund is initiated.
payment_idstring The unique identifier of the payment for which a refund is initiated. For example, pay_FgR9UMzgmKDJRi.
created_atinteger Unix timestamp at which the refund was created. For example, 1600856650.
batch_idstring This parameter is populated if the refund was created as part of a batch upload. For example, batch_00000000000001.
notesjson object Key-value store for storing your reference data. A maximum of 15 key-value pairs can be included. For example, "note_key": "Beam me up Scotty".
receiptstringA unique identifier provided by you for your internal reference.
acquirer_dataarrayA dynamic array consisting of a unique reference number (either RRN, ARN or UTR) that is provided by the banking partner when a refund is processed. This reference number can be used by the customer to track the status of the refund with the bank.
statusstringIndicates the state of the refund. Possible values:
pending: This state indicates that Razorpay is attempting to process the refund.processed: This is the final state of the refund.failed: A refund can attain the failed state in the following scenarios:
Refund is not possible for a payment which is more than 6 months old.
speed_requestedstring The processing mode of the refund seen in the refund response.
This attribute is seen in the refund response only if the speed parameter is set in the refund request.
Possible value is normal, which indicates that the refund will be processed via the normal speed. The refund will take 5-7 working days.
speed_processedstring This is a parameter in the response which describes the mode used to process a refund.
This attribute is seen in the refund response only if the speed parameter is set in the refund request. Possible value is normal, which indicates that the refund has been processed by the payment processing partner. The refund will take 5-7 working days.
Errors
The API {key/secret} provided is invalid.
Error Status: 4xx
The API credentials passed in the API call differ from the ones generated on the Dashboard.
Solution
{Payment_id} is not a valid id.
Error Status: 400
The payment_id provided is invalid.
Solution
The requested URL was not found on the server.
Error Status: 400
Possible reasons:
- The URL is wrong or is missing something.
- A POST API is executed by GET method.
Solution
{any Extra field} is/are not required and should not be sent.
Error Status: 400
An additional or unrequired parameter is passed.
Solution
The refund amount provided is greater than amount captured.
Error Status: 400
The refund amount entered is more than the amount captured.
Solution
The amount must be atleast USD 1.00.
Error Status: 400
The refund amount entered is less than $1.00.
Solution
The payment has been fully refunded already.
Error Status: 400
The payment_id has already been refunded fully.
Solution
Curl
change language
change language
1curl -u [YOUR_KEY_ID]:[YOUR_KEY_SECRET] \2-X POST https://api.razorpay.com/v1/payments/pay_29QQoUBi66xm2f/refund \3-H 'Content-Type: application/json' \4-d '{5"amount": 5001006}'
Success
Failure
1{2"id": "rfnd_FP8QHiV938haTz",3"entity": "refund",4"amount": 500100,5"receipt": "Receipt No. 31",6"currency": "",7"payment_id": "pay_29QQoUBi66xm2f",8"notes": [],9"receipt": null,10"acquirer_data": {11"arn": null12},13"created_at": 1597078866,14"batch_id": null,15"status": "processed",16"speed_processed": "normal",17"speed_requested": "normal"18}