Payme Integration
Payme is one of the most popular payment systems in Uzbekistan. This guide shows how to integrate Payme with PayTechUZ.
Installation
pip install paytechuz
Basic Usage
Create Gateway
import os
from paytechuz.gateways.payme import PaymeGateway
gateway = PaymeGateway(
payme_id="your_payme_id",
payme_key="your_payme_key",
is_test_mode=True, # True for test, False for production
)
Create Payment
payment = gateway.create_payment(
id="12345", # Invoice ID
amount=50000, # 500.00 UZS (in tiyin)
return_url="https://example.com/return",
account_field_name="id" # Required: field name for account lookup
)
print(f"Payment URL: {payment}")
# Redirect user to payment URL
Check Payment Status
status = gateway.check_payment("transaction_id")
print(f"Status: {status['status']}")
Webhook
from paytechuz.gateways.payme.webhook import PaymeWebhookHandler
webhook_handler = PaymeWebhookHandler(
payme_id="your_payme_id",
payme_key="your_payme_key"
)
def process_webhook(request_data):
response = webhook_handler.handle_webhook(request_data)
if response['result']:
# Payment successful
print("Payment successful!")
return response
Django Integration
Settings.py
INSTALLED_APPS = [
# ...
'paytechuz.integrations.django',
]
PAYTECHUZ = {
'PAYME': {
'PAYME_ID': 'your_payme_id',
'PAYME_KEY': 'your_payme_key',
'ACCOUNT_MODEL': 'shop.models.Order',
'ACCOUNT_FIELD': 'id',
'AMOUNT_FIELD': 'amount',
'IS_TEST_MODE': True,
}
}
Create Payment
Creating payment using settings:
from django.conf import settings
from paytechuz.gateways.payme import PaymeGateway
# Create gateway from settings
gateway = PaymeGateway(
payme_id=settings.PAYTECHUZ['PAYME']['PAYME_ID'],
payme_key=settings.PAYTECHUZ['PAYME']['PAYME_KEY'],
is_test_mode=settings.PAYTECHUZ['PAYME']['IS_TEST_MODE']
)
# Create payment
payment_url = gateway.create_payment(
id=order.id,
amount=order.amount,
return_url='https://example.com/payment/callback',
account_field_name=settings.PAYTECHUZ['PAYME']['ACCOUNT_FIELD'] # From settings
)
Views.py
from paytechuz.integrations.django.views import BasePaymeWebhookView
from .models import Order
class PaymeWebhookView(BasePaymeWebhookView):
def successfully_payment(self, params, transaction):
order = Order.objects.get(id=transaction.account_id)
order.status = 'paid'
order.save()
def cancelled_payment(self, params, transaction):
order = Order.objects.get(id=transaction.account_id)
order.status = 'cancelled'
order.save()
def get_check_data(self, params, account): # optional
"""
Return additional data for CheckPerformTransaction (fiscal receipt)
You can override this method to return additional data for fiscal receipt
"""
return {
"additional": {"first_name": account.user.first_name}, # optional
"detail": { # optional
"receipt_type": 0,
"shipping": {"title": "Yetkazib berish", "price": 10000},
"items": [
{
"discount": 0,
"title": account.product_name,
"price": account.amount,
"count": 1,
"code": "00001",
"units": 1,
"vat_percent": 0,
"package_code": "123456"
}
]
}
}
URLs.py
from django.urls import path
from .views import PaymeWebhookView
urlpatterns = [
path('webhooks/payme/', PaymeWebhookView.as_view(), name='payme_webhook'),
]
FastAPI Integration
from fastapi import FastAPI, Request
from paytechuz.gateways.payme import PaymeGateway
from paytechuz.integrations.fastapi import PaymeWebhookHandler
import os
app = FastAPI()
# Create gateway
payme = PaymeGateway(
payme_id=os.getenv('PAYME_ID'),
payme_key=os.getenv('PAYME_KEY'),
is_test_mode=True
)
@app.post("/payment/create")
async def create_payment():
payment_url = payme.create_payment(
id="12345",
amount=50000,
return_url="https://example.com/return",
account_field_name="id" # Required: field name for account lookup
)
return {"payment_url": payment_url}
@app.post("/webhooks/payme")
async def webhook(request: Request):
handler = PaymeWebhookHandler(
payme_id=os.getenv('PAYME_ID'),
payme_key=os.getenv('PAYME_KEY'),
account_model=Order,
account_field='id',
amount_field='amount'
)
return await handler.handle_webhook(request)
Configuration
Test Mode
For testing, use these credentials:
- Payme ID:
test_payme_id - Payme Key:
test_payme_key - Test Card:
8600 0691 9540 6311
Production Mode
- Register at Payme Business
- Get your production credentials
- Set
is_test_mode=False
Error Handling
from paytechuz.exceptions import PaymeException
try:
payment = gateway.create_payment(
id="12345",
amount=50000,
return_url="https://example.com/return",
account_field_name="id" # Required: field name for account lookup
)
except PaymeException as e:
print(f"Payme error: {e}")