## IEPTB (CENPROT) / Protestos
Consulta a existência e os dados de Protestos de pessoas físicas e jurídicas no Instituto de Estudos de Protesto de Títulos do Brasil (IEPTB).É necessário ter uma conta criada no site https://www.pesquisaprotesto.com.br/ para poder usar a consulta com login GOV.BROs protestos de cartórios de SP não retornam detalhes por meio desta API. É necessário usar a API IEPTB (CENPROT) / Protestos / Detalhes SP para obter os detalhes dos protestos de São Paulo, usando o valor do campo obter_detalhes como parâmetro.Essa API possui um limite diário de requisições por login utilizado. Contate o suporte para mais informações.


### Site URL
- https://www.pesquisaprotesto.com.br/

### Request
POST endpoint: `https://api.infosimples.com/api/v2/consultas/ieptb/protestos`



| Parameter     | Description                                                                                                                                                                                                                                                                        |
| ------------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| token*        | The token that will authenticate and authorize the request.                                                                                                                                                                                                                        |
| cnpj**        | CNPJ of the company to be queried.                                                                                                                                                                                                                                                 |
| cpf**         | CPF of the individual to be queried.                                                                                                                                                                                                                                               |
| login_cpf**   | Este parâmetro é necessário caso o login no GOV.BR seja feito 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 site do CENPROT seja feito com certificado digital. Conteúdo do arquivo do certificado digital A1 encriptado seguindo <a href="http://api.infosimples.com/consultas/docs/certificados#criptografia">as instruções de criptografia</a>. |
| pkcs12_pass** | Este parâmetro é necessário caso o login no site do CENPROT seja feito com certificado digital. Senha do certificado digital A1 encriptada seguindo <a href="http://api.infosimples.com/consultas/docs/certificados#criptografia">as instruções de criptografia</a>.               |

> * 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",
    "service": "ieptb/protestos",
    "parameters": {
      "cnpj": "11111111111111"
    },
    "client_name": "Minha Empresa",
    "token_name": "Token de Produção",
    "billable": true,
    "price": "0.24",
    "requested_at": "2020-02-23T17:12:47.000-03:00",
    "elapsed_time_in_milliseconds": 1739,
    "remote_ip": "111.111.111.111",
    "signature": "U2FsdGVkX18zNFcMrUqtH6J9XaNetybNKi69arzHJYJRZ2IvC6rcmfGelMJO1DI8f0xoVYnHlpXQ0ldMNugTDA=="
  },
  "data_count": 1,
  "data": [
    {
      "cartorios": {
        "RJ": [
          {
            "codigo": null,
            "obter_detalhes": null,
            "nome": "Nome de Exemplo",
            "telefone": "1111111111",
            "endereco": "Avenida Paulista",
            "cidade_codigo": "",
            "cidade_codigo_ibge": "",
            "municipio": "São Paulo",
            "cidade": "São Paulo",
            "bairro": "Jardins",
            "atualizacao_data": "",
            "quantidade": "1",
            "periodo_pesquisa": "",
            "protestos": [
              {
                "cpf_cnpj": "11111111111111",
                "data": "",
                "data_protesto": "",
                "data_protesto_string": "",
                "data_vencimento": "",
                "data_vencimento_string": "",
                "valor": 79414.96,
                "valor_string": "79.414,96",
                "chave": "",
                "nome_apresentante": "",
                "nome_cedente": "",
                "tem_anuencia": true
              }
            ]
          }
        ],
        "RS": [
          {
            "codigo": null,
            "obter_detalhes": null,
            "nome": "Nome de Exemplo",
            "telefone": "1111111111",
            "endereco": "Avenida Paulista",
            "cidade_codigo": "",
            "cidade_codigo_ibge": "",
            "municipio": "São Paulo",
            "cidade": "São Paulo",
            "bairro": "Jardins",
            "atualizacao_data": "",
            "quantidade": "1",
            "periodo_pesquisa": "",
            "protestos": [
              {
                "cpf_cnpj": "11111111111111",
                "data": "",
                "data_protesto": "",
                "data_protesto_string": "",
                "data_vencimento": "",
                "data_vencimento_string": "",
                "valor": 79414.96,
                "valor_string": "79.414,96",
                "chave": "",
                "nome_apresentante": "",
                "nome_cedente": "",
                "tem_anuencia": false
              }
            ]
          }
        ]
      },
      "consulta_data": "11/11/1111",
      "consulta_datahora": "23/02/2020 17:07",
      "documento_pesquisado": "11111111111111",
      "quantidade_titulos": 1,
      "site_receipt": "https://api.infosimples.com/exemplo-de-url"
    }
  ],
  "site_receipts": [
    "https://api.infosimples.com/exemplo-de-url"
  ]
}
```


### 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/ieptb/protestos'
args = {
  "cnpj":        "VALUE_OF_PARAMETER_CNPJ",
  "cpf":         "VALUE_OF_PARAMETER_CPF",
  "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("="),
  "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.
