Интеграция с Payme
Payme — одна из самых популярных платёжных систем в Узбекистане. Это руководство показывает, как интегрировать Payme с PayTechUZ.
Установка
pip install paytechuz
Базовое использование
Создание шлюза
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 для теста, False для продакшена)
Создание платежа
payment = gateway.create_payment(
id="12345", # ID счёта
amount=50000, # 500.00 UZS (в тийинах)
return_url="https://example.com/return"
)
print(f"Payment URL: {payment}")
# Перенаправьте пользователя на URL платежа
Проверка статуса платежа
status = gateway.check_payment("transaction_id")
print(f"Status: {status['status']}")
Вебхук
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']:
# Платёж успешен
print("Платёж успешен!")
return response
Интеграция с Django
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,
}
}
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()
URLs.py
from django.urls import path
from .views import PaymeWebhookView
urlpatterns = [
path('webhooks/payme/', PaymeWebhookView.as_view(), name='payme_webhook'),
]
Интеграция с FastAPI
from fastapi import FastAPI, Request
from paytechuz.gateways.payme import PaymeGateway
from paytechuz.integrations.fastapi import PaymeWebhookHandler
import os
app = FastAPI()
# Создание шлюза
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"
)
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)
Конфигурация
Тестовый режим
Для тестирования используйте эти данные:
- Payme ID:
test_payme_id - Payme Key:
test_payme_key - Тестовая карта:
8600 0691 9540 6311
Продакшен режим
- Зарегистрируйтесь на Payme Business
- Получите ваши продакшен данные
- Установите
is_test_mode=False
Обработка ошибок
from paytechuz.exceptions import PaymeException
try:
payment = gateway.create_payment(
id="12345",
amount=50000,
return_url="https://example.com/return"
)
except PaymeException as e:
print(f"Ошибка Payme: {e}")