Skip to main content

Tool for easy working with https://portal5.cbr.ru API

Project description

cbr-client

PyPI - License PyPI - Python Version

Клиент для работы с api ЦБ РФ

Описание АПИ - https://cbr.ru/lk_uio/guide/rest_api/

Установка

pip install cbr-client

Зависимости

Использование

# необходимо запускать python -m asyncio
from cbr_client import Client

conn_params = dict(
    url='https://portal5test.cbr.ru',
    login='test',
    password='test',
    user_agent='test app'
)

client = Client(**conn_params)
# или через контекстный менеджер
# async with Client(**conn_params) as client:
#     ...

files = [
        ('report.zip.enc', b'encrypted report content'),
        ('report.zip.1.sig', b'operator signature'),
        ('report.zip.2.sig', b'client signature')
    ]

# отправка отчета на портал ЦБ
# создание сообщения
msg = await client.create_message(files, '1-ПИ')
# загрузка файлов
for f in msg.files:
    await client.upload(f)
# или опциональная загрузка чанками
for f in msg.files:
    await client.upload(f, chunked=True, chunk_size=2**16)
# финализация (закрытие сессии)
await client.finalize_message(msg)

# получение квитанций
receipts =await client.get_receipts(msg_id=msg.oid)
for rcpt in receipts:
    # получение файла из хранилища
    for f in rcpt.files:
        # сохраняется в f.content
        await client.download(f)

# получение сообщений по типу формы
messages = await client.get_messages(form='1-ПИ')
# или по статусу
messages = await client.get_messages(status='draft')
# или по типу сообщения (inbox/outbox)
messages = await client.get_messages(msg_type='outbox')
# паджинация, по умолчанию возвращается первая страница
messages = await client.get_messages(status='draft', page=4)
# или комбинировать параметры как требуется 

# получение файлов сообщения
messages = await client.get_messages()
for msg in messages:
    # получение файла из хранилища
    for f in msg.files:
        # сохраняется в f.content
        await client.download(f)

# получение списка возможных задач
tasks = await client.get_tasks()

# получение списка справочников с данными
dictionaries = await client.get_dictionaries()

# получение данных из определенного справочника
d = await client.get_dictionary(oid='dictionary_id')

# получение данных профиля
profile = await client.get_profile()

# получение доступной квоты использования хранилища
quota = await client.get_profile_quota()

# удаление сообщения 
await client.delete_message(msg_id='message_id')

# в конце работы не забываем закрывать соединение
await client.close()

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

cbr_client-0.4.0.tar.gz (10.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

cbr_client-0.4.0-py3-none-any.whl (7.3 kB view details)

Uploaded Python 3

File details

Details for the file cbr_client-0.4.0.tar.gz.

File metadata

  • Download URL: cbr_client-0.4.0.tar.gz
  • Upload date:
  • Size: 10.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for cbr_client-0.4.0.tar.gz
Algorithm Hash digest
SHA256 ccee747042e71104559d9cced6d08b8b31c2b73934f5f92c6e12ce2fb26bb692
MD5 a05d92507a525d590d1febc8e98efb9c
BLAKE2b-256 fe0bdbc6da825d605b304d3f9918a928a82193826cceb99b39dcd204fb477bb1

See more details on using hashes here.

Provenance

The following attestation bundles were made for cbr_client-0.4.0.tar.gz:

Publisher: python-publish.yml on mrslow/cbr-client

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file cbr_client-0.4.0-py3-none-any.whl.

File metadata

  • Download URL: cbr_client-0.4.0-py3-none-any.whl
  • Upload date:
  • Size: 7.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for cbr_client-0.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 a06ca046a2d508cb9cc523e38169c75e0133da265df2fee654721bb23298e8b2
MD5 80c40dabf4511b44c9600c622998b374
BLAKE2b-256 43c404b01e3f4c85906a00893eb7dcf79372611c5b4d049702a3c84a64c7b72d

See more details on using hashes here.

Provenance

The following attestation bundles were made for cbr_client-0.4.0-py3-none-any.whl:

Publisher: python-publish.yml on mrslow/cbr-client

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page