Metadata-Version: 2.4
Name: dfe-nfse
Version: 0.2.0
Summary: Biblioteca para baixar NFSe do Ambiente Nacional (ADN)
Home-page: https://github.com/DaavidSiilva/dfe-nfse
Author: David Silva
Author-email: david.emery.silva@gmail.com
Project-URL: Homepage, https://tax-transformation.com/
Project-URL: Repository, https://github.com/DaavidSiilva/dfe-nfse
Project-URL: linkedin, https://www.linkedin.com/in/davidm-silva/
Classifier: Programming Language :: Python :: 3
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: OS Independent
Requires-Python: >=3.6
Description-Content-Type: text/markdown
License-File: LICENSE
Requires-Dist: requests
Requires-Dist: cryptography
Dynamic: author
Dynamic: author-email
Dynamic: classifier
Dynamic: description
Dynamic: description-content-type
Dynamic: home-page
Dynamic: license-file
Dynamic: project-url
Dynamic: requires-dist
Dynamic: requires-python
Dynamic: summary

<div align="center">
  <img src="https://raw.githubusercontent.com/DaavidSiilva/dfe-nfse/main/assets/logo.png" alt="Logo DFE-NFSe" width="200"/>
</div>

<p align="center">
  <img src="https://static.pepy.tech/badge/dfe-nfse" />
  <img src="https://img.shields.io/pypi/v/dfe-nfse" />
  <img src="https://img.shields.io/github/stars/DaavidSiilva/dfe-nfse" />
</p>

# NFSe Nacional

Biblioteca Python desenvolvida para facilitar o download e automação de Notas Fiscais de Serviço Eletrônicas (NFSe) diretamente do Ambiente de Dados Nacional (ADN).

Esta ferramenta foi projetada para interagir com a API oficial da Receita Federal, gerenciar certificados digitais A1 e organizar os arquivos XML baixados de forma estruturada.

Documentação Oficial ADN: https://adn.nfse.gov.br/contribuintes/docs/index.html

## Funcionalidades

- Integração direta com o Ambiente de Dados Nacional (ADN).
- Conversão automática de certificados (.pfx) para formatos compatíveis com a API (.pem/.key).
- Download em lote de documentos fiscais a partir de um NSU (Número Sequencial Único).
- Organização automática dos arquivos XML baixados em diretórios por Ano e Mês (ex: 2024.01).
- Download de DANFSe através da chave de acesso.


## Instalação

A biblioteca está disponível no PyPI e pode ser instalada utilizando o pip:

```bash
pip install dfe-nfse
```

## Como Usar

Para utilizar a biblioteca, é necessário possuir um certificado digital modelo A1 válido e sua respectiva senha.

### Exemplo Básico de Download XML

```python
from nfse import download_nfse

# Configurações iniciais
cnpj_empresa = "00000000000000"
nsu_inicial = 100  # Último NSU processado ou 0 para o início
caminho_saida = "./documentos_fiscais"
caminho_certificado = "/caminho/para/seu/certificado.pfx"
senha_certificado = "sua_senha_segura"

# Executa o download
resultado = download_nfse(
    cnpj=cnpj_empresa,
    nsu=nsu_inicial,
    output_path=caminho_saida,
    cert_path=caminho_certificado,
    cert_password=senha_certificado
)

print(f"Status da operação: {resultado}")
```

### Exemplo Básico de Download danfse

```python
from nfse import download_danfse

# Configurações iniciais
chave = "00000000000000000000000000000000000000000000000000"
caminho_saida = "./PDF"
caminho_certificado = "/caminho/para/seu/certificado.pfx"
senha_certificado = "sua_senha_segura"

# Executa o download
resultado = download_danfse(
    chave=chave,
    output_path=caminho_saida,
    cert_path=caminho_certificado,
    cert_password=senha_certificado
)

print(f"Status da operação: {resultado}")
```

### Detalhes dos Parâmetros

A função `download_nfse` aceita os seguintes argumentos:

- **cnpj (str)**: O CNPJ da empresa contribuinte (apenas números ou com formatação padrão). A biblioteca normaliza automaticamente removendo pontuações.
- **nsu (int)**: Número Sequencial Único a partir do qual a busca será realizada. Utilize este controle para baixar apenas notas novas.
- **output_path (str)**: Diretório raiz onde os XMLs serão salvos. A estrutura interna será criada automaticamente no formato `Ano.Mes/ChaveAcesso.xml`.
- **cert_path (str)**: Caminho absoluto ou relativo para o arquivo do certificado digital (.pfx).
- **cert_password (str)**: Senha para descriptografar o certificado digital.

### Retorno

A função retorna uma string com o resultado da operação, que pode ser:
- Confirmação de quantidade de documentos baixados.
- Mensagens de erro da API (404, 500, etc.).
- Exceções locais (arquivo não encontrado, senha incorreta).

## Requisitos do Sistema

- Python 3.6 ou superior
- Biblioteca `requests`
- Biblioteca `cryptography`

## Estrutura de Arquivos

Após a execução, os arquivos serão organizados da seguinte forma no diretório de saída:

```text
documentos_fiscais/
├── 2023.12/
│   ├── 35231200000000000000000000000000000000000001.xml
│   └── 35231200000000000000000000000000000000000002.xml
└── 2024.01/
    ├── 35240100000000000000000000000000000000000001.xml
    └── ...
```

## Licença

Distribuído sob a licença MIT. Consulte o arquivo `LICENSE` para mais informações.
