Metadata-Version: 2.4
Name: payvo_sdk
Version: 0.0.3
Summary: Python SDK для работы с Payvo API
Home-page: https://github.com/erruqie/payvo_sdk
Author: erruqie
Author-email: clownl3ss@icloud.com
Classifier: Programming Language :: Python :: 3
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: OS Independent
Requires-Python: >=3.8
Description-Content-Type: text/markdown
Requires-Dist: requests>=2.30.0
Dynamic: author
Dynamic: author-email
Dynamic: classifier
Dynamic: description
Dynamic: description-content-type
Dynamic: home-page
Dynamic: requires-dist
Dynamic: requires-python
Dynamic: summary

# Payvo SDK

Python SDK для работы с [Payvo API](https://docs.payvo.ru/).
Позволяет интегрировать платёжный сервис в Python-приложения быстро и удобно.

---

## ⚡ Установка

### 🔹 Через PyPI

```bash
pip install payvo-sdk
```

---

## 🛠 Инициализация SDK

```python
from payvo_sdk import Payvo

# Инициализация
payvo = Payvo(
    merchant_id="ваш_merchant_id",
    merchant_secret_key="ваш_secret_key",
)
```

---

## 💳 Работа с платежами

### Создание платежа

```python
payment = payvo.create_payment(
    amount=200.0,
    description="Тестовый платеж"
)
print(payment)
```

### Получение информации о платеже

```python
info = payvo.get_payment(payment_uuid=payment["uuid"])
print(info)
```

---

## 🔁 Работа с возвратами

### Создание возврата

```python
refund = payvo.create_refund(
    payment_uuid=payment["uuid"],
    amount=50.0,
    description="Частичный возврат"
)
print(refund)
```

### Получение информации о возврате

```python
refund_info = payvo.get_refund(refund_uuid=refund["uuid"])
print(refund_info)
```

---

## 🔄 Автоплатежи

```python
autopayment = payvo.create_autopayment(
    customer_id="id_клиента",
    amount=150.0,
    description="Автоплатеж"
)
print(autopayment)
```

> ⚠️ Для автоплатежей необходимо согласовать с Payvo возможность сохранения платёжного метода.

---

## 🔔 Работа с вебхуками

### Проверка секретного ключа вебхука

```python
webhook_data = {"secret_key": "тестовый_ключ"}
is_valid = Payvo.verify_webhook(webhook_data, secret_key="тестовый_ключ")
print(is_valid)  # True или False
```

> 💡 Используйте `verify_webhook` для проверки, что уведомление пришло именно от Payvo.

---

## 📚 Полезные ссылки

* [Документация Payvo API](https://docs.payvo.ru/)
* [PyPI](https://pypi.org/)

---

## 📝 Пример полного скрипта

```python
from payvo_sdk import Payvo

payvo = Payvo(
    merchant_id="ваш_merchant_id",
    merchant_secret_key="ваш_secret_key"
)

# Создать платеж
payment = payvo.create_payment(200.0, "Тестовый платеж")

# Проверка платежа
info = payvo.get_payment(payment["uuid"])

# Частичный возврат
refund = payvo.create_refund(payment["uuid"], 50.0, "Частичный возврат")

# Проверка вебхука
webhook_data = {"secret_key": "тестовый_ключ"}
print(Payvo.verify_webhook(webhook_data, secret_key="тестовый_ключ"))
```
