marcelabeh/emissor-nfse-nacional

Biblioteca PHP para emissão, consulta e cancelamento de NFS-e Nacional (Sefin) — Clean Architecture, validação XSD v1.01, assinatura SHA-256, suporte IBS/CBS

Maintainers

Package info

github.com/MarcelaBeh/emissor-nfse-nacional

Homepage

Issues

pkg:composer/marcelabeh/emissor-nfse-nacional

Statistics

Installs: 52

Dependents: 0

Suggesters: 0

Stars: 10

v2.1.1 2026-05-22 23:22 UTC

README

NFSe Nacional

Packagist PHP Version PHPStan Tests License

Biblioteca PHP para integração com NFSe Nacional - Pacote Composer reutilizável para emissão, consulta e cancelamento de Notas Fiscais de Serviço Eletrônicas no padrão nacional.

Clean ArchitectureSOLIDPSR-12PHP 8.3+PHPStan Level 8

📦 Instalação

composer require marcelabeh/emissor-nfse-nacional

🚀 Uso Rápido

use MarcelaBeh\EmissorNfseNacional\Presentation\Facade\NfseNacionalFacade;
use MarcelaBeh\EmissorNfseNacional\Presentation\Factory\ConfigFactory;
use NFePHP\Common\Certificate;

// 1. Carregar certificado
$certificado = Certificate::loadPfx($caminhoCertificado, $senha);

// 2. Criar configuração
$config = ConfigFactory::createHomologacao('codigo-ibge-municipio');

// 3. Criar facade
$nfse = NfseNacionalFacade::create((array)$config, $certificado);

// 4. Emitir DPS
$response = $nfse->emitirDps($dpsRequest);

📚 Documentação

Documento Descrição
GUIA_IMPLEMENTACAO.md Guia completo de uso com exemplos
ARQUITETURA.md Arquitetura do sistema e decisões de design
SEGURANCA_COMPLIANCE.md Diretrizes de segurança
CONTRIBUTING.md Como contribuir
CHANGELOG.md Histórico de alterações
examples/ Exemplos práticos de uso

✅ Requisitos

  • PHP 8.3+
  • ext-dom, ext-curl, ext-zlib, ext-openssl, ext-mbstring

🔧 Qualidade de Código

composer test    # PHPUnit (633 testes, 1571 assertions)
composer cs      # PHP-CS-Fixer (dry-run)
composer cs:fix  # PHP-CS-Fixer (aplicar)
composer stan    # PHPStan nível 8
composer check   # Tudo junto

Métricas:

  • 633 testes unitários e de integração
  • PHPStan nível 8 (máximo rigor) - 0 erros
  • Clean Architecture - 9.5/10
  • SOLID completo - 9/10
  • PSR-12 - Code style padronizado
  • 100% compliance com especificações NFSe Nacional v1.00 e v1.01

📁 Estrutura

src/
├── Domain/           # Entidades e Value Objects
├── Application/     # Services e DTOs
├── Infrastructure/  # HTTP, XML, Segurança
└── Presentation/    # Facade e Factories

🏛️ Padrões Aplicados

Padrão Onde
Clean Architecture Separação em camadas (Domain → Application → Infrastructure → Presentation)
Facade NfseNacionalFacade - ponto único de entrada
Factory ServiceFactory, ConfigFactory - criação de dependências
DTO DpsRequest, NfseResponse, EventoRequest - transporte de dados
Value Object Cnpj, Cpf, Money, ChaveAcesso - imutáveis e auto-validáveis
Validator DpsValidator, XsdValidator - validação de entrada e XML

🔄 Fluxo de Uso

1. Carregar certificado → Certificate::loadPfx()
2. Criar configuração → ConfigFactory::createHomologacao() ou createProducao()
3. Instanciar facade → NfseNacionalFacade::create()
4. Montar request → DpsRequest / EventoRequest
5. Executar operação → facade->emitirDps() / consultarPorChave() / cancelar()

📄 API Principal

NfseNacionalFacade - Ponto único de entrada:

  • emitirDps(DpsRequest)NfseResponse
  • consultarPorChave(string)NfseResponse|null
  • consultarDpsPorChave(string)array
  • cancelar(EventoRequest)EventoResponse
  • consultarEventos(string)array
  • consultarDanfse(string)string|array
  • consultarDanfseNfse(string)string|array

⚠️ Avisos Importantes

Configuração do Município

A variável prefeitura deve receber o código IBGE do município (7 dígitos), conforme especificação dos XSDs da NFSe (ABRASF).

Encoding XML

O XML pode vir em ISO-8859-1. Use o segundo parâmetro se necessário:

$nfse->consultarPorChave('CHAVE', false);

🐛 FAQ - Erro E999

O erro E999 indica falha não catalogada pela Receita. Causas comuns:

  • CNPJ/CPF do prestador não cadastrado/habilitado na NFSe Nacional
  • Erros de servidor (500)
  • Problemas no ambiente de homologação (comum)

🤝 Créditos e Agradecimentos

Este projeto é uma reestruturação completa com Clean Architecture do projeto original.

📦 Projeto Original

🔐 Dependências

👩‍💻 Manutenção Atual

  • Marcela Beatriz (@marcelabeh)
  • Arquitetura: Clean Architecture + SOLID + DDD
  • Cobertura de testes: 633 testes
  • Análise estática: PHPStan level 8

📜 Licença

LGPL-3.0-or-later (GNU Lesser General Public License v3.0 ou posterior)

Veja o arquivo LICENSE para detalhes completos.

💼 O que isso significa?

Você PODE:

  • Usar comercialmente (grátis)
  • Modificar o código
  • Distribuir em projetos proprietários
  • Vender produtos que usam esta biblioteca

⚠️ Você DEVE:

  • Manter o copyright original
  • Se modificar A BIBLIOTECA, compartilhar as mudanças (LGPL)
  • Incluir uma cópia da licença LGPL