A Python library for interacting with PhonePe Payment Gateway API.
Project description
PhonePe Payment Gateway Python Package
This Python package provides a simple interface to the PhonePe Payment Gateway. It can be used to create PhonePe payment links, check the status of PhonePe transactions, and refund PhonePe transactions.
Installation
To install the package, run the following command:
pip install phonepe
Usage
The following code shows how to create a PhonePe payment link:
- Initiate PhonePe Object
from phonepe import PhonePe
phonepe = PhonePe("MERCHANT_ID", "PHONEPE_SALT", "PHONEPE_HOST", "REDIRECT_URL", "WEBHOOK_URL")
Args:
merchant_id (str): The ID of the merchant.
phone_pe_salt (str): The PhonePe salt.
redirect_url (str): The redirect URL.
webhook_url (str): The webhook URL.
phone_pe_salt_index (int, optional): The PhonePe salt index. Defaults to 1.
redirect_mode (str, optional): The redirect mode. Defaults to "GET". Valid Values "GET/POST"
- Create Transaction With Order Data
order_data= phonepe.create_txn("ORDER_ID", 100, "USER_ID")
#Extract Payment Link
link = order_data["data"]["instrumentResponse"]["redirectInfo"]["url"]
print(link)
-
The payload that is going to be sent to the merchant on the specified callback URL will have a base64 encoded JSON.
-
Upon base64 decoding the response, you should get a JSON with a format similar to the response returned by transaction status API. Following are the response headers sent with a callback.
-
Please follow this documentation if you are updating the paymenty status via
webhook
Args:
order_id (str): The ID of the order.
amount (int): The transaction amount in paise.
user (str): The user ID of the payment maker.
Example Response:
{
"success": true,
"code": "SUCCESS",
"message": "Your request has been successfully completed.",
"data": {
"merchantId": "MERCHANTUAT",
"merchantTransactionId": "b7aa2cc7-cc5e-4d71-b98f-63ebf549010c",
"instrumentResponse": {
"type": "PAY_PAGE",
"redirectInfo": {
"url": "https://mercury-uat.phonepe.com/transact/pg?token=NGVjMzhjOWMzMGI5ODI2OWMwYmQ2MzUzYWE2ZDYzZGM0M2M0NjZkNjVjMWRmNzlmODk1YWEwNjViMTUwNjYyOTI4NDY1OWExYzNmMjQzNjYzZjgxOTQzYjVjMGUyMmYyZGZhMTg5ODRlZDM2MzEzNWYyZDViOTdkZmU2NjFjOGU3ZTdiMzNlNzpmM2ZkZDYwY2JmNGFiYTUxM2Y3OGJhNGVjOTQ5OWU1NQ",
"method": "GET"
}
}
}
}
Check Transaction Status
The following code shows how to check the status of a PhonePe transaction:
status = phonepe.check_txn_status("MERCHANT_TXN_ID")
print(status)
Example Response:
{
"success": true,
"code": "PAYMENT_SUCCESS",
"message": "Your request has been successfully completed.",
"data": {
"merchantId": "FKRT",
"merchantTransactionId": "MT7850590068188104",
"transactionId": "T2111221437456190170379",
"amount": 100,
"paymentState": "COMPLETED",
"responseCode": "PAYMENT_SUCCESS",
"paymentInstrument": {
"type": "UPI",
"utr": "206378866112"
}
}
}
- S2S and Check Status API Handling
Once the customer is redirected back to the merchant website/app, merchants should check with their server if they have received the Server-to-Server Callback response. If not, it is mandatory to make a Transaction Status API check with PhonePe backend systems to know the actual status of the payment and, then accordingly process the result.
The payment status can be Success, Failed or Pending. When Pending, merchants should retry until the status changes to Success or Failed.
if phonepe.verify_webhook_checksum(check_sum_in_header:str, b64_encoded_order_data:dict):
update_payment_status_in_db()
Check Status API - Reconciliation [MANDATORY]
If the payment status is Pending, then Check Status API should be called in the following interval:
The first status check at 20-25 seconds post transaction start, then
Every 3 seconds once for the next 30 seconds,
Every 6 seconds once for the next 60 seconds,
Every 10 seconds for the next 60 seconds,
Every 30 seconds for the next 60 seconds, and then
Every 1 min until timeout (15 mins).
Refund A Transaction
from phonepe import RefundTxn
refund_txn = RefundTxn(
txn_user_id="USER_ID",
merchant_order_id="ORDER_ID",
phonepe_txn_id="PHONEPE_TXN_ID",
amount=100, ##in paise
)
status = phonepe.refund_txn(refund_txn)
print(status)
- Example Response:
{
"success": true,
"code": "PAYMENT_SUCCESS",
"message": "Your request has been successfully completed.",
"data": {
"merchantId": "MERCHANTUAT",
"merchantTransactionId": "ROD620471739210623",
"transactionId": "TR620471739210623",
"amount": 10000,
"state": "COMPLETED",
"responseCode": "SUCCESS"
}
}
Full Example
from phonepe import PhonePe
from phonepe import RefundTxn
phonepe = PhonePe(
merchant_id="PGTESTPAYUAT",
phone_pe_salt="099eb0cd-02cf-4e2a-8aca-3e6c6aff0399",
phone_pe_host="https://api-preprod.phonepe.com/apis/pg-sandbox",
redirect_url="https://webhook.site/42fb84f2-1831-4467-9199-6bf0b839dc69",
webhook_url="https://webhook.site/42fb84f2-1831-4467-9199-6bf0b839dc69"
)
# Create PhonePe Order
order_data = phonepe.create_txn("OTGTRT156", 1000, "bijay")
payment_link = order_data["data"]["instrumentResponse"]["redirectInfo"]["url"]
# Check Transaction Status
txn_status = phonepe.check_txn_status(resp['data']['merchantTransactionId'])
# Refund PhonePe Order
refund = RefundTxn(txn_user_id="bijay", merchant_order_id="OTGTRT156", phonepe_txn_id="T2307112141199670477007",
amount=1000)
ref_resp = phonepe.refund_txn(refund)
For more information, please see the official documentation.
I hope this is helpful! Let me know if you have any other questions.
Pending Feature
* Subscription Module
* Submerchant Onboarding
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file phonepe-1.0.1.tar.gz
.
File metadata
- Download URL: phonepe-1.0.1.tar.gz
- Upload date:
- Size: 5.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.17
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 94eccc1207784ea2a01cb9febecad1fae585548131a9995052c0cd5d18318d9a |
|
MD5 | 473d44665cc3527a97cd31734de96952 |
|
BLAKE2b-256 | 9ea89fbfcf6bb2c764ed6a1ac607e27959e66e398e6fec0a855f3cc0e60be7d2 |
File details
Details for the file phonepe-1.0.1-py3-none-any.whl
.
File metadata
- Download URL: phonepe-1.0.1-py3-none-any.whl
- Upload date:
- Size: 5.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.17
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 37bf4196608933430856324013ba2ab67a484362c08f4d68e044f2b9ca84fdc9 |
|
MD5 | d5c71799aded897c480f6545f15f2093 |
|
BLAKE2b-256 | 88df0a27a3cf20b3f36309b186e967402430b0d7d999dbca37dae1d860e9a29c |