## SENATRAN / Veículo
Consulta dados de um veículo na base RENAVAM (Registro Nacional de Veículos Automotores), incluindo restrições de roubo/furto, comunicação de venda, processos RENAJUD, multas interestaduais RENAINF e recalls disponíveis. Importante: o site de origem possui um limite diário de 5 consultas por login.


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

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



| 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.                                                                                                                                                                   |
| renavam*      | RENAVAM do veículo a ser consultado.                                                                                                                                                                                                                                       |
| placa*        | Placa do veículo a ser consultado.                                                                                                                                                                                                                                         |
| cpf**         | CPF do proprietário do veículo.                                                                                                                                                                                                                                            |
| cnpj**        | CNPJ do proprietário do veículo.                                                                                                                                                                                                                                           |
| login_cpf**   | Este parâmetro é necessário caso o login no GOV.BR seja feito com CPF e senha. Deve ser informado o CPF para fazer login no GOV.BR.                                                                                                                                        |
| login_senha** | Este parâmetro é necessário caso o login no GOV.BR seja feito com CPF e 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",
    "service": "senatran/veiculo",
    "parameters": {
      "placa": "AAA1111",
      "renavam": "11111111111",
      "cnpj": "11111111111111",
      "login_cpf": "11111111111",
      "login_senha": "111111111"
    },
    "client_name": "Minha Empresa",
    "token_name": "Token de Produção",
    "billable": true,
    "price": "0.3",
    "requested_at": "2020-07-28T08:09:43.000-03:00",
    "elapsed_time_in_milliseconds": 779,
    "remote_ip": "111.111.111.111",
    "signature": "U2FsdGVkX19QFjNN2sQfwZ3VJqvdwWWMJFQwn7c61kKV7rVZoyN6LxybIiW1KodQDLYa5mQS5dUJKrdMXf2RYg=="
  },
  "data_count": 1,
  "data": [
    {
      "ano_fabricacao": 2008,
      "ano_modelo": 2008,
      "arrendatario_cnpj": "",
      "arrendatario_cpf": "11111111111",
      "arrendatario_nome": "Nome de Exemplo",
      "carga": 1.5,
      "carroceria": "FURGAO",
      "carroceria_codigo": "111",
      "categoria": "ALUGUEL",
      "chassi": "11A111A1111111111",
      "cilindradas": 2800,
      "cnpj": "11111111111111",
      "combustivel": "DIESEL",
      "combustivel_codigo": "11",
      "comunicacao_venda_detalhes": {
        "data_venda": "11/11/1111",
        "data_registro": "11/11/1111",
        "cnpj": "",
        "cpf": "11111111111",
        "nome": "Nome de Exemplo",
        "normalizado_cnpj": "",
        "normalizado_cpf": "11111111111"
      },
      "cor": "AZUL",
      "cor_codigo": "11",
      "cpf": "",
      "csvs_emitidos": [
        {
          "identificacaoCsv": "111111111111111",
          "pdf_url": "https://www.exemplo.com/exemplo-de-url"
        }
      ],
      "eixos": 2,
      "especie": "CARGA",
      "existe_comunicacao_venda": true,
      "existe_multa_renainf": true,
      "existe_recall": false,
      "existe_renajud": false,
      "existe_roubo_furto": false,
      "indicador_alarme": false,
      "indicador_leilao": false,
      "lotacao": 3,
      "marca_modelo": "FIAT/DUCATO MULTI",
      "marca_modelo_codigo": "111111",
      "multas_renainf_detalhes": {
        "quantidade": "1",
        "lista": [
          {
            "placa": "AAA1111",
            "ait": "A111111111",
            "orgao_codigo": "111111",
            "orgao_descricao": "Exemplo de texto",
            "infracao_codigo": "1111",
            "infracao_descricao": "Exemplo de texto",
            "numero_renainf": "11111111111",
            "local": "Avenida Paulista",
            "infracao_data": "11/11/1111",
            "infracao_hora": "11:11",
            "valor": 195.23,
            "vencimento_data": "11/11/1111"
          },
          {
            "placa": "AAA1111",
            "ait": "AAA1111111",
            "orgao_codigo": "111111",
            "orgao_descricao": "Exemplo de texto",
            "infracao_codigo": "1111",
            "infracao_descricao": "Exemplo de texto",
            "numero_renainf": "11111111111",
            "local": "Avenida Paulista",
            "infracao_data": "11/11/1111",
            "infracao_hora": "11:11",
            "valor": 130.16,
            "vencimento_data": "11/11/1111"
          },
          {
            "placa": "AAA1111",
            "ait": "AAA1111111",
            "orgao_codigo": "111111",
            "orgao_descricao": "Exemplo de texto",
            "infracao_codigo": "1111",
            "infracao_descricao": "Exemplo de texto",
            "numero_renainf": "11111111111",
            "local": "Avenida Paulista",
            "infracao_data": "11/11/1111",
            "infracao_hora": "11:11",
            "valor": 293.47,
            "vencimento_data": "11/11/1111"
          },
          {
            "placa": "AAA1111",
            "ait": "AAA1111111",
            "orgao_codigo": "111111",
            "orgao_descricao": "Exemplo de texto",
            "infracao_codigo": "1111",
            "infracao_descricao": "Exemplo de texto",
            "numero_renainf": "11111111111",
            "local": "Avenida Paulista",
            "infracao_data": "11/11/1111",
            "infracao_hora": "11:11",
            "valor": 130.16,
            "vencimento_data": "11/11/1111"
          },
          {
            "placa": "AAA1111",
            "ait": "AAA1111111",
            "orgao_codigo": "111111",
            "orgao_descricao": "Exemplo de texto",
            "infracao_codigo": "1111",
            "infracao_descricao": "Exemplo de texto",
            "numero_renainf": "11111111111",
            "local": "Avenida Paulista",
            "infracao_data": "11/11/1111",
            "infracao_hora": "11:11",
            "valor": 130.16,
            "vencimento_data": "11/11/1111"
          },
          {
            "placa": "AAA1111",
            "ait": "1A 1111111",
            "orgao_codigo": "111111",
            "orgao_descricao": "Exemplo de texto",
            "infracao_codigo": "1111",
            "infracao_descricao": "Exemplo de texto",
            "numero_renainf": "11111111111",
            "local": "Avenida Paulista",
            "infracao_data": "11/11/1111",
            "infracao_hora": "11:11",
            "valor": 195.23,
            "vencimento_data": "11/11/1111"
          },
          {
            "placa": "AAA1111",
            "ait": "AAA1111111",
            "orgao_codigo": "111111",
            "orgao_descricao": "Exemplo de texto",
            "infracao_codigo": "1111",
            "infracao_descricao": "Exemplo de texto",
            "numero_renainf": "11111111111",
            "local": "Avenida Paulista",
            "infracao_data": "11/11/1111",
            "infracao_hora": "11:11",
            "valor": 130.16,
            "vencimento_data": "11/11/1111"
          }
        ]
      },
      "nome": "Nome de Exemplo",
      "normalizado_arrendatario_cnpj": "",
      "normalizado_arrendatario_cpf": "11111111111",
      "normalizado_cnpj": "11111111111111",
      "normalizado_cpf": "",
      "normalizado_placa": "AAA1111",
      "normalizado_possuidor_cnpj": "",
      "normalizado_possuidor_cpf": "11111111111",
      "numero_motor": "111111S*1111111*",
      "placa": "AAA1111",
      "placa_novo_padrao": false,
      "possuidor_cnpj": "",
      "possuidor_cpf": "11111111111",
      "possuidor_nome": "Nome de Exemplo",
      "potencia": 127,
      "procedencia": "NACIONAL",
      "recall_detalhes": {},
      "renajud_detalhes": {},
      "renavam": "11111111111",
      "restricao_1": "ARRENDAMENTO",
      "restricao_1_codigo": "11",
      "restricao_2": "SEM RESTRICAO",
      "restricao_2_codigo": "11",
      "restricao_3": "SEM RESTRICAO",
      "restricao_3_codigo": "11",
      "restricao_4": "SEM RESTRICAO",
      "restricao_4_codigo": "11",
      "roubo_furto_detalhes": {},
      "situacao": "CIRCULACAO",
      "tipo": "CAMINHONETE",
      "tipo_codigo": "11",
      "site_receipt": null
    }
  ],
  "site_receipts": []
}
```


### 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/veiculo'
args = {
  "renavam":     "VALOR_DO_PARAMETRO_RENAVAM",
  "placa":       "VALOR_DO_PARAMETRO_PLACA",
  "cpf":         "VALOR_DO_PARAMETRO_CPF",
  "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.
