## SENATRAN / Penalidade de Advertência por Escrito
Retorna o PDF da Notificação de Penalidade de Advertência por Escrito de uma infração vinculada a um veículo na posse de um usuário do SENATRAN/gov.br através da placa e chave da infração informados.


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

### Request
POST endpoint: `https://api.infosimples.com/api/v2/consultas/senatran/advertencia-escrito`



| Parameter       | Description                                                                                                                                                                                                                                                                |
| --------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| token*          | The token that will authenticate and authorize the request.                                                                                                                                                                                                                |
| chave_infracao* | Número de chave da infração a ser consultada.                                                                                                                                                                                                                              |
| placa*          | License plate of the vehicle to be queried.                                                                                                                                                                                                                                |
| cnpj**          | CNPJ of the company to be queried.                                                                                                                                                                                                                                         |
| 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>.               |

> * Required parameter.

> ** Optional parameter. Sometimes it is necessary to set at least one of the optional parameters for the service to work properly.


### Response examples (OK)
```json
{
  "code": 200,
  "code_message": "A requisição foi processada com sucesso.",
  "errors": [],
  "header": {
    "api_version": "v2",
    "api_version_full": "2.2.36-20260429094732",
    "product": "Consultas",
    "service": "senatran/advertencia-escrito",
    "parameters": {
      "chave_infracao": "000000A0000000000000",
      "cnpj": "12.345.678/9012-34",
      "login_cpf_md5": "e379c59a3573be16480533ae3f53ea1b",
      "login_senha_md5": "e379c59a3573be16480533ae3f53ea1b",
      "placa": "AAA1111"
    },
    "client_name": "Minha Empresa",
    "token_name": "Token de Produção",
    "billable": true,
    "price": "0.26",
    "requested_at": "2026-04-29T11:08:02.000-03:00",
    "elapsed_time_in_milliseconds": 242,
    "remote_ip": "111.111.111.111",
    "signature": "C+5Npt6oxdfK4O4s5rYAFVgNHHe0Y4R4YMhFUCiWT/Gf4hHYeKa8zqx1VPJ4Yk0g9k9qMPLUZpxzUq3W1ZWRbRXeI5jo9zsAi0S1Ew=="
  },
  "data_count": 1,
  "data": [
    {
      "autuacao": {
        "codigo_orgao_autuador": "000000",
        "orgao_autuador": "PREF. DE RS NOVO HAMBURGO",
        "codigo_orgao_competente": "111111",
        "orgao_competente": "PREF. DE RS NOVO HAMBURGO",
        "numero_ait": "RE02111111",
        "data_notificacao": "11/11/1111"
      },
      "condutor": {
        "nome": "Exemplo de Nome",
        "cnh": "11111111111",
        "uf_pais": "SP/BR",
        "documento": "111111111"
      },
      "embarcador_transportador": {
        "nome": "Exemplo de Nome",
        "cpf_cnpj": "12.345.678/9012-34"
      },
      "identificacao_agente": "Exemplo de Agente",
      "infracao": {
        "codigo_infracao": "7455",
        "desdobramento": "3",
        "valor_multa": "R$ 130,16",
        "descricao": "Exemplo de descrição",
        "medicao_realizada": "11.11 km/h",
        "limite_regulamentado": "11.11 km/h",
        "valor_considerado": "11.11 km/h",
        "renainf": ""
      },
      "local_data_hora": {
        "local_infracao": "Exemplo de endereço",
        "data_infracao": "11/11/1111",
        "hora_infracao": "09:34",
        "codigo_municipio": "35012-2 - SÃO PAULO",
        "municipio": "SAO PAULO / SP",
        "uf": "SP"
      },
      "mensagem_senatran": "Exemplo de Mensagem",
      "numero_instrumento_afericao": "Exemplo de Instrumento",
      "observacoes": "Exemplo de Observação",
      "proprietario": {
        "nome": "Exemplo de Nome",
        "cpf_cnpj": "12.345.678/9012-34",
        "cnh": "11111111111",
        "uf_pais": "SP/BR"
      },
      "veiculo": {
        "placa": "AAA1111",
        "especie": "Exemplo de espécie",
        "pais": "Brasil",
        "marca_modelo_versao": "CHEV/ONIX PLUS 10MT LT1"
      },
      "site_receipt": "https://www.exemplo.com/exemplo-de-url"
    }
  ],
  "site_receipts": ["https://www.exemplo.com/exemplo-de-url"]
}
```


### Preview file

The preview file (`site_receipts`) in the response JSON may be **synthesized by Infosimples** using data from the source (website/app) that processed the automation if the file generated by the source is not suitable for viewing.

### Code snippets


#### Python
```python
# Tested with: 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/advertencia-escrito'
args = {
  "chave_infracao": "VALUE_OF_PARAMETER_CHAVE_INFRACAO",
  "placa":          "VALUE_OF_PARAMETER_PLACA",
  "cnpj":           "VALUE_OF_PARAMETER_CNPJ",
  "login_cpf":      "VALUE_OF_PARAMETER_LOGIN_CPF",
  "login_senha":    "VALUE_OF_PARAMETER_LOGIN_SENHA",
  "pkcs12_cert":    aes_bridge.encrypt(base64.b64encode(open("certificate.pfx", "rb").read()).decode(), "ENCRYPTION_KEY").decode("ascii").replace("+", "-").replace("/", "_").rstrip("="),
  "pkcs12_pass":    aes_bridge.encrypt("CERTIFICATE_PASSWORD", "ENCRYPTION_KEY").decode("ascii").replace("+", "-").replace("/", "_").rstrip("="),
  "token":          "WRITE_YOUR_TOKEN_HERE",
  "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'])
```


## We are here to help
Do you still need to figure something out? Reach us at [suporte@infosimples.com.br](mailto:suporte@infosimples.com.br) and our highly qualified support team will be happy to help.
