## DETRAN / RS / CNH
Consulta a pontuação de uma CNH no site do detran do estado do Rio Grande do Sul


### Site URL
- https://www.portaldetransito.rs.gov.br/dtw2/app/servico/hab/consulta-pontuacao-form.xhtml

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



| Parameter     | Description                                                                                                                                                                                                                                                                |
| ------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| token*        | The token that will authenticate and authorize the request.                                                                                                                                                                                                                |
| rg*           | Rg                                                                                                                                                                                                                                                                         |
| cnh*          | Cnh                                                                                                                                                                                                                                                                        |
| nome*         | Name of the person to be queried.                                                                                                                                                                                                                                          |
| birthdate*    | Date of birth in ISO 8601 format. For example, April 22, 1985 is represented as "1985-04-22". Make sure to include leading zeros; the format "1985-4-22" is invalid.                                                                                                       |
| 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>.               |

> * 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.20-20240827143817",
    "product": "Consultas",
    "service": "detran/rs/cnh",
    "parameters": {
      "birthdate": "11/11/1111",
      "cnh": "11111111111",
      "login_cpf_md5": "e379c59a3573be16480533ae3f53ea1b",
      "login_senha_md5": "e379c59a3573be16480533ae3f53ea1b",
      "nome": "Exemplo de Nome",
      "rg": "11.111.111-1"
    },
    "client_name": "Minha Empresa",
    "token_name": "Token de Produção",
    "billable": true,
    "price": "0.26",
    "requested_at": "2024-08-28T16:28:27.000-03:00",
    "elapsed_time_in_milliseconds": 195,
    "remote_ip": "111.111.111.111",
    "signature": "U2FsdGVkX19h8HzC0u52ZxbU+w+tyvdeVDQSPqGKkr9nQ0fv9E+fCaV7Wfhms37Yp8POEJgoY7gSzpwyOHqysQ=="
  },
  "data_count": 1,
  "data": [
    {
      "andamento_servico_datas": {
        "conclusao_exame": "11/11/1111",
        "entrega": "09/05/2017",
        "postagem": "11/11/1111",
        "recebimento_grafica": "11/11/1111",
        "recebimento_malote": "11/11/1111",
        "solicitacao_emissao": "11/11/1111"
      },
      "avaliacao_psicologica": {
        "categoria": "A E",
        "data": "11/11/2011",
        "situacao": "Apto",
        "taxa_exame": "Pago"
      },
      "categoria": "A E",
      "cfc_atual": {
        "endereco": "Avenida Paulista, 1636. São Paulo. SP. Brasil.",
        "municipio": "SAO PAULO / SP",
        "nome": "Exemplo de Nome",
        "telefone": "(11) 1111-1111"
      },
      "data_habilitacao_categorias": {
        "cat_a": "11/11/1111",
        "cat_b": "11/11/1111",
        "cat_c": "11/11/1111",
        "cat_d": "11/11/1111",
        "cat_e": "11/11/1111"
      },
      "identidade": "11.111.111-1",
      "infracoes": [
        {
          "data_hora": "11/11/1111 11:11",
          "infracao": "7455-0 TRANSITAR EM VELOCIDADE SUPERIOR A MAXIMA PERMITIDA EM ATE 20%",
          "local": "Avenida Paulista, 1636",
          "pontuacao": 4,
          "situacao_ait": "Exemplo de Texto",
          "suspensao_cnh": "Exemplo de Texto",
          "veiculo": "IXY2368"
        },
        {
          "data_hora": "11/11/1111 11:11",
          "infracao": "7455-0 TRANSITAR EM VELOCIDADE SUPERIOR A MAXIMA PERMITIDA EM ATE 20%",
          "local": "Avenida Paulista, 1636",
          "pontuacao": 4,
          "situacao_ait": "Exemplo de Texto",
          "suspensao_cnh": "Exemplo de Texto",
          "veiculo": "EWU8894"
        }
      ],
      "modelo": null,
      "numero": "1111111111",
      "pontos": {
        "aguardando_confirmacao": 0,
        "confirmados": 0
      },
      "primeira_habilitacao": "11/11/1111",
      "renach": {
        "categoria": "A E",
        "data_hora": "11/11/1111 11:11",
        "numero": "1111111111",
        "servico": "Renovação de exames",
        "situacao": "RENACH encerrado em 25/04/2017"
      },
      "situacao": "TRANSFERIDO PARA SP",
      "uf": "SP",
      "validade": "20/04/2022",
      "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/detran/rs/cnh'
args = {
  "rg":          "VALUE_OF_PARAMETER_RG",
  "cnh":         "VALUE_OF_PARAMETER_CNH",
  "nome":        "VALUE_OF_PARAMETER_NOME",
  "birthdate":   "VALUE_OF_PARAMETER_BIRTHDATE",
  "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.
