From 371fc47a25df37f23e1bfe9fabbbdd478e0c233d Mon Sep 17 00:00:00 2001 From: Patrick Acioli Date: Tue, 18 Jun 2019 20:51:09 -0300 Subject: [PATCH 1/9] Add specific version of PyXB --- requirements-nfse.txt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/requirements-nfse.txt b/requirements-nfse.txt index a203ffa..582da17 100644 --- a/requirements-nfse.txt +++ b/requirements-nfse.txt @@ -1,3 +1,3 @@ # Opcional para NFS-e suds-jurko -pyxb +pyxb=1.2.4 From d37c46ff30205c10b16b5f29eefcbdf5db15e21b Mon Sep 17 00:00:00 2001 From: juniortada Date: Mon, 1 Jul 2019 21:18:04 -0300 Subject: [PATCH 2/9] [new] add NFC-e MG #69 --- pynfe/processamento/serializacao.py | 4 ++-- pynfe/utils/webservices.py | 18 +++++++++++------- 2 files changed, 13 insertions(+), 9 deletions(-) diff --git a/pynfe/processamento/serializacao.py b/pynfe/processamento/serializacao.py index c87074a..6cbec9b 100644 --- a/pynfe/processamento/serializacao.py +++ b/pynfe/processamento/serializacao.py @@ -757,10 +757,10 @@ class SerializacaoQrcode(object): elif uf.upper() == 'SP': if tpamb == '1': qrcode = NFCE[uf.upper()]['HTTPS'] + 'www.' + NFCE[uf.upper()]['QR'] + url - url_chave = NFCE[uf.upper()]['HTTPS'] + 'www.' + NFCE[uf.upper()]['URL'] + url + url_chave = NFCE[uf.upper()]['HTTPS'] + 'www.' + NFCE[uf.upper()]['URL'] else: qrcode = NFCE[uf.upper()]['HTTPS'] + 'www.homologacao.' + NFCE[uf.upper()]['QR'] + url - url_chave = NFCE[uf.upper()]['HTTPS'] + 'www.homologacao.' + NFCE[uf.upper()]['URL'] + url + url_chave = NFCE[uf.upper()]['HTTPS'] + 'www.homologacao.' + NFCE[uf.upper()]['URL'] # BA tem comportamento distindo para qrcode e url elif uf.upper() == 'BA': if tpamb == '1': diff --git a/pynfe/utils/webservices.py b/pynfe/utils/webservices.py index d3c58af..51dc74b 100644 --- a/pynfe/utils/webservices.py +++ b/pynfe/utils/webservices.py @@ -157,13 +157,17 @@ NFCE = { 'URL': 'http://hinternet.sefaz.ba.gov.br/nfce/consulta' }, 'MG': { - 'STATUS': '', - 'AUTORIZACAO': '', - 'RECIBO': '', - 'CHAVE': '', - 'INUTILIZACAO': '', - 'EVENTOS': '', - 'QR': '' + 'STATUS': 'fazenda.mg.gov.br/nfce/services/NFeStatusServico4', + 'AUTORIZACAO': 'fazenda.mg.gov.br/nfce/services/NFeAutorizacao4', + 'RECIBO': 'fazenda.mg.gov.br/nfce/services/NFeRetAutorizacao4', + 'CHAVE': 'fazenda.mg.gov.br/nfce/services/NFeConsultaProtocolo4', + 'INUTILIZACAO': 'fazenda.mg.gov.br/nfce/services/NFeInutilizacao4', + 'EVENTOS': 'fazenda.mg.gov.br/nfce/services/NFeRecepcaoEvento4', + 'CADASTRO': 'fazenda.mg.gov.br/nfce/services/CadConsultaCadastro4', + 'QR': 'fazenda.mg.gov.br/portalnfce/sistema/qrcode.xhtml?', + 'HTTPS': 'https://nfce.', + 'HOMOLOGACAO': 'https://hnfce.', + 'URL': 'fazenda.mg.gov.br/portalnfce' }, 'ES': { 'STATUS': '', From 2eb45107fe954d4596e335bc0e952afa9a52bea8 Mon Sep 17 00:00:00 2001 From: juniortada Date: Mon, 9 Sep 2019 15:55:15 -0300 Subject: [PATCH 3/9] update readme and setup --- README.md | 4 +++- setup.py | 10 +++++++--- 2 files changed, 10 insertions(+), 4 deletions(-) diff --git a/README.md b/README.md index eb45520..b8ee260 100644 --- a/README.md +++ b/README.md @@ -91,7 +91,9 @@ Documentação - https://github.com/leotada/PyNFe/wiki - http://pynfe.readthedocs.org/pt/latest/ -backlog: + +Backlog +------- - renomeado metodo serializar_evento (_serializar_evento) - removido metoco con.cancelar (utilizar con.evento) - add evento carta de correção (con.evento) diff --git a/setup.py b/setup.py index f042f17..13d22d3 100644 --- a/setup.py +++ b/setup.py @@ -1,5 +1,5 @@ #!/usr/bin/env python -from setuptools import setup, find_packages +import setuptools try: # for pip >= 10 from pip._internal.req import parse_requirements as parse except ImportError: # for pip <= 9.0.3 @@ -7,13 +7,17 @@ except ImportError: # for pip <= 9.0.3 requirements = lambda f: [str(i.req) for i in parse(f, session=False)] -setup( +setuptools.setup( name='PyNFe', version='0.4', - packages=find_packages(), + author='TadaSoftware', + author_email='tadasoftware@gmail.com', + url='https://github.com/TadaSoftware', + packages=setuptools.find_packages(), package_data={ 'pynfe': ['data/**/*.txt'], }, install_requires=requirements('requirements.txt'), zip_safe=False, + python_requires='>=3.6', ) From e9f20a6b1c2711ff5d3d1d9fc14fe65c0df8c6b3 Mon Sep 17 00:00:00 2001 From: juniortada Date: Wed, 11 Sep 2019 19:30:16 -0300 Subject: [PATCH 4/9] [fix] atualizado SVAN apenas MA e SVRS NFC-e MA --- pynfe/processamento/comunicacao.py | 11 +++++++---- 1 file changed, 7 insertions(+), 4 deletions(-) diff --git a/pynfe/processamento/comunicacao.py b/pynfe/processamento/comunicacao.py index 5b915ea..1232ce3 100644 --- a/pynfe/processamento/comunicacao.py +++ b/pynfe/processamento/comunicacao.py @@ -358,8 +358,7 @@ class ComunicacaoSefaz(Comunicacao): raise Exception('Modelo não encontrado! Defina modelo="nfe" ou "nfce"') # Estados que utilizam outros ambientes else: - lista_svrs = ['AC', 'RJ', 'RN', 'PB', 'SC', 'SE', 'PI', 'DF', 'ES'] - lista_svan = ['MA','PA'] + lista_svrs = ['AC', 'RJ', 'RN', 'PB', 'SC', 'SE', 'PI', 'DF', 'ES', 'PA'] if self.uf.upper() in lista_svrs: if self._ambiente == 1: ambiente = 'HTTPS' @@ -373,7 +372,9 @@ class ComunicacaoSefaz(Comunicacao): self.url = NFCE['SVRS'][ambiente] + NFCE['SVRS'][consulta] else: raise Exception('Modelo não encontrado! Defina modelo="nfe" ou "nfce"') - elif self.uf.upper() in lista_svan: + # unico UF que utiliza SVAN ainda para NF-e + # SVRS para NFC-e + elif self.uf.upper() == 'MA': if self._ambiente == 1: ambiente = 'HTTPS' else: @@ -383,9 +384,11 @@ class ComunicacaoSefaz(Comunicacao): self.url = NFE['SVAN'][ambiente] + NFE['SVAN'][consulta] elif modelo == 'nfce': # nfce Ex: https://homologacao.nfce.fazenda.pr.gov.br/nfce/NFeStatusServico3 - self.url = NFCE['SVAN'][ambiente] + NFCE['SVAN'][consulta] + self.url = NFCE['SVRS'][ambiente] + NFCE['SVRS'][consulta] else: raise Exception('Modelo não encontrado! Defina modelo="nfe" ou "nfce"') + else: + raise Exception(f"Url não encontrada para {modelo} e {consulta} {self.uf.upper()}") return self.url def _construir_xml_soap(self, metodo, dados, cabecalho=False): From c1abb35bb7188c1f07c2e260d1e5b35212eb6ebf Mon Sep 17 00:00:00 2001 From: Junior Tada Date: Tue, 24 Sep 2019 17:10:42 -0300 Subject: [PATCH 5/9] =?UTF-8?q?[new]=20add=20cBenef=20(c=C3=B3digo=20de=20?= =?UTF-8?q?benef=C3=ADcio=20fiscal=20na=20UF)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- pynfe/entidades/produto.py | 2 ++ pynfe/processamento/serializacao.py | 5 ++++- 2 files changed, 6 insertions(+), 1 deletion(-) diff --git a/pynfe/entidades/produto.py b/pynfe/entidades/produto.py index 21e3cfb..6d06e96 100644 --- a/pynfe/entidades/produto.py +++ b/pynfe/entidades/produto.py @@ -34,6 +34,8 @@ class Produto(Entidade): # Tabela https://www.confaz.fazenda.gov.br/anexo-i.pdf cest = str() + cbenef = str() + # - Unid. Com. unidade_comercial = str() diff --git a/pynfe/processamento/serializacao.py b/pynfe/processamento/serializacao.py index 6cbec9b..559a691 100644 --- a/pynfe/processamento/serializacao.py +++ b/pynfe/processamento/serializacao.py @@ -222,7 +222,10 @@ class SerializacaoXML(Serializacao): etree.SubElement(prod, 'NCM').text = produto_servico.ncm # Codificação opcional que detalha alguns NCM. Formato: duas letras maiúsculas e 4 algarismos. # Se a mercadoria se enquadrar em mais de uma codificação, informar até 8 codificações principais. - #etree.SubElement(prod, 'NVE').text = '' + # etree.SubElement(prod, 'NVE').text = '' + # etree.SubElement(prod, 'CEST').text = produto_service.cest + if produto_servico.cbenef: + etree.SubElement(prod, 'cBenef').text = produto_servico.cbenef etree.SubElement(prod, 'CFOP').text = produto_servico.cfop etree.SubElement(prod, 'uCom').text = produto_servico.unidade_comercial etree.SubElement(prod, 'qCom').text = str(produto_servico.quantidade_comercial or 0) From 8740ca8323a733e1e34351523197f97507d01ad6 Mon Sep 17 00:00:00 2001 From: Junior Tada Date: Wed, 23 Oct 2019 15:01:00 -0300 Subject: [PATCH 6/9] [fix] corrige url consulta cadastro SVRS --- pynfe/utils/webservices.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pynfe/utils/webservices.py b/pynfe/utils/webservices.py index 51dc74b..847ba3f 100644 --- a/pynfe/utils/webservices.py +++ b/pynfe/utils/webservices.py @@ -446,7 +446,7 @@ NFE = { 'CHAVE': 'svrs.rs.gov.br/ws/NfeConsulta/NfeConsulta4.asmx', 'INUTILIZACAO': 'svrs.rs.gov.br/ws/nfeinutilizacao/nfeinutilizacao4.asmx', 'EVENTOS': 'svrs.rs.gov.br/ws/recepcaoevento/recepcaoevento4.asmx', - 'CADASTRO': 'https://cad.svrs.rs.gov.br/ws/cadconsultacadastro/cadconsultacadastro2.asmx', + 'CADASTRO': 'https://cad.svrs.rs.gov.br/ws/cadconsultacadastro/cadconsultacadastro4.asmx', 'HTTPS': 'https://nfe.', 'HOMOLOGACAO': 'https://nfe-homologacao.' }, From 8c9273a603419829c0b9a5ac4d13c2c7030c4095 Mon Sep 17 00:00:00 2001 From: juniortada Date: Thu, 24 Oct 2019 14:00:55 -0300 Subject: [PATCH 7/9] [fix] corrigido url consulta cadastro PE --- pynfe/utils/webservices.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pynfe/utils/webservices.py b/pynfe/utils/webservices.py index 847ba3f..6eb373d 100644 --- a/pynfe/utils/webservices.py +++ b/pynfe/utils/webservices.py @@ -333,7 +333,7 @@ NFE = { 'CHAVE': 'sefaz.pe.gov.br/nfe-service/services/NFeConsultaProtocolo4', 'INUTILIZACAO': 'sefaz.pe.gov.br/nfe-service/services/NFeInutilizacao4', 'EVENTOS': 'sefaz.pe.gov.br/nfe-service/services/NFeRecepcaoEvento4', - # 'CADASTRO': 'sefaz.pe.gov.br/nfe-service/services/CadConsultaCadastro2', + 'CADASTRO': 'sefaz.pe.gov.br/nfe-service/services/CadConsultaCadastro4?wsdl', 'HTTPS': 'https://nfe.', 'HOMOLOGACAO': 'https://nfehomolog.' }, From ed8335bb76874de6e23f42e152c18a012f29e348 Mon Sep 17 00:00:00 2001 From: juniortada Date: Thu, 24 Oct 2019 14:07:33 -0300 Subject: [PATCH 8/9] [fix] corrigido url consulta cadastro CE --- pynfe/utils/webservices.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pynfe/utils/webservices.py b/pynfe/utils/webservices.py index 6eb373d..49c6029 100644 --- a/pynfe/utils/webservices.py +++ b/pynfe/utils/webservices.py @@ -321,7 +321,7 @@ NFE = { 'CHAVE': 'sefaz.ce.gov.br/nfe4/services/NFeConsultaProtocolo4?WSDL', 'INUTILIZACAO': 'sefaz.ce.gov.br/nfe4/services/NFeInutilizacao4?WSDL', 'EVENTOS': 'sefaz.ce.gov.br/nfe4/services/NFeRecepcaoEvento4?WSDL', - 'CADASTRO': 'nfe.sefaz.ce.gov.br/nfe4/services/CadConsultaCadastro4?wsdl', + 'CADASTRO': 'sefaz.ce.gov.br/nfe4/services/CadConsultaCadastro4?wsdl', 'DOWNLOAD': 'sefaz.ce.gov.br/nfe2/services/NfeDownloadNF?wsdl', 'HTTPS': 'https://nfe.', 'HOMOLOGACAO': 'https://nfeh.' From 420e8f72b2e2682cb997dd69331bf235b907e35e Mon Sep 17 00:00:00 2001 From: juniortada Date: Thu, 24 Oct 2019 14:21:08 -0300 Subject: [PATCH 9/9] [fix] atualizado lista de SVRS --- pynfe/processamento/comunicacao.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/pynfe/processamento/comunicacao.py b/pynfe/processamento/comunicacao.py index 1232ce3..2a9bd41 100644 --- a/pynfe/processamento/comunicacao.py +++ b/pynfe/processamento/comunicacao.py @@ -200,7 +200,7 @@ class ComunicacaoSefaz(Comunicacao): :return: """ # UF que utilizam a SVRS - Sefaz Virtual do RS: Para serviço de Consulta Cadastro: AC, RN, PB, SC - lista_svrs = ['AC', 'RJ', 'RN', 'PB', 'SC', 'PI'] + lista_svrs = ['AC', 'RN', 'PB', 'SC'] # RS implementa um método diferente na consulta de cadastro if self.uf.upper() == 'RS': @@ -358,7 +358,7 @@ class ComunicacaoSefaz(Comunicacao): raise Exception('Modelo não encontrado! Defina modelo="nfe" ou "nfce"') # Estados que utilizam outros ambientes else: - lista_svrs = ['AC', 'RJ', 'RN', 'PB', 'SC', 'SE', 'PI', 'DF', 'ES', 'PA'] + lista_svrs = ['AC', 'AL', 'AP', 'DF', 'ES', 'PB', 'PI', 'RJ', 'RN', 'RO', 'RR', 'SC', 'SE', 'TO'] if self.uf.upper() in lista_svrs: if self._ambiente == 1: ambiente = 'HTTPS'