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
Package info
github.com/MarcelaBeh/emissor-nfse-nacional
pkg:composer/marcelabeh/emissor-nfse-nacional
Requires
- php: ^8.3
- ext-curl: *
- ext-dom: *
- ext-mbstring: *
- ext-openssl: *
- ext-zlib: *
- nfephp-org/sped-common: ^5.1
Requires (Dev)
- friendsofphp/php-cs-fixer: ^3.59
- phpstan/phpstan: ^2.1
- phpunit/phpunit: ^10
- roave/security-advisories: dev-latest
This package is auto-updated.
Last update: 2026-05-29 13:01:56 UTC
README
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 Architecture • SOLID • PSR-12 • PHP 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)→NfseResponseconsultarPorChave(string)→NfseResponse|nullconsultarDpsPorChave(string)→arraycancelar(EventoRequest)→EventoResponseconsultarEventos(string)→arrayconsultarDanfse(string)→string|arrayconsultarDanfseNfse(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
- Repositório: hadder/nfse-nacional
- Autor: Fernando Friedrich (@fernando-friedrich)
- Contribuição: Base inicial e compreensão das regras de negócio NFSe Nacional
🔐 Dependências
- NFePHP/sped-common - Manipulação de certificados digitais A1/A3 e assinatura XML
- Projeto mantido pela comunidade brasileira desde 2008
- github.com/nfephp-org/sped-common
- Criado por Roberto L. Machado (@robmachado)
👩💻 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
