## ANP / Certificados
Através do CPF ou CNPJ, é possível emitir um Certificado de Autorização de Operação de Ponto de Abastecimento.


### URL do site
- https://spa.anp.gov.br/consultas_certificados.asp

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



| 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. |
| cnpj**    | CNPJ da empresa a ser consultada.                                                                        |
| cpf**     | CPF do indivíduo 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",
    "service": "anp/certificados",
    "parameters": {
      "cnpj": "11111111111111"
    },
    "client_name": "Minha Empresa",
    "token_name": "Token de Produção",
    "billable": true,
    "price": "0.2",
    "requested_at": "2019-03-11T10:36:33.000-03:00",
    "elapsed_time_in_milliseconds": 3,
    "remote_ip": "111.111.111.111",
    "signature": "U2FsdGVkX1+ZlwZsamgFi5fXeSwa2pv4tdfgQabjbDK7KVXnGpENA6YlwsmfDmhArXAao9jX1oaQPLeFhj24yg=="
  },
  "data_count": 1,
  "data": [
    {
      "consulta_comprovante": "11A1.AA11.11AA.AA1A",
      "consulta_datahora": "11/03/2019 07:30",
      "empresa_cnpj_cpf": "11.111.111",
      "empresa_codigo_agente_simp": "1111111111",
      "empresa_endereco_bairro": "Jardins",
      "empresa_endereco_cep": "01311-300",
      "empresa_endereco_complemento": "Apartamento Prédio A",
      "empresa_endereco_logradouro": "Avenida Paulista",
      "empresa_endereco_municipio": "São Paulo",
      "empresa_endereco_numero": "Km 111",
      "empresa_endereco_uf": "SP",
      "empresa_razao_social": "Empresa XYZ",
      "instalacao_cnpj_cpf": "11.111.111/1111-11",
      "instalacao_codigo_simp": "1111111 - Autorizada em: 11/11/1111",
      "instalacao_codigo_simp_codigo": "1111111",
      "instalacao_codigo_simp_data": "11/11/1111",
      "instalacao_codigo_simp_status": "Autorizada",
      "instalacao_endereco_bairro": "Jardins",
      "instalacao_endereco_cep": "01311-300",
      "instalacao_endereco_complemento": "Apartamento Prédio A",
      "instalacao_endereco_logradouro": "Avenida Paulista",
      "instalacao_endereco_municipio": "São Paulo",
      "instalacao_endereco_numero": "km 11",
      "instalacao_endereco_uf": "SP",
      "instalacao_nome": "Nome de Exemplo",
      "licenca_emissor": "SEMAD",
      "licenca_numero_operacao": "111/1111",
      "licenca_validade_data": "11/11/1111",
      "protocolo_data": "",
      "protocolo_emissor": "",
      "protocolo_numero": "",
      "tanques": [
        [
          "1",
          "ÓLEO DIESEL B S10 - COMUM",
          "15,00"
        ]
      ],
      "site_receipt": "https://api.infosimples.com/receipt/exemplo-de-url"
    }
  ],
  "site_receipts": [
    "https://api.infosimples.com/receipt/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

url = 'https://api.infosimples.com/api/v2/consultas/anp/certificados'
args = {
  "cnpj":    "VALOR_DO_PARAMETRO_CNPJ",
  "cpf":     "VALOR_DO_PARAMETRO_CPF",
  "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.
