## DETRAN / PR / CNH
Consulta a pontuação de uma CNH pelo portal do Detran PR


### Site URL
- https://www.extratodebito.detran.pr.gov.br/detranextratos/gerarExtratoPontuacao.do?action=viewExtract

### Request
POST endpoint: `https://api.infosimples.com/api/v2/consultas/detran/pr/cnh`



| Parameter     | Description                                                                                                                                                                                                                                                 |
| ------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| token*        | The token that will authenticate and authorize the request.                                                                                                                                                                                                 |
| registro_cnh* | Registro_cnh                                                                                                                                                                                                                                                |
| modelo*       | Deve ser informado o valor <strong>0</strong> para CNH com foto, ou <strong>1</strong> para CNH sem foto                                                                                                                                                    |
| cpf*          | CPF of the individual to be queried.                                                                                                                                                                                                                        |
| validade_cnh* | Deve ser informada a data de validade da CNH no formato yyyy-mm-dd                                                                                                                                                                                          |
| pkcs12_cert*  | Este parâmetro é necessário para realizar login com certificado digital. Conteúdo do arquivo do certificado digital A1 encriptado seguindo <a href="http://api.infosimples.com/consultas/docs/certificados#criptografia">as instruções de criptografia</a>. |
| pkcs12_pass*  | Este parâmetro é necessário para realizar login com certificado digital. Senha do certificado digital A1 encriptada seguindo <a href="http://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.13-20231009094632",
    "product": "Consultas",
    "service": "detran/pr/cnh",
    "parameters": {
      "cpf": "123.456.789-01",
      "modelo": "0",
      "registro_cnh": "1111111111",
      "validade_cnh": "2025-12-30"
    },
    "client_name": "Minha Empresa",
    "token_name": "Token de Produção",
    "billable": true,
    "price": "0.24",
    "requested_at": "2023-10-10T08:45:35.000-03:00",
    "elapsed_time_in_milliseconds": 750,
    "remote_ip": "111.111.111.111",
    "signature": "U2FsdGVkX19wYe3HzA3oPz/Eoqo68dWzbaUYMvVqdWUJMdito155V3eJxqPXwntFG5P/8fl037q+z0tyKAXwdw=="
  },
  "data_count": 1,
  "data": [
    {
      "advertencias": [
        {
          "descricao": "ART 218, I DO CTB TRANSITAR VELOC SUP MAX PERMITIDA EM ATE 20%",
          "infracao_datahora": "08/10/2021 14:23"
        }
      ],
      "cassacoes": [
        {
          "processo_administrativo": "11111111",
          "situacao": "Em recurso JARI"
        },
        {
          "processo_administrativo": "11111111",
          "situacao": "Cumprida"
        }
      ],
      "categoria": "AE",
      "data_primeira_habilitacao": "19/03/2003",
      "fiscalizacao": "NÃO RECOLHER CNH",
      "historico_pontuacao": [
        {
          "auto_infracao": "ABC1111111",
          "placa": "AAA1111",
          "pontos": "5",
          "natureza": "Exemplo de Natureza",
          "responsabilidade": "CONDUTOR",
          "apresentacao_condutor": "SIM",
          "local": "Avenida Paulista, 807"
        },
        {
          "auto_infracao": "ABC1111111",
          "placa": "AAA1111",
          "pontos": "5",
          "natureza": "Exemplo de Natureza",
          "responsabilidade": "CONDUTOR",
          "apresentacao_condutor": "SIM",
          "local": "Avenida Paulista, 807"
        },
        {
          "auto_infracao": "ABC1111111",
          "placa": "AAA1111",
          "pontos": "5",
          "natureza": "Exemplo de Natureza",
          "responsabilidade": "CONDUTOR",
          "apresentacao_condutor": "SIM",
          "local": "Avenida Paulista, 807"
        }
      ],
      "nome": "Exemplo de Nome",
      "outros": [
        "Condutor não apresenta os requisitos necessários para abertura de processo de Reciclagem Preventiva."
      ],
      "recursos": [
        "11111111",
        "11111111",
        "11111111",
        "11111111"
      ],
      "registro_cnh": "1111111111",
      "situacao_cnh": "NORMAL",
      "suspensoes": [
        {
          "processo_administrativo": "11111111",
          "situacao": "A cumprir/recorrer JARI até 11/11/11111"
        },
        {
          "processo_administrativo": "11111111",
          "situacao": "Em recurso Def. Prévia"
        },
        {
          "processo_administrativo": "11111111",
          "situacao": "Cumprida"
        },
        {
          "processo_administrativo": "11111111",
          "situacao": "Vinculada a outra notificação"
        }
      ],
      "ultimos_doze_meses": [
        {
          "auto_infracao": "ABC1111111",
          "placa": "AAA1111",
          "pontos": "5",
          "natureza": "Exemplo de Natureza",
          "responsabilidade": "CONDUTOR",
          "apresentacao_condutor": "SIM",
          "local": "Avenida Paulista, 807"
        }
      ],
      "validade": "19/11/2025",
      "validade_toxicologico": "30/10/2025",
      "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 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
import base64
# pip install aes-bridge
import aes_bridge

url = 'https://api.infosimples.com/api/v2/consultas/detran/pr/cnh'
args = {
  "registro_cnh": "VALUE_OF_PARAMETER_REGISTRO_CNH",
  "modelo":       "VALUE_OF_PARAMETER_MODELO",
  "cpf":          "VALUE_OF_PARAMETER_CPF",
  "validade_cnh": "VALUE_OF_PARAMETER_VALIDADE_CNH",
  "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.
