## SEFAZ / MG / DEC / Caixa Postal
Retorna mensagens de uma página da Caixa Postal do DEC (Domicílio Eletrônico do Contribuinte) da Secretaria da Fazenda de Minas Gerais.


### URL do site
- https://www2.fazenda.mg.gov.br/sol/

### Requisição
URL para POST: `https://api.infosimples.com/api/v2/consultas/sefaz/mg/dec/caixa-postal`



| 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.                                                                                                    |
| pkcs12_cert*       | 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*       | Senha do certificado digital A1 encriptada seguindo <a href="http://api.infosimples.com/consultas/docs/certificados#criptografia">as instruções de criptografia</a>.                                        |
| ignora_nao_lidas** | Se for informado o valor 0, a API abrirá as mensagens não lidas da caixa postal.                                                                                                                            |
| data_inicio**      | Data de início no formato ISO 8601. Por exemplo, 22 de Abril de 1985 é representado em ISO 8601 da forma "1985-04-22". Preste atenção que é necessário incluir zeros, o formato "1985-4-22" seria inválido. |
| data_fim**         | Data de fim no formato ISO 8601. Por exemplo, 22 de Abril de 1985 é representado em ISO 8601 da forma "1985-04-22". Preste atenção que é necessário incluir zeros, o formato "1985-4-22" seria inválido.    |

> * 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",
    "product": "Consultas",
    "service": "sefaz/mg/dec/caixa-postal",
    "parameters": {
      "ignora_nao_lidas": 1,
      "data_inicio": "1111-11-11",
      "data_fim": "1111-11-11",
      "pkcs12_cert_md5": "aa25eae9298a43740f9a763477c20a1f",
      "pkcs12_pass_md5": "c9c59c5246576b81c3f2712100204dec"
    },
    "client_name": "Minha Empresa",
    "token_name": "Token de Produção",
    "billable": true,
    "price": "0.2",
    "requested_at": "2022-07-13T19:38:01.000-03:00",
    "elapsed_time_in_milliseconds": 225,
    "remote_ip": "111.111.111.111",
    "signature": "U2FsdGVkX19/6LXsazqd+03hxUasdicsDfDxoAOXhmJB6oAoGDT/FlJZYBk4YlJNFnRPJuEc4psHQQ9QGQfJ0g=="
  },
  "data_count": 1,
  "data": [
    {
      "lidas": 1,
      "mensagens": [
        {
          "lida": false,
          "envio_data": "11/11/1111",
          "ciencia_data": "11/11/1111",
          "assunto": "Exemplo de Texto",
          "categoria": "Comunicação",
          "nome_empresarial": null,
          "ie": null,
          "numero_mensagem": null,
          "remetente": null,
          "protocolo": null,
          "situacao_protocolo": null,
          "protocolo_transmissao": null,
          "transmissao_data": null,
          "tipo_declaracao": null,
          "periodo": null,
          "situacao": null,
          "conteudo_texto": null,
          "conteudo_html": null
        },
        {
          "lida": true,
          "envio_data": "11/11/1111 11:11:11",
          "ciencia_data": "11/11/1111 11:11:1",
          "assunto": "Exemplo de Texto",
          "categoria": "Comunicação",
          "nome_empresarial": "Exemplo de Nome",
          "ie": "11111111",
          "numero_mensagem": "11111111",
          "remetente": "Exemplo de Texto",
          "protocolo": "111.111.111.111-1",
          "situacao_protocolo": "INDEFERIDA",
          "protocolo_transmissao": "111.111.111.111-1",
          "transmissao_data": "11/11/1111",
          "tipo_declaracao": "Exemplo de Texto",
          "periodo": "11/1111",
          "situacao": "Desprezada",
          "conteudo_texto": "Exemplo de mensagem",
          "conteudo_html": "<div>Exemplo de <b>mensagem</b></div>"
        }
      ],
      "nao_lidas": 1,
      "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
import base64
# pip install aes-bridge
import aes_bridge

url = 'https://api.infosimples.com/api/v2/consultas/sefaz/mg/dec/caixa-postal'
args = {
  "pkcs12_cert":      aes_bridge.encrypt(base64.b64encode(open("certificado.pfx", "rb").read()).decode(), "INFORME_A_CHAVE_DE_CRIPTOGRAFIA").decode("ascii").replace("+", "-").replace("/", "_").rstrip("="),
  "pkcs12_pass":      aes_bridge.encrypt("SENHA_DO_CERTIFICADO", "INFORME_A_CHAVE_DE_CRIPTOGRAFIA").decode("ascii").replace("+", "-").replace("/", "_").rstrip("="),
  "ignora_nao_lidas": "VALOR_DO_PARAMETRO_IGNORA_NAO_LIDAS",
  "data_inicio":      "VALOR_DO_PARAMETRO_DATA_INICIO",
  "data_fim":         "VALOR_DO_PARAMETRO_DATA_FIM",
  "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.
