## DETRAN / MG / Pontuação CNH
Consulta os pontos em uma carteira de motorista no DETRAN do estado de Minas Gerais através do CPF, Data de Nascimento e Data da Primeira Habilitação.


### URL do site
- https://detran.mg.gov.br/habilitacao/prontuario/consultar-pontuacao-cnh/

### Requisição
URL para POST: `https://api.infosimples.com/api/v2/consultas/detran/mg/pontuacao-cnh`



| 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.                                                                                                                                                                   |
| registro_cnh* | Registro_cnh                                                                                                                                                                                                                                                               |
| 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",
    "api_version_full": "2.2.27-20250522163659",
    "product": "Consultas",
    "service": "detran/mg/pontuacao-cnh",
    "parameters": {
      "login_cpf_md5": "ca1b455362647b7effeb83dc98d56c4a",
      "login_senha_md5": "3bcfe867e29d34937bb6582b6618e9eb",
      "registro_cnh": "1234567890"
    },
    "client_name": "Minha Empresa",
    "token_name": "Token de Produção",
    "billable": true,
    "price": "0.2",
    "requested_at": "2024-06-12T13:40:36.000-03:00",
    "elapsed_time_in_milliseconds": 177,
    "remote_ip": "111.111.111.111",
    "signature": "U2FsdGVkX18Yqy0+yHp6ZP+NtAK2yFO3OsEFVDXR3dJkx4KT+WzYEfoLZPiq8WFidWWHlEUn5sAqzt2rsWYYtA=="
  },
  "data_count": 1,
  "data": [
    {
      "cpf": null,
      "data_hora_consulta": "Terça-feira, 27 de Maio de 2025 - 15 horas e 57 minutos",
      "infracoes": [
        {
          "placa": "AAA1234",
          "orgao_atuador": "PREF. DE: MG - BELO HORIZONTE",
          "data_infracao": "12/10/2017",
          "descricao": "Avancar o sinal vermelho do semaforo - fiscal ...",
          "local": "Exemplo de texto",
          "situacao": "PENDENTE",
          "valor": "R$ 293,47",
          "noralizado_valor": 293.47,
          "pontos": null,
          "data_hora": null,
          "infracao": null
        },
        {
          "placa": "AAA1234",
          "orgao_atuador": "PREF. DE: MG - BELO HORIZONTE",
          "data_infracao": "30/05/2020",
          "descricao": "Estacionar no ponto de embarque desembarque d ...",
          "local": "Exemplo de texto",
          "situacao": "PENDENTE",
          "valor": "R$ 130,16",
          "noralizado_valor": 130.16,
          "pontos": null,
          "data_hora": null,
          "infracao": null
        },
        {
          "placa": "AAA1234",
          "orgao_atuador": "PREF. DE: MG - BELO HORIZONTE",
          "data_infracao": "14/10/2020",
          "descricao": "Transitar em velocidade superior a maxima per ...",
          "local": "Exemplo de texto",
          "situacao": "PENDENTE",
          "valor": "R$ 130,16",
          "noralizado_valor": 130.16,
          "pontos": null,
          "data_hora": null,
          "infracao": null
        }
      ],
      "nome": "Exemplo de Nome",
      "normalizado_data_hora_consulta": "27/05/2025 15:57",
      "numero_identidade": "AB1234567890",
      "orgao_expeditor": "SSP",
      "total_pontos": "4",
      "uf": "MG",
      "site_receipt": "https://www.exemplo.com/exemplo-de-url"
    }
  ],
  "site_receipts": [
    "https://www.exemplo.com/exemplo-de-url"
  ]
}
```


### Arquivo de visualização de consulta

O arquivo de visualização de consulta (`site_receipts`) disponibilizado no retorno da API é **emitido pela fonte original**.

### 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/detran/mg/pontuacao-cnh'
args = {
  "registro_cnh": "VALOR_DO_PARAMETRO_REGISTRO_CNH",
  "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.
