## DETRAN / PI / Licenciamento
Consulta as principais pendências de pagamento como licenciamento anual e multas.


### Site URL
- http://taxas.detran.pi.gov.br/licenciamento/index.jsf

### Request
POST endpoint: `https://api.infosimples.com/api/v2/consultas/detran/pi/licenciamento`



| Parameter   | Description                                                 |
| ----------- | ----------------------------------------------------------- |
| token*      | The token that will authenticate and authorize the request. |
| placa*      | License plate of the vehicle to be queried.                 |
| renavam*    | RENAVAM of the vehicle to be queried.                       |
| exercicio** | Exercicio                                                   |

> * 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",
    "service": "detran/pi/licenciamento",
    "parameters": {
      "exercicio": "2021",
      "placa": "AAA1111",
      "renavam": "11111111111"
    },
    "client_name": "Minha Empresa",
    "token_name": "Token de Produção",
    "billable": true,
    "price": "0.2",
    "requested_at": "2021-03-09T14:24:43.000-03:00",
    "elapsed_time_in_milliseconds": 398,
    "remote_ip": "111.111.111.111",
    "signature": "U2FsdGVkX19luEcAiX96sN6JQ3YuQHH3RxYU6blYJntQlGRU7oSWKDvWZEDwAzV4lr2KAZFyEutR0r9nFYAzzg=="
  },
  "data_count": 1,
  "data": [
    {
      "exercicio": "2021",
      "licenciamento": [
        {
          "vencimento": "31/03/2021",
          "tipo": "Licenciamento",
          "descricao": "Exemplo de texto",
          "exercicio": "2021",
          "valor": "62,56",
          "valor_normalizado": 62.56
        }
      ],
      "multas": [
        {
          "data_infracao": "11/11/1111 11:11",
          "vencimento_penalidade": "11/11/1111",
          "vencimento_boleto": "",
          "descricao": "Exemplo de texto",
          "orgao_autuador": "nº AUTO: A111111 Codigo infração: 70301 CONDUZIR MOTOCICLETA, MOTONETA E CICLOMOTOR SEM CAPACETE DE SEGURANC",
          "local": "Avenida Paulista",
          "status": "RUA ARMANDO CAJUBA-TEM PAO",
          "valor": "Penalizada",
          "valor_normalizado": 0.0
        },
        {
          "data_infracao": "11/11/1111 11:11",
          "vencimento_penalidade": "11/11/1111",
          "vencimento_boleto": "",
          "descricao": "Exemplo de texto",
          "orgao_autuador": "nº AUTO: GO1111111 Codigo infração: 70301 CONDUZIR MOTOCICLETA, MOTONETA E CICLOMOTOR SEM CAPACETE DE SEGURANC",
          "local": "Avenida Paulista",
          "status": "RUA ANHAGUERA 401",
          "valor": "Autuada",
          "valor_normalizado": 0.0
        },
        {
          "data_infracao": "11/11/1111 11:11",
          "vencimento_penalidade": "11/11/1111",
          "vencimento_boleto": "",
          "descricao": "Exemplo de texto",
          "orgao_autuador": "nº AUTO: AB11111111 Codigo infração: 70481 CONDUZIR MOTOCICLETA, MOTONETA E CICLOMOTOR TRANSPORTANDO PASSAGEIRO",
          "local": "Avenida Paulista",
          "status": "CRUZAMENTO DA AV SAO SEBASTIA",
          "valor": "Autuada",
          "valor_normalizado": 0.0
        }
      ],
      "placa": "AAA1111",
      "renavam": "111111111",
      "site_receipt": null
    }
  ],
  "site_receipts": []
}
```


### Preview file

The preview file (`site_receipts`) in the response JSON is **generated by the source (website/app)** that processed the automation.

### Code snippets


#### Python
```python
# Tested with: Python 3.10.19, Python 3.14.0
import requests

url = 'https://api.infosimples.com/api/v2/consultas/detran/pi/licenciamento'
args = {
  "placa":     "VALUE_OF_PARAMETER_PLACA",
  "renavam":   "VALUE_OF_PARAMETER_RENAVAM",
  "exercicio": "VALUE_OF_PARAMETER_EXERCICIO",
  "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.
