## Polícia Rodoviária Federal / Infrações
Consulta autuações e multas em aberto na Polícia Rodoviária Federal (PRF).


### URL do site
- https://cpag.prf.gov.br/multas

### Requisição
URL para POST: `https://api.infosimples.com/api/v2/consultas/prf/infracoes`



| 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. |
| placa*    | Placa do veículo a ser consultado.                                                                       |
| renavam*  | RENAVAM do veículo a ser consultado.                                                                     |

> * 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",
    "product": "Consultas",
    "service": "prf/infracoes",
    "parameters": {
      "placa": "AAA1111",
      "renavam": "1111111111"
    },
    "client_name": "Minha Empresa",
    "token_name": "Token de Produção",
    "billable": true,
    "price": "0.24",
    "requested_at": "2022-10-28T15:20:09.000-03:00",
    "elapsed_time_in_milliseconds": 133,
    "remote_ip": "111.111.111.111",
    "signature": "U2FsdGVkX18dgEBrCjaESAc0P1hcyl1X41WYNgqrTu7t+YVOgLahJRUM4Rfa+bHiw/1WO+71D/k7kqierU1Fzw=="
  },
  "data_count": 1,
  "data": [
    {
      "codigo_controle": "11111111111111111111",
      "emissao_datahora": "28/10/2022 15:18:21",
      "infracoes": [
        {
          "nosso_numero": "1111111111",
          "ait": "A123456789",
          "placa": "AAA1111",
          "placa_uf": "SP",
          "renavam": "1111111111",
          "local": "Avenida Paulista, 807",
          "datahora": "22/09/2022 14:48:51",
          "codigo": "111",
          "descricao": "Exemplo de descrição",
          "enquadramento": "218 II",
          "amparo": "Lei 9503/97(CTB)",
          "pontos": 5,
          "numero_notificacao": 11111111,
          "data_limite_defesa": "01/01/2000",
          "data_limite_recurso": "01/01/2000",
          "valor": 195.23,
          "valor_devido": 156.18,
          "exigivel": "Não",
          "status": "Aberto",
          "boleto_url": "https://www.exemplo.com/exemplo-de-url",
          "boleto_ait": "A123456789",
          "boleto_vencimento": "11/11/1111",
          "boleto_valor": "111,11",
          "normalizado_boleto_valor": 111.11,
          "boleto_codigo_barras": "123456789012345678901234567890123456789012345678"
        }
      ],
      "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 **pode ser sintetizado pela Infosimples** usando as informações originais da fonte quando o arquivo emitido pela fonte não for adequado para visualização.

### Exemplos de códigos para integração com a API


#### Python
```python
# Testado com: Python 3.10.19, Python 3.14.0
import requests

url = 'https://api.infosimples.com/api/v2/consultas/prf/infracoes'
args = {
  "placa":   "VALOR_DO_PARAMETRO_PLACA",
  "renavam": "VALOR_DO_PARAMETRO_RENAVAM",
  "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.
