UPI Intent One-Time Mandate Integration - PayU Hosted
Theβ―pre_authorizeβ―parameter is used to pre-authorize payments using the PayU Hosted Checkout integration with theβ―_paymentβ―API.
Note:
You need to activate the Pre-authorize payments before you start using this integration. Contact your PayU Key Account Manager (KAM) to activate Pre-authorize Payments.
Step 1: Post the Pre-Auth transaction request
Post the additional parameters for with the Pre-Authorization using the Merchant Hosted Checkout. For API Reference, refer to UPI One-Time Mandate Transaction API.
Environment
Test Environment | https://test.payu.in/_payment |
Production Environment | https://secure.payu.in/_payment |
The pre_authorize parameter as specified is used to pre-authorize payments using the Merchant Hosted Checkout integration with the _payment API.
Parameter | Description | Example |
---|---|---|
keymandatory | varchar This parameter is the unique Merchant Key provided by PayU for your merchant account. | Your Test Key |
txnidmandatory | varchar This parameter is known as Transaction ID (or Order ID). It is the order reference number generated at your (Merchantβs) end. It is an identifier that you (merchant) would use to track a particular order. If a transaction using a particular transaction ID has already been successful at PayU, the usage of the same Transaction ID again would fail. Hence, you must post us a unique transaction ID for every new transaction.Character limit : 25Note: Ensure that the transaction ID sent to us has not been successful earlier. In case of this duplication, the customer would get an error of βduplicate Order ID.β | fd3e847h2 |
amountmandatory | float This parameter should contain the payment amount of the particular transaction.Note: Type-cast the amount to float type | 1000 |
productinfomandatory | varchar This parameter should contain a brief product description. It should be a string describing the product.Character limit : 100 | Time Magazine Subscription |
firstnamemandatory | varchar Must contain the first name of the customer.Character limit : 60 | Ashish |
emailmandatory | varchar Must contain the email of the customer.This information is helpful when it comes to issues related to fraud detection and chargebacks. Hence, it is a must to provide the correct information. Also, MIS reporting is shared with few issuing banks where email and mobile number is used to keep track of users using SI transactions. Character limit: 50 | [email protected] |
phonemandatory | varchar Must contain the phone number of the customer.This information is helpful when it comes to issues related to fraud detection and chargebacks. Hence, it is must to provide the correct information Character limit: 50 | 9843176540 |
surlmandatory | surL is the acronym for Success URL. This parameter must contain the URL on which PayU will redirect the final response if the transaction is successful. | |
furlmandatory | furl is the acronym for for Failure URL. This parameter must contain the URL on which PayU will redirect the final response if the transaction is failed. | |
pre_authorizemandatory for Pre-Auth | This parameter is set to 1 to pre-authorize payment. | 1 |
si_details | This parameter contains the following information in JSON format: - paymentStartDate - paymentEndDate Example: {"paymentStartDate":"2024-07-24","paymentEndDate":"2024-07-28"} | {"paymentStartDate":"2024-07-24","paymentEndDate":"2024-07-28"} |
hashmandatory | Hash is a crucial parameter used to ensure that any date is not tampered while redirecting customer from the merchant website to PayUβs payment interface while registration transactions. It is SHA512 hash generated by encrypting values of merchant key, txnid, amount, productinfo, firstname, email, udf and si_details by merchant salt. In the case of registration transaction, the formula is used to calculate this hash is similar to the following: HASH = SHA512(sha512(key|txnid|amount|productinfo|firstname|email|udf1|udf2|udf3|udf4|udf5||||||SALT)) |
Hashing
You must hash the request parameters using the following hash logic:
sha512(key|txnid|amount|productinfo|firstname|email|udf1|udf2|udf3|udf4|udf5||||||SALT)
For more information, refer to Generate Hash.
Sample request
curl --request POSTβ―β―
--url https://test.payu.in/_payment β―
--header 'accept: text/plain' β―
--header 'content-type: application/x-www-form-urlencoded' β―
--data key=JPM7Fg β―
--data txnid=aso6787 β―
--data siDetails="{"paymentStartDate": "2019-09-01","paymentEndDate": "2019-12-01"}" β―
--data pre_authorize=1 \β―
--data amount=100.00 β―
--data productinfo=iPhone β―
--data firstname=Ashish β―
--data [email protected] β―
--data phone=9876543210 β―
--data surl=https://apiplayground-response.herokuapp.com/ β―
--data furl=https://apiplayground-response.herokuapp.com/ β―
--data hash=8e8de8a3cf2ba999e16c0ffdb63a645074af4ad1aa0a8d66d81555a119c004e1791173fe6199084f256623664b250d3aeb50fc2c4cfc155e729d8811a157c98bβ―
Step 2: Check the response from PayU
Success scenario
For Intent, as part of response, Intent URL is returned. Now, merchant needs to use data received in intentURIData parameter, JSON decode the response and use URL to invoke intent at their end
{
"metaData": {
"message": null,
"referenceId": "c5161bae370de1bd4fb886c6c66567a8",
"statusCode": null,
"txnId": "a7440cc636e747b635df",
"txnStatus": "pending",
"unmappedStatus": "pending"
},
"result": {
"paymentId": "99900000000001875",
"merchantName": "Name409208872",
"merchantVpa": "paytmqr@icici",
"amount": "10000.00",
"acsTemplate": "PGh0bWw+PGJvZHk+PGZvcm0gbmFtZT0icGF5bWVudF9wb3N0IiBpZD0icGF5bWVudF9wb3N0IiBhY3Rpb249Imh0dHBzOi8vcHA3OHNlY3VyZS5wYXl1LmluLzY1OWFjNWRhNWUyZjlmNzM1NzhkZWYwYzVjNDM2MWFmOWJhMGVkYmExYjk3NDg2Mjg3ZDI2MzBjZDg1YmU3NWUvaW50ZW50U2VhbWxlc3NIYW5kbGVyLnBocCIgbWV0aG9kPSJwb3N0Ij48aW5wdXQgdHlwZT0iaGlkZGVuIiBuYW1lPSJ0b2tlbiIgdmFsdWU9IjIxNjU0RTEyLUY5N0QtM0MxRS0zNjlFLTg5RDdGMzREODkyMSI+PGlucHV0IHR5cGU9ImhpZGRlbiIgbmFtZT0iYW1vdW50IiB2YWx1ZT0iMTAwMDAuMDAiPjxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9Im1paHBheWlkIiB2YWx1ZT0iNjU5YWM1ZGE1ZTJmOWY3MzU3OGRlZjBjNWM0MzYxYWY0ZmY4N2VjNzAwOTVmYmQzNjcyMTQ5MzAzMWQyNTYyMiI+PGlucHV0IHR5cGU9ImhpZGRlbiIgbmFtZT0iZGlzYWJsZUludGVudFNlYW1sZXNzRmFpbHVyZSIgdmFsdWU9IjAiPjxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9InBheWVlVnBhIiB2YWx1ZT0icGF5dG1xckBpY2ljaSI+PGlucHV0IHR5cGU9ImhpZGRlbiIgbmFtZT0icGF5ZWVOYW1lIiB2YWx1ZT0iTmFtZTQwOTIwODg3MiI+PGlucHV0IHR5cGU9ImhpZGRlbiIgbmFtZT0iYWRkaXRpb25hbENoYXJnZXMiIHZhbHVlPSIiPjxpbnB1dCB0eXBlPSJoaWRkZW4iIG5hbWU9InRyYW5zYWN0aW9uRmVlIiB2YWx1ZT0iMTAwMDAuMDAiPjwvZm9ybT48c2NyaXB0IHR5cGU9J3RleHQvamF2YXNjcmlwdCc+CiAgICAgICAgICAgICAgICAgICAgICAgICAgICB3aW5kb3cub25sb2FkPWZ1bmN0aW9uKCl7CiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZG9jdW1lbnQuZm9ybXNbJ3BheW1lbnRfcG9zdCddLnN1Ym1pdCgpOwogICAgICAgICAgICAgICAgICAgICAgICAgICAgfQogICAgICAgICAgICAgICAgICAgICAgICA8L3NjcmlwdD48L2JvZHk+PC9odG1sPg==",
"otpPostUrl": "https:\/\/pp78secure.payu.in\/ResponseHandler.php"
}
}
Failure scenarios
For Intent, as part of response, Intent URL is returned. Now, you need to use data received in intentURIData parameter, JSON decode the response and use URL to invoke intent at your end.
After the transaction is authorised by the customer, PayU will receive confirmation. Same will be passed to the you as webhook.
{
"metaData": { "message": "Transaction failed due to invalid params shared by the merchant", "referenceId": "dde7096af9db932a9fd09b9b4383d8be",
"statusCode": "E1101",
"txnId": "0c4931ddee7a4f69227f", "txnStatus": "failed", "intentURIData":"upi:\/\/mandate?pa=payu24@icici&pn=Payu&tr=EZM2024042211452400151 942&am=10000.00&cu=INR&orgid=400011&mc=6012&purpose=01&tn=Upi%20Mandate&validitystart=22042024&validityend=21052024&amrule=MAX&Recur=ONETIME&Rev=N&Share=Y &Block=Y&txnType=CREATE&mode=13", "unmappedStatus": "failure" }, "result": {}
}
Step 3: Capture a pre-authorized payment
To capture a pre-authorized payment, use the following command. After the API command is successful, the transaction would be captured and settled to you.=
Parameter | Description |
---|---|
key mandatory | This parameter is the unique Merchant Key provided by PayU for your merchant account. The Merchant Key acts as the unique identifier (primary key) to identify a Merchant Account in our database. Sample value β YbfVda |
command mandatory | For initiating a capture transaction, the value of the parameter will be passed as - capture_transaction |
hash mandatory | This parameter must contain the hash value to be calculated at merchant end. Hash logic for this API is: sha512(key|command|var1|salt)β¨sha512 |
var1 mandatory | This parameter must contain the payuId that was generated by PayU as part of pre-authorize operation. |
var2 mandatory | This parameter contains the token, that is, merchant unique reference number. |
var3 mandatory | This parameter must contain the amount to be captured. |
Sample request
curl --location --request POST 'https://info.payu.in/merchant/postservice.php?form=2' \
--header 'Content-Type: application/x-www-form-urlencoded' \
--form 'key="JF***g"' \
--form 'command="capture_transaction"' \
--form 'hash="67411736ab98c59522492a12751a6015c41b87764019f9dc14052690c2c7af9095d31002fc109dcf3596c2f38792d56db6f6207b1989010f2adf51c144fa3019"' \
--form 'var1="15246574846"' \
--form 'var2="authorizeTransaction123"' \
--form 'var3="1"'
Sample response
{
"status": 1,
"msg": "Capture Request Queued",
"request_id": "Request ID",
"bank_ref_num": "Bank Reference Number"
}
Step 4: Check Transaction Status
To check the status of the transaction, use the verify_payment API. For more information, refer to Verify Payment API.
Updated about 18 hours ago