## TCU / Consulta Consolidada de Pessoa Jurídica (APF)
Consulta informações sobre um CNPJ no TCU, CNJ e Portal da Transparência (CEIS/CNEP)


### URL do site
- https://certidoes-apf.apps.tcu.gov.br/

### Requisição
URL para POST: `https://api.infosimples.com/api/v2/consultas/tcu/consolidada-pj`



| 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.                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| aceita_resultado_parcial** | Define o comportamento da API quando a fonte apresenta problemas e não consegue emitir todas as certidões e/ou documentos.<ul><li><strong>"0"</strong>: opção padrão. A API retorna código 620. Garante que você só receba código 200 se a informação completa estiver disponível.</li><li><strong>"1"</strong>: a API retorna código 200, com dados parciais. Você receberá os dados que estiverem disponíveis na fonte, eventualmente não contemplando a totalidade das certidões disponíveis.</li></ul> |

> * 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.16-20240305173839",
    "product": "Consultas",
    "service": "tcu/consolidada-pj",
    "parameters": {
      "cnpj": "12.345.678/9012-34"
    },
    "client_name": "Minha Empresa",
    "token_name": "Token de Produção",
    "billable": true,
    "price": "0.2",
    "requested_at": "2024-03-06T13:01:30.000-03:00",
    "elapsed_time_in_milliseconds": 249,
    "remote_ip": "111.111.111.111",
    "signature": "U2FsdGVkX1/v0yD0+xWgLypCoJdQHcjDxl5MTvUKILq8xfXe1pVsaeRXc7JhK0I5G+/q2HgTCc8A5oNR1H3yAg=="
  },
  "data_count": 1,
  "data": [
    {
      "certidoes": [
        {
          "descricao": "Exemplo de descrição",
          "emissor": "Exemplo de Nome",
          "certidao_orgao_original_url": "https://www.exemplo.com/exemplo-de-url",
          "observacao": "Exemplo de Texto",
          "resultado_consulta": "Nada Consta",
          "tempo_geracao": 0.0
        },
        {
          "descricao": "Exemplo de descrição",
          "emissor": "Exemplo de Nome",
          "certidao_orgao_original_url": "https://www.exemplo.com/exemplo-de-url",
          "observacao": "Exemplo de Texto",
          "resultado_consulta": "Nada Consta",
          "tempo_geracao": 0.0
        },
        {
          "descricao": "Exemplo de descrição",
          "emissor": "Exemplo de Nome",
          "certidao_orgao_original_url": "https://www.exemplo.com/exemplo-de-url",
          "observacao": "Exemplo de Texto",
          "resultado_consulta": "Constam Registros",
          "tempo_geracao": 0.0
        },
        {
          "descricao": "Exemplo de descrição",
          "emissor": "Exemplo de Nome",
          "certidao_orgao_original_url": "https://www.exemplo.com/exemplo-de-url",
          "observacao": "Exemplo de Texto",
          "resultado_consulta": "Constam Registros",
          "tempo_geracao": 0.0
        }
      ],
      "cnpj": "12.345.678/9012-34",
      "nome_fantasia": "Exemplo de Nome Fantasia",
      "razao_social": "Exemplo de Razão Social",
      "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

url = 'https://api.infosimples.com/api/v2/consultas/tcu/consolidada-pj'
args = {
  "cnpj":                     "VALOR_DO_PARAMETRO_CNPJ",
  "aceita_resultado_parcial": "VALOR_DO_PARAMETRO_ACEITA_RESULTADO_PARCIAL",
  "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.
