Paysharp APIs are organized around REST. Our API has predictable resource-oriented URLs, accepts JSON requests and returns JSON response, and uses standard HTTP response codes, authentication, and verbs.
You can use our APIs in the sandbox(testing) and production(live) environments. We provide two different API urls and tokens for sandbox and production(live).
Pass API token and content-type for all the requests in header, API token can be generated from merchant dashboard.
Create an intent url for an order. Intent URL can be used in mobile websites, by clicking the intent url, the customer can pay using any UPI app available in his mobile phone.
Parameters | Range | Datatype | Required | Description |
---|---|---|---|---|
orderId | Max 36 | string | Y | Unique identifier to identify order |
amount | Min 1 - No Max limit | number | Y | Amount for the order (Paysharp does not set any maximum amount limits; the maximum amount limit may vary based on the MCC code up to 1 Lac / 2 Lac / 5 Lac / Or any upper limits set by NPCI) |
customerId | Max 36 | string | Y | Unique identifier to identify customer |
customerName | Max 100 | string | N | Customer name |
customerMobileNo | Max 10 | string | Y | Customer Mobile No. |
customerEmail | Max 100 | string | N | Customer email address |
remarks | Max 35 | string | Y | Remark for the transaction. Recommend to pass orderId / invoiceId |
Parameters | Datatype | Description |
---|---|---|
paysharpReferenceNo | string | Payment reference number for the payment |
intentUrl | string | Intent Url generated for the orderId |
phonepeUrl | string | Phonepe intent Url is used to open PhonePe app |
gpayUrl | string | Google intent Url is used to open GPay app |
orderId | string | Returns the request value |
amount | number | Returns the request value |
customerId | string | Returns the request value |
customerName | string | Returns the request value |
customerMobileNo | string | Returns the request value |
customerEmail | string | Returns the request value |
remarks | string | Returns the request value |
{
"orderId" : "APR8910005",
"amount" : 500,
"customerId" : "C_1112",
"customerName" : "Ram",
"customerMobileNo" : "9111100000",
"customerEmail" : "",
"remarks" : "Invoice No - APR8910005"
}
{
"code" : 200,
"message" : "success",
"data" : {
"paysharpReferenceNo" : "upi_dedc619auJz3YB096Se7Zh",
"intentUrl" : "upi://pay?...",
"phonepeUrl" : "phonepe://pay?...",
"gpayUrl" : "tez://upi/pay?...",
"orderId" : "APR8910005",
"amount" : 500,
"customerId" : "C_1112",
"customerName" : "Ram",
"customerMobileNo" : "9111100000",
"customerEmail" : "",
"remarks" : "Invoice No - APR8910005"
}
}
Create a dynamic QR code for an order. The QR code can be scanned and payable from any UPI app, the customer only able to pay the requested amount for the requested order.
Parameters | Range | Datatype | Required | Description |
---|---|---|---|---|
orderId | Max 36 | string | Y | Unique identifier to identify order |
amount | Min 1 - No Max limit | number | Y | Amount for the order (Paysharp does not set any maximum amount limits; the maximum amount limit may vary based on the MCC code up to 1 Lac / 2 Lac / 5 Lac / Or any upper limits set by NPCI) |
customerId | Max 36 | string | Y | Unique identifier to identify customer |
customerName | Max 100 | string | N | Customer name |
customerMobileNo | Max 10 | string | Y | Customer Mobile No. |
customerEmail | Max 100 | string | N | Customer email address |
remarks | Max 35 | string | Y | Remark for the transaction. Recommend to pass orderId / invoiceId |
Parameters | Datatype | Description |
---|---|---|
paysharpReferenceNo | string | Payment reference number for the payment |
qrCode | string | Base64 string version of dynamic QR code for the order. |
orderId | string | Returns the request value |
amount | number | Returns the request value |
customerId | string | Returns the request value |
customerName | string | Returns the request value |
customerMobileNo | string | Returns the request value |
customerEmail | string | Returns the request value |
remarks | string | Returns the request value |
{
"orderId" : "APR8910005",
"amount" : 500,
"customerId" : "C_1112",
"customerName" : "Ram",
"customerMobileNo" : "9111100000",
"customerEmail" : "",
"remarks" : "Invoice No - APR8910005"
}
{
"code" : 200,
"message" : "success",
"data" : {
"paysharpReferenceNo" : "upi_dedc619auJz3YB096Se7Zh",
"qrCode" : "...",
"orderId" : "APR8910005",
"amount" : 500,
"customerId" : "C_1112",
"customerName" : "Ram",
"customerMobileNo" : "9111100000",
"customerEmail" : "",
"remarks" : "Invoice No - APR8910005"
}
}
By calling the API, able to send payment collection request to the customerVPA (customer UPI handle) for the order. The customer receives a payment request in the UPI app, the customer can either pay or reject the payment request.
Parameters | Range | Datatype | Required | Description |
---|---|---|---|---|
orderId | Max 36 | string | Y | Unique identifier to identify order |
amount | Min 1 - No Max limit | number | Y | Amount for the order (Paysharp does not set any maximum amount limits; the maximum amount limit may vary based on the MCC code up to 1 Lac / 2 Lac / 5 Lac / Or any upper limits set by NPCI) |
customerVPA | Max 255 | string | Y | Customer VPA (UPI handle) |
customerId | Max 36 | string | Y | Unique identifier to identify customer |
customerName | Max 100 | string | N | Customer name |
customerMobileNo | Max 10 | string | Y | Customer Mobile No. |
customerEmail | Max 100 | string | N | Customer email address |
remarks | Max 35 | string | Y | Remark for the transaction. Recommend to pass orderId / invoiceId |
Parameters | Datatype | Description |
---|---|---|
paysharpReferenceNo | string | Payment reference number for the payment |
orderId | string | Returns the request value |
amount | number | Returns the request value |
customerVPA | string | Returns the request value |
customerId | string | Returns the request value |
customerName | string | Returns the request value |
customerMobileNo | string | Returns the request value |
customerEmail | string | Returns the request value |
remarks | string | Returns the request value |
{
"orderId" : "APR8910005",
"amount" : 500,
"customerVPA" : "customervpaname@yesb",
"customerId" : "C_1112",
"customerName" : "Ram",
"customerMobileNo" : "9111100000",
"customerEmail" : "",
"remarks" : "Invoice No - APR8910005"
}
{
"code" : 200,
"message" : "success",
"data" : {
"paysharpReferenceNo" : "upi_dedc619auJz3YB096Se7Zh",
"orderId" : "APR8910005",
"amount" : 500,
"customerVPA" : "customervpaname@yesb",
"customerId" : "C_1112",
"customerName" : "Ram",
"customerMobileNo" : "9111100000",
"customerEmail" : "",
"remarks" : "Invoice No - APR8910005"
}
}
By calling the API, able to get the order status and know the order is success, failed, etc..
Parameters | Range | Datatype | Required | Description |
---|---|---|---|---|
orderId | Max 36 | string | Y | Unique identifier to identify order |
Refer webhook, Same as webhook except attemptCount parameter
{
"code" : 200,
"message" : "success",
"data" : {
"orderId" : "202001051004",
"customerId" : "C_1112",
"customerVPA" : "pstest5@yesb",
"amount" : 500,
"fee" : 5,
"tax" : 0.90,
"totalFee" : 5.90,
"netAmount" : 494.10,
"paysharpReferenceNo" : "upi_dedc619auJz3YB096Se7Zh",
"utrNumber" : "228200422398",
"transactionDate" : "2021-02-20T11:25:51+05:30",
"status" : "SUCCESS",
"remarks" : "Invoice No - 202001051004"
}
}
{
"code" : 200,
"message" : "success",
"data" : {
"orderId" : "202001051005",
"customerId" : "0001",
"amount" : 50,
"paysharpReferenceNo" : "upi_afa3ef251C7Qbtj8Lr900N",
"status" : "PENDING",
"remarks" : "Invoice No - 202001051005"
}
}
{
"code" : 200,
"message" : "success",
"data" : {
"orderId" : "202001051005",
"customerId" : "0001",
"amount" : 50,
"paysharpReferenceNo" : "upi_afa3ef251C7Qbtj8Lr900N",
"status" : "ON PROGRESS",
"remarks" : "Invoice No - 202001051005"
}
}
{
"code" : 200,
"message" : "success",
"data" : {
"orderId" : "202001051009",
"customerId" : "C_1112",
"customerVPA" : "pstest5@yesb",
"amount" : 1,
"paysharpReferenceNo" : "upi_5c2ddc77LLAVf8MhM9bFCS",
"transactionDate" : "2021-02-20T11:25:51+05:30",
"status" : "FAILED",
"remarks" : "Invoice No - 202001051009",
"failureCode" : "EC00100U69",
"failureReason" : "Collect Expired"
}
}
{
"code" : 200,
"message" : "success",
"data" : {
"orderId" : "202001051007",
"customerId" : "customer1",
"amount" : 50,
"paysharpReferenceNo" : "upi_6e7662d2pA9bg149Wy0Xgb",
"transactionDate" : null,
"status" : "EXPIRED",
"remarks" : "Invoice No - 202001051007"
}
}
By calling the API, you are able to verify customerVPA exists and also get the name associated with the VPA.
Parameters | Range | Datatype | Required | Description |
---|---|---|---|---|
customerVPA | Max 255 | string | Y | Customer VPA (UPI handle)
Note: In the sandbox environment all the VPAs will return false except the following VPAs. pstest2@yesb pstest4@yesb pstest6@yesb pstest7@yesb pstest8@yesb pstest9@yesb Use the above VPAs for testing to get true |
Parameters | Datatype | Description |
---|---|---|
isValid | boolean | Returns true if VPA is valid or not |
customerVPA | string | Returns the request value |
customerName | string | Returns the name associated with VPA otherwise returns empty |
{
"customerVPA" : "pstest2@ybl"
}
{
"code" : 200,
"message" : "success",
"data" : {
"isValid" : true,
"customerVPA" : "pstest2@ybl",
"customerName" : "Ram"
}
}
{
"customerVPA" : "pstest00000@yesb"
}
{
"code" : 200,
"message" : "success",
"data" : {
"isValid" : false,
"customerVPA" : "pstest00000@yesb",
"customerName" : ""
}
}
Our system will call your webhook url and post the payment status when payment is received. In case your webhook does not respond, our system marks the call as failed. Your webhook should respond in JSON format with content-type: application/json.
Parameters | Datatype | Description |
---|---|---|
orderId | string | Returns the order Id |
customerId | string | Returns the customer Id for the order |
customerVPA | string | Returns the customerVPA for the order (Only returned for collect request API) |
amount | number | Amount for the order |
fee | number | Fee for the transaction |
tax | number | Tax for the transaction fee |
totalFee | number | Sum of fee and tax |
netAmount | number | Actual amount after deducting fee and tax. |
paysharpReferenceNo | string | Payment reference number for the transaction |
utrNumber | string | Unique transaction number provided by Bank |
transactionDate | datetime | Transaction date in ISO 8601 format |
status | string | Status should be SUCCESS |
remarks | string | Remark for the transaction provided by the merchant on create order. |
attemptCount | number | Number of times the webhook invoked(Only returned for webhook response) |
Parameters | Datatype | Description |
---|---|---|
orderId | string | |
customerId | string | |
customerVPA | string | Returns the customerVPA for the order (Only returned for collect request API) |
amount | number | For non-success case always returns as 0 |
paysharpReferenceNo | string | |
status | string |
ON PROGRESS FAILED PENDING EXPIRED |
attemptCount | number | Number of times the webhook invoked(Only returned for webhook response) |
failureCode | string | Failure code returned by bank |
failureReason | string | Failure reason(description) returned by bank |
{
"orderId" : "202001051004",
"customerId" : "C_1112",
"customerVPA" : "pstest5@yesb",
"amount" : 500,
"fee" : 5,
"tax" : 0.90,
"totalFee" : 5.90,
"netAmount" : 494.10,
"paysharpReferenceNo" : "upi_dedc619auJz3YB096Se7Zh",
"utrNumber" : "228200422398",
"transactionDate" : "2021-02-20T11:25:51+05:30",
"status" : "SUCCESS",
"remarks" : "Invoice No - APR8910005",
"attemptCount" : 1
}
{
"orderId" : "202001051004",
"customerId" : "C_1112",
"customerVPA" : "pstest5@yesb",
"amount" : 0,
"paysharpReferenceNo" : "upi_dedc619auJz3YB096Se7Zh",
"status" : "FAILED",
"remarks" : "Invoice No - 202001051004",
"attemptCount" : 1,
"failureCode" : "EC00100NA",
"failureReason" : "Transaction fail: Invalid MPIN"
}
Response status
Http Status: 200
Response Body
{
"code" : 200,
"message" : "success"
}
Http Status Code: 200 - Success
400 - Error
{
"code" : 400,
"errorCode" : 6001,
"message" : "Unable to create order, order exits with the same orderId"
}
Error Codes | Error Messages |
---|---|
6001 | Unable to create order, order exits with the same orderId |
6002 | order not found |
6003 | Unable to send collection request, Invalid customerVPA |
6004 | Amount should be minimum |
6500 | Bank server not available |
Login to your Sandbox / Production environment and UPI API Postman Collection download from the dashboard.