## DNIT / Infrações (CNPJ)
Consulta dados de multas e situação de débitos no Departamento Nacional de Infraestrutura de Transportes (DNIT), que tem como uma das funções aplicar multas por excesso de peso e ou de velocidade, por meio dos postos de pesagem e das lombadas eletrônicas nas rodovias federais. Retorna as 50 infrações mais recentes. Os dados são obtidos através do CNPJ e Razão social informados.


### Site URL
- https://servicos.dnit.gov.br/multas/conta/login

### Request
POST endpoint: `https://api.infosimples.com/api/v2/consultas/dnit/infracoes-cnpj`



| Parameter     | Description                                                                                                                                                                                                                                                                |
| ------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| token*        | The token that will authenticate and authorize the request.                                                                                                                                                                                                                |
| login_cpf**   | Este parâmetro é necessário tanto para o uso de certificado digital quanto para o login 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>.               |
| cnpj*         | CNPJ da empresa vinculada ao login GOV.BR a ser consultada                                                                                                                                                                                                                 |
| razao_social* | Razão social completa da forma que consta no registro da Receita Federal                                                                                                                                                                                                   |

> * 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.19-20240619232643",
    "product": "Consultas",
    "service": "dnit/infracoes-cnpj",
    "parameters": {
      "login_cpf_md5": "e379c59a3573be16480533ae3f53ea1b",
      "login_senha_md5": "e379c59a3573be16480533ae3f53ea1b",
      "cnpj": "00000000000000",
      "razao_social": "Empresa XYZ"
    },
    "client_name": "Minha Empresa",
    "token_name": "Token de Produção",
    "billable": true,
    "price": "0.2",
    "requested_at": "2024-06-20T10:45:36.000-03:00",
    "elapsed_time_in_milliseconds": 623,
    "remote_ip": "111.111.111.111",
    "signature": "U2FsdGVkX19IG/yRE+VQ8+EtzWqCELu9rTqQFaXAh+GgrKoGokEF7Udx/WeO8pVERqF9+1lR/ugztA+uun19CQ=="
  },
  "data_count": 1,
  "data": [
    {
      "cnpj": "12.345.678/9012-34",
      "infracoes": [
        {
          "site_consulta_url": "https://www.exemplo.com/exemplo-de-url",
          "ait": "A123456789",
          "descricao": "Exemplo de descrição",
          "placa": "AAA1111",
          "placa_uf": "SP",
          "datahora": "26/08/2016 às 13h30min",
          "local": "Avenida Paulista, 807",
          "municipio": "SAO PAULO / SP",
          "situacao": "Encerrado - Descrição indisponível.",
          "gravidade": "Art. 218, I / Média - 4 pontos",
          "desconto_sne": "Não",
          "valor": "R$ 85,13",
          "cnpj": "12.345.678/9012-34",
          "cpf": "123.456.789-01",
          "codigo_proprietario": 11111111,
          "enquadramento": "Velocidade superior em até 20%",
          "codigo_enquadramento": 12345,
          "fase_atual": "Ativo - Fase de Penalidade",
          "causa_cancelamento": "Descrição indisponível.",
          "vencimento": "01/09/2017",
          "url_foto": "https://www.exemplo.com/exemplo-de-url",
          "normalizado_datahora": "26/08/2016 13:30:00",
          "normalizado_valor": 85.13,
          "normalizado_valor_guia": 0.0,
          "normalizado_cpf": "12345678901",
          "normalizado_cnpj": "12345678901234",
          "debito_quitado": true
        },
        {
          "site_consulta_url": "https://www.exemplo.com/exemplo-de-url",
          "ait": "A123456789",
          "descricao": "Exemplo de descrição",
          "placa": "AAA1111",
          "placa_uf": "SP",
          "datahora": "12/10/2018 às 10h06min",
          "local": "Avenida Paulista, 807",
          "municipio": "SAO PAULO / SP",
          "situacao": "Encerrado - Descrição indisponível.",
          "gravidade": "Art. 218, I / Média - 4 pontos",
          "desconto_sne": "Não",
          "valor": "R$ 130,16",
          "cnpj": "12.345.678/9012-34",
          "cpf": "123.456.789-01",
          "codigo_proprietario": 11111111,
          "enquadramento": "Velocidade superior em até 20%",
          "codigo_enquadramento": 12345,
          "fase_atual": "Ativo - Fase de Penalidade",
          "causa_cancelamento": "Descrição indisponível.",
          "vencimento": "23/05/2019",
          "url_foto": "https://www.exemplo.com/exemplo-de-url",
          "normalizado_datahora": "12/10/2018 10:06:00",
          "normalizado_valor": 130.16,
          "normalizado_valor_guia": 0.0,
          "normalizado_cpf": "12345678901",
          "normalizado_cnpj": "12345678901234",
          "debito_quitado": true
        }
      ],
      "site_receipt": "https://www.exemplo.com/exemplo-de-url"
    }
  ],
  "site_receipts": []
}
```


### 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/dnit/infracoes-cnpj'
args = {
  "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("="),
  "cnpj":         "VALUE_OF_PARAMETER_CNPJ",
  "razao_social": "VALUE_OF_PARAMETER_RAZAO_SOCIAL",
  "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.
