## Contas / CPFL / Download (Empresas)
Faz download da conta de energia elétrica mais recente na Agência Virtual para Empresas da CPFL.


### URL do site
- https://www.cpfl.com.br/b2c-auth/login

### Requisição
URL para POST: `https://api.infosimples.com/api/v2/consultas/contas/cpfl/download-empresas`



| 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.        |
| email*       | Login utilizado para acessar o site.                                                                            |
| senha*       | Senha utilizada para acessar o site.                                                                            |
| instalacao** | Número da instalação a ser consultada. Caso não seja informada, será retornado o primeiro resultado encontrado. |
| cnpj**       | CNPJ da instalação a ser consultada. Caso não seja informado, será retornado o primeiro resultado encontrado.   |
| cpf**        | CPF da instalação a ser consultada. Caso não seja informado, será retornado o primeiro resultado encontrado.    |

> * 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.8-20230530111258",
    "product": "Consultas",
    "service": "contas/cpfl/download-empresas",
    "parameters": {
      "cnpj": "12.345.678/9012-34",
      "cpf": "123.456.789-01",
      "email": "exemplo@email.com",
      "instalacao": "1234567890",
      "senha_md5": "e379c59a3573be16480533ae3f53ea1b"
    },
    "client_name": "Minha Empresa",
    "token_name": "Token de Produção",
    "billable": true,
    "price": "0.2",
    "requested_at": "2023-05-31T08:29:35.000-03:00",
    "elapsed_time_in_milliseconds": 559,
    "remote_ip": "111.111.111.111",
    "signature": "U2FsdGVkX1/iYJshV7oFwRZ/qnSyidQBiBfF3NMO80qljb19sB8VFKJVTgyYYDFFkdX/gyMsznqDtYbv/YIqgw=="
  },
  "data_count": 1,
  "data": [
    {
      "cliente": "123456789",
      "clientes_cnpj": [
        "12.345.678/9012-34",
        "12.345.678/9012-34"
      ],
      "clientes_cpf": [
        "123.456.789-12",
        "123.456.789-12",
        "123.456.789-12",
        "123.456.789-12"
      ],
      "consumo_total": "22,94",
      "conta_paga": true,
      "endereco": "Avenida Paulista, 807. São Paulo. SP. Brasil.",
      "instalacao": "1234567890",
      "lista_instalacoes": [
        "1234567890"
      ],
      "mes_referencia": "04/2023",
      "nome": "Exemplo de Nome",
      "normalizado_consumo_total": 22.94,
      "normalizado_valor": 2649.86,
      "valor": "2.649,86",
      "vencimento": "",
      "site_receipt": "https://www.exemplo.com/exemplo-de-url"
    }
  ],
  "site_receipts": []
}
```


### 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/contas/cpfl/download-empresas'
args = {
  "email":      "VALOR_DO_PARAMETRO_EMAIL",
  "senha":      "VALOR_DO_PARAMETRO_SENHA",
  "instalacao": "VALOR_DO_PARAMETRO_INSTALACAO",
  "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.
