## Prefeitura / RJ / Rio de Janeiro / NFS-e (Nota Fiscal Eletrônica de Serviços)
Consulta uma Nota Fiscal Eletrônica de Serviços na Prefeitura do município do Rio de Janeiro e retorna os dados da nota obtidos a partir da aplicação de um OCR (a confiabilidade dos dados retornados não é 100% por se tratar de um OCR).


### Site URL
- https://notacarioca.rio.gov.br/Documentos/verificacao.aspx

### Request
POST endpoint: `https://api.infosimples.com/api/v2/consultas/pref/rj/rio-janeiro/nfs`



| Parameter           | Description                                                 |
| ------------------- | ----------------------------------------------------------- |
| token*              | The token that will authenticate and authorize the request. |
| cpf**               | CPF of the individual to be queried.                        |
| cnpj**              | CNPJ of the company to be queried.                          |
| numero_nota*        | Numero_nota                                                 |
| codigo_verificacao* | Codigo_verificacao                                          |

> * 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",
    "product": "Consultas",
    "service": "pref/rj/rio-janeiro/nfs",
    "parameters": {
      "cnpj": "12345678901234",
      "codigo_verificacao": "A1B2C3D4",
      "numero_nota": "1234"
    },
    "client_name": "Minha Empresa",
    "token_name": "Token de Produção",
    "billable": true,
    "price": "0.1",
    "requested_at": "2022-02-15T15:13:38.000-03:00",
    "elapsed_time_in_milliseconds": 154,
    "remote_ip": "111.111.111.111",
    "signature": "U2FsdGVkX18CGeuSJposKlyZOKMhPgoeCUYK3FEFpP/JjvD3B+DZWTO+vsR4DfJ2qMePk7qyU5ppLo9YCatCPw=="
  },
  "data_count": 1,
  "data": [
    {
      "cancelada": false,
      "logo_visivel": true,
      "ocr_codigo_servico": "1111 - Exemplo de serviço",
      "ocr_codigo_verificacao": "XXXX-XXXX",
      "ocr_discriminacao": "Exemplo de discriminação",
      "ocr_emissao_datahora": "10/04/2013 18:34:58",
      "ocr_numero": "00000000",
      "ocr_outras_informacoes": "Outras informações",
      "ocr_prestador_cpf_cnpj": "12345678901234",
      "ocr_prestador_email": "exemplo@email.com",
      "ocr_prestador_endereco": "Avenida Paulista, 807. São Paulo. SP. Brasil.",
      "ocr_prestador_inscricao_municipal": "11111111",
      "ocr_prestador_municipio": "São Paulo",
      "ocr_prestador_nome": "Exemplo de Nome",
      "ocr_prestador_uf": "SP",
      "ocr_tomador_cpf_cnpj": "12345678901234",
      "ocr_tomador_email": "exemplo@email.com",
      "ocr_tomador_endereco": "Avenida Paulista, 807. São Paulo. SP. Brasil.",
      "ocr_tomador_inscricao_municipal": "11111111",
      "ocr_tomador_municipio": "São Paulo",
      "ocr_tomador_nome": "Exemplo de Nome",
      "ocr_tomador_uf": "SP",
      "ocr_valor_aliquota": "",
      "ocr_valor_base_calculo": "140.00",
      "ocr_valor_credito": "0.70",
      "ocr_valor_deducoes": "0.00",
      "ocr_valor_iss": "7.00",
      "ocr_valor_total": "140.00",
      "site_receipt": "https://www.exemplo.com/exemplo-de-url"
    }
  ],
  "site_receipts": [
    "https://www.exemplo.com/exemplo-de-url"
  ]
}
```


### Preview file

The preview file (`site_receipts`) in the response JSON is **generated by the source (website/app)** that processed the automation.

### Code snippets


#### Python
```python
# Tested with: Python 3.10.19, Python 3.14.0
import requests

url = 'https://api.infosimples.com/api/v2/consultas/pref/rj/rio-janeiro/nfs'
args = {
  "cpf":                "VALUE_OF_PARAMETER_CPF",
  "cnpj":               "VALUE_OF_PARAMETER_CNPJ",
  "numero_nota":        "VALUE_OF_PARAMETER_NUMERO_NOTA",
  "codigo_verificacao": "VALUE_OF_PARAMETER_CODIGO_VERIFICACAO",
  "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.
