## SENATRAN / Boleto da Infração
Retorna o PDF da infração de um veículo na posse de um usuário do SENATRAN/gov.br através da placa e chave da infração informados.


### URL do site
- https://portalservicos.senatran.serpro.gov.br/#/veiculos/meus-veiculos

### Requisição
URL para POST: `https://api.infosimples.com/api/v2/consultas/senatran/boleto-infracao`



| Parâmetro       | Descrição                                                                                                                                                                                                                                                                  |
| --------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| token*          | Chave de autenticação da API. É com o token que a API reconhece e autoriza quem está fazendo a consulta.                                                                                                                                                                   |
| chave_infracao* | Número de chave da infração a ser consultada.                                                                                                                                                                                                                              |
| obter_desconto* | Informar <b>1</b> para apenas obter o boleto caso a opção de 40% de desconto estiver disponível. Em algumas situações, pode ser necessário aguardar um tempo para a geração do boleto com desconto. Valor padrão: <b>0</b>.                                                |
| placa*          | Placa do veículo a ser consultado.                                                                                                                                                                                                                                         |
| cnpj**          | CNPJ da empresa a ser consultada.                                                                                                                                                                                                                                          |
| login_cpf**     | Deve ser informado o CPF para fazer login no GOV.BR.                                                                                                                                                                                                                       |
| login_senha**   | Deve ser informada a senha para fazer login no GOV.BR.                                                                                                                                                                                                                     |
| pkcs12_cert**   | Este parâmetro é necessário caso o login no GOV.BR seja feito com certificado digital. Conteúdo do arquivo do certificado digital A1 encriptado seguindo <a href="https://api.infosimples.com/consultas/docs/certificados#criptografia">as instruções de criptografia</a>. |
| pkcs12_pass**   | Este parâmetro é necessário caso o login no GOV.BR seja feito com certificado digital. Senha do certificado digital A1 encriptada seguindo <a href="https://api.infosimples.com/consultas/docs/certificados#criptografia">as instruções de criptografia</a>.               |

> * Parâmetro obrigatório.

> ** Parâmetro opcional. Pode ser necessário informar algum dos parâmetros opcionais para que a consulta funcione adequadamente.


### Exemplos de respostas (OK)
```json
{
  "code": 200,
  "code_message": "A requisição foi processada com sucesso.",
  "errors": [],
  "header": {
    "api_version": "v2",
    "api_version_full": "2.2.29-20250902101125",
    "product": "Consultas",
    "service": "senatran/boleto-infracao",
    "parameters": {
      "chave_infracao": "000000A0000000000000",
      "cnpj": "12.345.678/9012-34",
      "obter_desconto": 0,
      "pkcs12_cert_md5": "aa25eae9298a43740f9a763477c20a1f",
      "pkcs12_pass_md5": "c9c59c5246576b81c3f2712100204dec",
      "placa": "AAA1111"
    },
    "client_name": "Minha Empresa",
    "token_name": "Token de Produção",
    "billable": true,
    "price": "0.38",
    "requested_at": "2025-09-03T17:50:18.000-03:00",
    "elapsed_time_in_milliseconds": 525,
    "remote_ip": "111.111.111.111",
    "signature": "U2FsdGVkX192zsYcsSP2BWXzQ/HCmQn8iMyrOEUhZ3uTF8NzPiHiJzCUDfq/PIXmxAA9XuUPA5N/3wKzyEPyqA=="
  },
  "data_count": 1,
  "data": [
    {
      "codigo_barras": "123456789012345678901234567890123456789012345678",
      "codigo_infracao": "5002",
      "codigo_orgao_autuador": "000000",
      "descricao_infracao": "Exemplo de Descrição da Infração",
      "desdobramento": "3",
      "normalizado_valor": 260.32,
      "normalizado_valor_a_pagar": 260.32,
      "orgao_competente": "DEPARTAMENTO NACIONAL DE INFRA-ESTRUTURA DE TRANSP (DF)",
      "placa": "AAA1111",
      "renainf": "",
      "responsavel": "Nome de Exemplo",
      "valor": "R$ 260,32",
      "valor_a_pagar": "R$ 260,32",
      "vencimento_data": "11/11/1111",
      "site_receipt": "https://www.exemplo.com/exemplo-de-url"
    }
  ],
  "site_receipts": [
    "https://www.exemplo.com/exemplo-de-url"
  ]
}
```


### Arquivo de visualização de consulta

O arquivo de visualização de consulta (`site_receipts`) disponibilizado no retorno da API **pode ser sintetizado pela Infosimples** usando as informações originais da fonte quando o arquivo emitido pela fonte não for adequado para visualização.

### Exemplos de códigos para integração com a API


#### Python
```python
# Testado com: Python 3.10.19, Python 3.14.0
import requests
import base64
# pip install aes-bridge
import aes_bridge

url = 'https://api.infosimples.com/api/v2/consultas/senatran/boleto-infracao'
args = {
  "chave_infracao": "VALOR_DO_PARAMETRO_CHAVE_INFRACAO",
  "obter_desconto": "VALOR_DO_PARAMETRO_OBTER_DESCONTO",
  "placa":          "VALOR_DO_PARAMETRO_PLACA",
  "cnpj":           "VALOR_DO_PARAMETRO_CNPJ",
  "login_cpf":      "VALOR_DO_PARAMETRO_LOGIN_CPF",
  "login_senha":    "VALOR_DO_PARAMETRO_LOGIN_SENHA",
  "pkcs12_cert":    aes_bridge.encrypt(base64.b64encode(open("certificado.pfx", "rb").read()).decode(), "INFORME_A_CHAVE_DE_CRIPTOGRAFIA").decode("ascii").replace("+", "-").replace("/", "_").rstrip("="),
  "pkcs12_pass":    aes_bridge.encrypt("SENHA_DO_CERTIFICADO", "INFORME_A_CHAVE_DE_CRIPTOGRAFIA").decode("ascii").replace("+", "-").replace("/", "_").rstrip("="),
  "token":          "INFORME_AQUI_O_TOKEN_DA_CHAVE_DE_ACESSO",
  "timeout":        "300"
}

response = requests.post(url, args)
response_json = response.json()
response.close()

if response_json['code'] == 200:
  print("Retorno com sucesso: ", response_json['data'])
elif response_json['code'] in range(600, 799):
  mensagem = "Resultado sem sucesso. Leia para saber mais: \n"
  mensagem += "Código: {} ({})\n".format(response_json['code'], response_json['code_message'])
  mensagem += "; ".join(response_json['errors'])
  print(mensagem)

print("Cabeçalho da consulta: ", response_json['header'])
print("URLs com arquivos de visualização (HTML/PDF): ", response_json['site_receipts'])
```


## Estamos prontos para ajudar
Ainda tem alguma dúvida ou precisa de ajuda na sua integração? Entre em contato em [suporte@infosimples.com.br](mailto:suporte@infosimples.com.br) e receba ajuda da nossa equipe técnica altamente qualificada.
