Интеграция с Click
Click — широко используемая платёжная система в Узбекистане. Это руководство показывает, как интегрировать Click с PayTechUZ.
Установка
pip install paytechuz
Базовое использование
Создание шлюза
import os
from paytechuz.gateways.click import ClickGateway
gateway = ClickGateway(
service_id="your_service_id",
merchant_id="your_merchant_id",
merchant_user_id="your_merchant_user_id",
secret_key="your_secret_key",
is_test_mode=True, # True для теста, False для продакшена)
Создание платежа
payment = gateway.create_payment(
id="12345", # ID счёта
amount=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.click.webhook import ClickWebhookHandler
webhook_handler = ClickWebhookHandler(
service_id="your_service_id",
secret_key="your_secret_key"
)
def process_webhook(request_data):
response = webhook_handler.handle_webhook(request_data)
if response['error'] == 0:
# Платёж успешен
print("Платёж успешен!")
return response
Интеграция с Django
Settings.py
INSTALLED_APPS = [
# ...
'paytechuz.integrations.django',
]
PAYTECHUZ = {
'CLICK': {
'SERVICE_ID': 'your_service_id',
'MERCHANT_ID': 'your_merchant_id',
'MERCHANT_USER_ID': 'your_merchant_user_id',
'SECRET_KEY': 'your_secret_key',
'ACCOUNT_MODEL': 'shop.models.Order',
'ACCOUNT_FIELD': 'id',
'AMOUNT_FIELD': 'amount',
'IS_TEST_MODE': True,
}
}
Views.py
from paytechuz.integrations.django.views import BaseClickWebhookView
from .models import Order
class ClickWebhookView(BaseClickWebhookView):
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 ClickWebhookView
urlpatterns = [
path('webhooks/click/', ClickWebhookView.as_view(), name='click_webhook'),
]
Интеграция с FastAPI
from fastapi import FastAPI, Request
from paytechuz.gateways.click import ClickGateway
from paytechuz.integrations.fastapi import ClickWebhookHandler
import os
app = FastAPI()
# Создание шлюза
click = ClickGateway(
service_id=os.getenv('CLICK_SERVICE_ID'),
merchant_id=os.getenv('CLICK_MERCHANT_ID'),
merchant_user_id=os.getenv('CLICK_MERCHANT_USER_ID'),
secret_key=os.getenv('CLICK_SECRET_KEY'),
is_test_mode=True
)
@app.post("/payment/create")
async def create_payment():
payment_url = click.create_payment(
id="12345",
amount=500.00,
return_url="https://example.com/return"
)
return {"payment_url": payment_url}
@app.post("/webhooks/click")
async def webhook(request: Request):
handler = ClickWebhookHandler(
service_id=os.getenv('CLICK_SERVICE_ID'),
secret_key=os.getenv('CLICK_SECRET_KEY'),
account_model=Order
)
return await handler.handle_webhook(request)
Конфигурация
Тестовый режим
Для тестирования используйте эти данные:
- Service ID:
test_service_id - Merchant ID:
test_merchant_id - Тестовая карта:
8600 0691 9540 6311
Продакшен режим
- Зарегистрируйтесь на Click Business
- Получите ваши продакшен данные
- Установите
is_test_mode=False
Обработка ошибок
from paytechuz.exceptions import ClickException
try:
payment = gateway.create_payment(
id="12345",
amount=500.00,
return_url="https://example.com/return"
)
except ClickException as e:
print(f"Ошибка Click: {e}")
Коды ответов вебхука
Click вебхук ожидает определённые коды ответов:
0- Успех-1- Ошибка проверки подписи-2- Неверный параметр суммы-3- Действие не найдено-4- Уже оплачено-5- Пользователь не существует-6- Транзакция не существует-7- Не удалось обновить пользователя-8- Ошибка в запросе от Click-9- Транзакция отменена