Biblioteca para facilitar o manuseio de boletos de contas PJ no Banco Inter.
Project description
PyInterBoleto
Biblioteca para facilitar o manuseio de boletos de contas PJ no Banco Inter.
Instalação
Basta executar o comando via pip (ou poetry):
pip install pyinterboleto
# ou via poetry
poetry add pyinterboleto
Documentação
A maioria das classes, métodos, funções e estruturas de dados já contém uma documentação habilitada para uso em IDEs no estilo numpy docstring.
Foi optado por não fazer uma documentação exclusiva (no estilo readthedocs) devido a ser uma biblioteca relativamente pequena.
Sendo assim, o pacote está organizado em três submódulos principais: emissão (os dados necessários na emissão são organizados em estruturas menores. São elas dados de: emissão, pagador, desconto, multa, mora e mensagem), consulta (detalhada, coleção e PDF) e cancelamento de boletos.
Em cada um desses links se encontram as funções e objetos com suas respectivas documentações, caso seja preciso mais informações.
Utilização básica
A classe principal que tem todas as funcionalidades requeridas para a API se
chama Boleto
. Através dela que todas as
operações de emissão, consulta e baixa feitas.
No entanto, como consta na documentação do Banco Inter, para se ter acesso a API é preciso emitir a chave e o certificado de acesso desta. Antes de utilizar este pacote, certifique-se que você já possui estes arquivos.
Feito isto, alguns exemplos de manuseio são mostrados nas seções à seguir.
Configuração de autenticação
Antes de fazer qualquer requisição à API do Inter é preciso antes definir o objeto de configuração para autenticação e autorização:
>>> from pathlib import Path
>>> from datetime import date, timedelta
>>> from prettyprinter import pprint, install_extras
>>> from pyinterboleto import RequestConfigs
>>>
>>> install_extras()
>>>
>>> # definição da configuração de autenticação
>>> direc = Path('caminho/para/pasta/com/certificados')
>>> cert = direc / 'Inter API_Certificado.crt'
>>> key = direc / 'Inter API_Chave.key'
>>> # client_id e client_secret são obtidos de acordo com a documentação do Inter
>>> client_id = 'valor-do-id-uuid'
>>> client_secret = 'valor-do-secret-uuid'
>>> scopes = (ScopeEnum.BOLETO_COBRANCA_WRITE,)
>>> configs = RequestConfigs(client_id=client_id, client_secret=client_secret, scopes=scopes, certificate=cert, key=key)
Emissão de boleto
Os dados a seguir são fictícios. Não os utilize do jeito que estão!
>>> from pyinterboleto import Boleto, Emissao, Pagador, Beneficiario
>>> boleto = Boleto(configs) # configs vem da seção configuração
>>>
>>> pagador = Pagador(
... cpfCnpj="12.345.678/0001-12",
... tipoPessoa=TipoPessoa.JURIDICA,
... nome="Alguma Empresa LTDA",
... endereco="Qulaquer um",
... cidade="Também do Brasil",
... uf="SP",
... cep="12345-678",
... )
>>> beneficiario = Beneficiario(
... cpfCnpj="123.456.789-01",
... tipoPessoa=TipoPessoa.FISICA,
... nome="Algum Nome de Pessoa",
... endereco="Algum lugar",
... bairro="Qualquer",
... cidade="Do Brasil",
... uf="SP",
... cep="12345-678",
... )
>>> dados = Emissao(
... pagador=pagador,
... beneficiario=beneficiario,
... seuNumero="000001",
... valorNominal=10.01,
... dataVencimento="2023-01-01",
... numDiasAgenda=25,
... )
>>> result = boleto.emitir(emissao)
>>> print(result)
{'seuNumero': '00001', 'nossoNumero': '00123456789',
'codigoBarras': '00000000000000000000000000000000000000000000',
'linhaDigitavel': '00000000000000000000000000000000000000000000000'}
>>>
Consultas
Há três categorias de consultas disponíveis: detalhamento individual de boletos, coleção de boletos e resgate de arquivos .pdf.
Consulta detalhada de boletos individuais
É preciso saber o número de identificação do título antes de fazer esta
requisição. Este número pode ser obtido quando a emissão do título é
bem sucedida (chave nossoNumero
do dicionário de resposta na seção anterior)
ou quando se faz a filtragem de coleções de boletos.
>>> boleto = Boleto(configs)
>>> num_boleto = '00123456789' # numero de identificação do título pelo Inter
>>> detail = boleto.consulta_detalhada(num_boleto)
>>> pprint(detail)
Consulta de coleção de boletos
As datas de início e final da filtragem são obrigatórias, há outras definições de elementos de filtragem opcionais.
>>> from datetime import date, timedelta
>>> boleto = Boleto(configs)
>>> inicial = date.today() - timedelta(days=30)
>>> final = date.today()
>>> lista = boleto.consulta_lista(inicial, final)
>>> pprint(lista)
Resgate de PDFs de boletos individuais
Assim como na consulta detalhada individual, é preciso saber o número de identificação do título antes de fazer a requisição. Há dois modos de como o PDF é armazendo: em memória ou salvo diretamento em um arquivo especificado.
>>> from pathlib import Path
>>> boleto = Boleto(configs)
>>> num_boleto = '00123456789'
>>> # Armazenado em um buffer de bytes na memória
>>> pdf = boleto.consulta_pdf(num_boleto)
>>>
>>> # salva em um arquivo chamado 'boleto.pdf' no diretório atual
>>> filename = Path().resolve() / 'boleto.pdf'
>>> boleto.consulta_pdf(num_boleto, filename)
Cancelamento de boleto
Também é preciso saber o número de identificação do título. Os tipos de
baixas são definidos no enum MotivoCancelamentoEnum
.
>>> from pyinterboleto import MotivoCancelamentoEnum
>>> boleto = Boleto(configs)
>>> num_boleto = '00123456789'
>>> boleto.cancelar_boleto(num_boleto, MotivoCancelamentoEnum.A_PEDIDO_DO_CLIENTE)
Testes
Como a API do Inter não possui ambiente de sandboxing, optei por "mockar" todas as repostas de acordo com a documentação oficial deles. Isso não isenta a biblioteca de bugs, tendo em vista que a própria documentação deles apresenta algumas inconsistências.
Para realizar os testes localmente, clone o repositório e instale as dependências de desenvolvimento:
# pode usar o gerenciador que quiser (e.g. poetry, conda, etc.)
pip install -r requirements-dev.txt
# poetry install --no-root (para o caso de usar poetry).
Para rodar os tests:
pytest
# ou no caso de poetry:
poetry run poe cov_local
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
File details
Details for the file pyinterboleto-1.0.3.tar.gz
.
File metadata
- Download URL: pyinterboleto-1.0.3.tar.gz
- Upload date:
- Size: 24.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.3.1 CPython/3.10.6 Linux/5.15.0-1024-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | e27b42459e21dcda887bf080aa0814c43ad9dbe9f833d4730101322d00cf3f9a |
|
MD5 | 5efbe0d5b0270c9a5a04284d6115ff03 |
|
BLAKE2b-256 | bd1fc52c001ace122ff5f99ad4287a5c9510f1f8ca2c764a9329e1c24eaa5368 |
File details
Details for the file pyinterboleto-1.0.3-py3-none-any.whl
.
File metadata
- Download URL: pyinterboleto-1.0.3-py3-none-any.whl
- Upload date:
- Size: 30.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.3.1 CPython/3.10.6 Linux/5.15.0-1024-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | ac19458bdf6a64b365ae2032c3401aab53c146fad586025cfa471e3dd04d682a |
|
MD5 | 724ddb0360fee73706bc970b5160bd59 |
|
BLAKE2b-256 | 4983e71f33c67562fcdeac76ad27a4a0676650a81946d6cf2359f56e6471525f |