Асинхронный/синхронный Python SDK для API Т-Банка (эквайринг и открытый банк).
Project description
tbank
Асинхронный и синхронный Python SDK для API Т-Банка (ex-Тинькофф).
tbank — типизированная библиотека для интеграции с платёжными и банковскими сервисами Т-Банка: интернет-эквайринг (приём платежей, СБП, рекуррент, фискализация 54-ФЗ) и открытый банковский API Т-Бизнеса (счета, выписки, рублёвые платежи, инвойсы, СБП-ссылки). Один пакет — оба мира, с общим ядром.
✨ Особенности
- 🚀 Async и sync — один API в двух вариантах на общем ядре (
httpx). - 🛡️ Строгая типизация — pydantic v2,
mypy --strictбез ошибок,py.typed. - 🔌 Полное покрытие — эквайринг (EACQ) и открытый банк (T-API) в одном пакете.
- 🔐 Аутентификация из коробки — SHA-256 Token-подпись (эквайринг), Bearer и mTLS (открытый банк).
- 💸 Корректные деньги — копейки (
int) для эквайринга,Decimalдля открытого банка (без float-погрешности). - 🔁 Надёжность — ретраи с экспоненциальным бэкоффом, уважение
Retry-After, идемпотентность. - 🧪 Проверено — 111 тестов, 99% покрытие.
📦 Установка
pip install tbank
Зависимости: Python 3.9+, pydantic>=2, httpx.
🚀 Быстрый старт
Эквайринг — приём платежа (redirect)
import asyncio
from tbank.acquiring import AcquiringClient
from tbank.acquiring.models import InitRequest
async def main() -> None:
async with AcquiringClient(terminal_key="...", password="...") as client:
payment = await client.init(InitRequest(amount=150000, order_id="A-1"))
print(payment.payment_url) # редиректим покупателя сюда
state = await client.get_state(payment.payment_id)
print(state.status)
asyncio.run(main())
Синхронный вариант — тот же API без async/await:
from tbank.acquiring.sync import AcquiringClient
with AcquiringClient(terminal_key="...", password="...") as client:
payment = client.init(InitRequest(amount=150000, order_id="A-1"))
Открытый банк — счета и выписки
from decimal import Decimal
from tbank.business import BusinessClient
from tbank.business.models import StatementParams
from datetime import datetime, timezone
async def main() -> None:
client = BusinessClient(token="...") # self-service токен из ЛК
accounts = await client.get_accounts() # счета + балансы (Decimal)
async for op in client.iter_statement(
StatementParams(account_number="40802...", from_=datetime(2026, 1, 1, tzinfo=timezone.utc))
):
print(op.operation_id, op.operation_amount) # авто-пагинация по nextCursor
await client.aclose()
🧩 Что покрыто
| Домен | Возможности |
|---|---|
tbank.acquiring (EACQ) |
Приём платежей (init/get_state/confirm/cancel), вебхуки, рекуррент (charge), клиенты и карты (add_customer/get_card_list/remove_card), СБП QR (get_qr/get_qr_members) и СБП-рекуррент (add_account_qr/charge_qr), фискализация 54-ФЗ (Receipt/send_closing_receipt), привязка карт (add_card/get_add_card_state) |
tbank.business (T-API) |
Счета и балансы (get_accounts), выписки с курсорной авто-пагинацией (get_statement/iter_statement/get_bank_statement), рублёвые платежи с налоговым блоком через mTLS (create_ruble_payment/get_payment_status), инвойсы (send_invoice), СБП-ссылки b2b (create_onetime_qr/create_reusable_qr) |
📋 Примеры
Рекуррентный платёж (эквайринг)
# 1) при первом платеже сохраняем карту:
await client.init(InitRequest(amount=150000, order_id="A-1", customer_key="c1", recurrent="Y"))
# → RebillId приходит в вебхуке на статус AUTHORIZED
# 2) последующие списания без покупателя:
await client.charge(payment_id, rebill_id)
СБП QR (эквайринг)
from tbank.acquiring.enums import QrDataType
payment = await client.init(InitRequest(amount=150000, order_id="A-1"))
qr = await client.get_qr(payment.payment_id, data_type=QrDataType.PAYLOAD)
print(qr.data) # ссылка qr.nspk.ru
Рублёвый платёж с mTLS (открытый банк)
from decimal import Decimal
from tbank.business import BusinessClient
from tbank.business.models import CreatePaymentRequest, PaymentFrom, ReceiverRequisites
client = BusinessClient(token="...", cert=("client.pem", "key.pem")) # mTLS-сертификат из ЛК
pid = await client.create_ruble_payment(CreatePaymentRequest(
from_=PaymentFrom(account_number="40802..."),
to=ReceiverRequisites(name="ООО Ромашка", inn="7700000000", account_number="40702...", bik="044525974"),
purpose="Оплата по счёту 1", amount=Decimal("12345.67"),
))
status = await client.get_payment_status(pid)
Фискализация 54-ФЗ (эквайринг)
from tbank.acquiring.models import Receipt, ReceiptItem
from tbank.acquiring.enums import Tax, Taxation, PaymentObject
await client.init(InitRequest(
amount=100000, order_id="A-1",
receipt=Receipt(
taxation=Taxation.USN_INCOME, email="client@example.com",
items=[ReceiptItem(name="Товар", price=100000, quantity=1, amount=100000,
tax=Tax.VAT_22, payment_object=PaymentObject.COMMODITY)],
),
))
⚠️ Обработка ошибок
Все ошибки наследуются от tbank.core.errors.TBankError:
from tbank.core.errors import TBankAPIError, TBankNetworkError, InsufficientFundsError
try:
await client.charge(payment_id, rebill_id)
except InsufficientFundsError:
... # недостаточно средств (типизированное исключение)
except TBankAPIError as e:
print(e.code, e.message) # прочие ошибки API
except TBankNetworkError:
... # сеть/таймаут после ретраев
🔗 Ссылки
- 📚 Документация: https://tbank.readthedocs.io
- 🐙 Репозиторий: https://github.com/masasibata/tbank
- 🏦 API Т-Банка: https://developer.tbank.ru/docs/api
🧪 Разработка
poetry install
poetry run pytest --cov=tbank # тесты + покрытие
poetry run mypy tbank # строгая типизация
poetry run black tbank tests && poetry run isort tbank tests
📄 Лицензия
MIT — см. LICENSE.
Project details
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file tbank-1.13.0.tar.gz.
File metadata
- Download URL: tbank-1.13.0.tar.gz
- Upload date:
- Size: 87.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.2.1 CPython/3.12.11 Linux/6.14.0-37-generic
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d66adbaf2ce60ba696a3c8227a447f40c9b7cee47970fa515b5ab914ad37252b
|
|
| MD5 |
1530722c40daf53863bb420363486903
|
|
| BLAKE2b-256 |
4f5193f8c74933ad8f98cb2d5427df128a4174bf5804d2133dd6e09b64347f45
|
File details
Details for the file tbank-1.13.0-py3-none-any.whl.
File metadata
- Download URL: tbank-1.13.0-py3-none-any.whl
- Upload date:
- Size: 171.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.2.1 CPython/3.12.11 Linux/6.14.0-37-generic
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
39a3c934d123a396fb22a1ae77f68ac2a989c2a8087f3ca1e49b12b00415fd57
|
|
| MD5 |
0e45d836a1b8d6bdebc70e63d0d105c6
|
|
| BLAKE2b-256 |
46958f10396656ea82c4ec3eaa1694c92e9c080c264aa718841da69e6bf2f477
|