Páginas filhas
  • DSERTSS3-2479 - [F.B.E] - Transmissão de documento

Versões comparadas

Chave

  • Esta linha foi adicionada.
  • Esta linha foi removida.
  • A formatação mudou.

01. DADOS GERAIS

Produto:

TOTVS Transmite

Linha de Produto:

Linha Protheus

Segmento:

Backoffice

Módulo:TOTVS Transmite
Função:Não Há
País:Brasil
Ticket:Não Há
Requisito/Story/Issue (informe o requisito relacionado) :DSERTSS3-2479

02. SITUAÇÃO/REQUISITO

Desenvolver mecanismo que possibilite ao TOTVS Transmite receber e realizar a transmissão (apenas em regime normal, contingência e EPEC serão realizadas a posteriori) de NF-e's. Essa construção deverá respeitar a seguinte arquitetura:

...

Bloco de código
languagejava
titleModelo Mensagem Transmissão
linenumberstrue
{
    "codigoFilial": "00ABDF58597BD69632540F3B0471F52E1838D7AD",
    "modelo": "NFe",
    "tipoTransmissao": "Emissao",
    "dados":  [
            "<?xml version="1.0" encoding="UTF-8"?><NFe xmlns="http://www.portalfiscal.inf.br/nfe"><infNFe versao="4.00" Id="NFe35220453113791000122557010000020271004545555"><ide><cUF>35</cUF><cNF>00454555</cNF><natOp>ICMS</natOp><mod>55</mod><serie>701</serie><nNF>2027</nNF><dhEmi>2022-04-04T11:32:00-03:00</dhEmi><tpNF>1</tpNF><idDest>2</idDest><cMunFG>3550308</cMunFG><tpImp>1</tpImp><tpEmis>1</tpEmis><cDV>5</cDV><tpAmb>2</tpAmb><finNFe>1</finNFe><indFinal>0</indFinal><indPres>1</indPres><procEmi>0</procEmi><verProc>12.1.025 | 3.0</verProc></ide><emit><CNPJ>53113791000122</CNPJ><xNome>TOTVS S.A</xNome><xFant>TESTE</xFant><enderEmit><xLgr>Avenida Braz Leme</xLgr><nro>1717</nro><xCpl>fundos</xCpl><xBairro>Santana</xBairro><cMun>3550308</cMun><xMun>SAO PAULO</xMun><UF>SP</UF><CEP>01250000</CEP><cPais>1058</cPais><xPais>BRASIL</xPais><fone>551123456789</fone></enderEmit><IE>111010945111</IE><CRT>3</CRT></emit><dest><CNPJ>01105481000162</CNPJ><xNome>NF-E EMITIDA EM AMBIENTE DE HOMOLOGACAO - SEM VALOR FISCAL</xNome><enderDest><xLgr>RUA PEDRO DE TOLEDO</xLgr><nro>155</nro><xBairro>CENTRO</xBairro><cMun>3100609</cMun><xMun>AGUA BOA</xMun><UF>MG</UF><CEP>02140000</CEP><cPais>1058</cPais><xPais>BRASIL</xPais><fone>1125901010</fone></enderDest><indIEDest>1</indIEDest><IE>4809634250038</IE><email>clipjspcont@testes.com.br</email></dest><det nItem="1"><prod><cProd>90000000000001</cProd><cEAN>3534561234569</cEAN><xProd>PNEU 130 TRASEIRO</xProd><NCM>44170010</NCM><CEST>0100700</CEST><cBenef></cBenef><CFOP>6101</CFOP><uCom>PC</uCom><qCom>1.0000</qCom><vUnCom>100.00000000</vUnCom><vProd>100.00</vProd><cEANTrib>3534561234569</cEANTrib><uTrib>PC</uTrib><qTrib>1.0000</qTrib><vUnTrib>100.00000000</vUnTrib><indTot>1</indTot></prod><imposto><ICMS><ICMS00><orig>0</orig><CST>00</CST><modBC>3</modBC><vBC>0</vBC><pICMS>0</pICMS><vICMS>0</vICMS></ICMS00></ICMS><IPI><cEnq>999</cEnq><IPINT><CST>53</CST></IPINT></IPI><PIS><PISNT><CST>08</CST></PISNT></PIS><COFINS><COFINSNT><CST>08</CST></COFINSNT></COFINS></imposto></det><total><ICMSTot><vBC>0</vBC><vICMS>0</vICMS><vICMSDeson>0</vICMSDeson><vFCPUFDest>0</vFCPUFDest><vICMSUFDest>0</vICMSUFDest><vICMSUFRemet>0</vICMSUFRemet><vFCP>0</vFCP><vBCST>0</vBCST><vST>0</vST><vFCPST>0</vFCPST><vFCPSTRet>0</vFCPSTRet><vProd>100.00</vProd><vFrete>0</vFrete><vSeg>0</vSeg><vDesc>0</vDesc><vII>0</vII><vIPI>0</vIPI><vIPIDevol>0</vIPIDevol><vPIS>0</vPIS><vCOFINS>0</vCOFINS><vOutro>0</vOutro><vNF>100.00</vNF></ICMSTot></total><transp><modFrete>1</modFrete></transp><cobr><fat><nFat>701000002027</nFat><vOrig>100.00</vOrig><vDesc>0</vDesc><vLiq>100.00</vLiq></fat><dup><nDup>001</nDup><dVenc>2022-04-04</dVenc><vDup>100.00</vDup></dup></cobr><pag><detPag><indPag>0</indPag><tPag>15</tPag><vPag>100.00</vPag></detPag></pag><infAdic><infCpl>O marcio nao sabe o que fala  Nota fiscal emitida sem destaque do ICMS.</infCpl></infAdic><infRespTec><CNPJ>53113791000122</CNPJ><xContato>Rodrigo de Almeida Sartorio</xContato><email>resp_tecnico_dfe_protheus@totvs.com.br</email><fone>1128593904</fone></infRespTec></infNFe></NFe><?xml version="1.0" encoding="UTF-8"?>
<NFe xmlns="http://www.portalfiscal.inf.br/nfe">
	<infNFe versao="4.00" Id="NFe35220453113791000122557010000020271004545555">
		<ide>
			<cUF>35</cUF>
			<cNF>00454555</cNF>
			<natOp>ICMS</natOp>
			<mod>55</mod>
			<serie>701</serie>
			<nNF>2027</nNF>
			<dhEmi>2022-04-04T11:32:00-03:00</dhEmi>
			<tpNF>1</tpNF>
			<idDest>2</idDest>
			<cMunFG>3550308</cMunFG>
			<tpImp>1</tpImp>
			<tpEmis>1</tpEmis>
			<cDV>5</cDV>
			<tpAmb>2</tpAmb>
			<finNFe>1</finNFe>
			<indFinal>0</indFinal>
			<indPres>1</indPres>
			<procEmi>0</procEmi>
			<verProc>12.1.025 | 3.0</verProc>
		</ide>
		<emit>
			<CNPJ>53113791000122</CNPJ>
			<xNome>TOTVS S.A</xNome>
			<xFant>TESTE</xFant>
			<enderEmit>
				<xLgr>Avenida Braz Leme</xLgr>
				<nro>1717</nro>
				<xCpl>fundos</xCpl>
				<xBairro>Santana</xBairro>
				<cMun>3550308</cMun>
				<xMun>SAO PAULO</xMun>
				<UF>SP</UF>
				<CEP>01250000</CEP>
				<cPais>1058</cPais>
				<xPais>BRASIL</xPais>
				<fone>551123456789</fone>
			</enderEmit>
			<IE>111010945111</IE>
			<CRT>3</CRT>
		</emit>
		<dest>
			<CNPJ>01105481000162</CNPJ>
			<xNome>NF-E EMITIDA EM AMBIENTE DE HOMOLOGACAO - SEM VALOR FISCAL</xNome>
			<enderDest>
				<xLgr>RUA PEDRO DE TOLEDO</xLgr>
				<nro>155</nro>
				<xBairro>CENTRO</xBairro>
				<cMun>3100609</cMun>
				<xMun>AGUA BOA</xMun>
				<UF>MG</UF>
				<CEP>02140000</CEP>
				<cPais>1058</cPais>
				<xPais>BRASIL</xPais>
				<fone>1125901010</fone>
			</enderDest>
			<indIEDest>1</indIEDest>
			<IE>4809634250038</IE>
			<email>clipjspcont@testes.com.br</email>
		</dest>
		<det nItem="1">
			<prod>
				<cProd>90000000000001</cProd>
				<cEAN>3534561234569</cEAN>
				<xProd>PNEU 130 TRASEIRO</xProd>
				<NCM>44170010</NCM>
				<CEST>0100700</CEST>
				<cBenef/>
				<CFOP>6101</CFOP>
				<uCom>PC</uCom>
				<qCom>1.0000</qCom>
				<vUnCom>100.00000000</vUnCom>
				<vProd>100.00</vProd>
				<cEANTrib>3534561234569</cEANTrib>
				<uTrib>PC</uTrib>
				<qTrib>1.0000</qTrib>
				<vUnTrib>100.00000000</vUnTrib>
				<indTot>1</indTot>
			</prod>
			<imposto>
				<ICMS>
					<ICMS00>
						<orig>0</orig>
						<CST>00</CST>
						<modBC>3</modBC>
						<vBC>0</vBC>
						<pICMS>0</pICMS>
						<vICMS>0</vICMS>
					</ICMS00>
				</ICMS>
				<IPI>
					<cEnq>999</cEnq>
					<IPINT>
						<CST>53</CST>
					</IPINT>
				</IPI>
				<PIS>
					<PISNT>
						<CST>08</CST>
					</PISNT>
				</PIS>
				<COFINS>
					<COFINSNT>
						<CST>08</CST>
					</COFINSNT>
				</COFINS>
			</imposto>
		</det>
		<total>
			<ICMSTot>
				<vBC>0</vBC>
				<vICMS>0</vICMS>
				<vICMSDeson>0</vICMSDeson>
				<vFCPUFDest>0</vFCPUFDest>
				<vICMSUFDest>0</vICMSUFDest>
				<vICMSUFRemet>0</vICMSUFRemet>
				<vFCP>0</vFCP>
				<vBCST>0</vBCST>
				<vST>0</vST>
				<vFCPST>0</vFCPST>
				<vFCPSTRet>0</vFCPSTRet>
				<vProd>100.00</vProd>
				<vFrete>0</vFrete>
				<vSeg>0</vSeg>
				<vDesc>0</vDesc>
				<vII>0</vII>
				<vIPI>0</vIPI>
				<vIPIDevol>0</vIPIDevol>
				<vPIS>0</vPIS>
				<vCOFINS>0</vCOFINS>
				<vOutro>0</vOutro>
				<vNF>100.00</vNF>
			</ICMSTot>
		</total>
		<transp>
			<modFrete>1</modFrete>
		</transp>
		<cobr>
			<fat>
				<nFat>701000002027</nFat>
				<vOrig>100.00</vOrig>
				<vDesc>0</vDesc>
				<vLiq>100.00</vLiq>
			</fat>
			<dup>
				<nDup>001</nDup>
				<dVenc>2022-04-04</dVenc>
				<vDup>100.00</vDup>
			</dup>
		</cobr>
		<pag>
			<detPag>
				<indPag>0</indPag>
				<tPag>15</tPag>
				<vPag>100.00</vPag>
			</detPag>
		</pag>
		<infAdic>
			<infCpl>TESTE COMPLEMENTAR</infCpl>
		</infAdic>
		<infRespTec>
			<CNPJ>53113791000122</CNPJ>
			<xContato>Rodrigo de Almeida Sartorio</xContato>
			<email>resp_tecnico_dfe_protheus@totvs.com.br</email>
			<fone>1128593904</fone>
		</infRespTec>
	</infNFe>
</NFe>"
        ]
}

 

  • Utilizar a ferramenta Postman (ou similares), com a mensagem para simular um ERP encaminhando documento(s) para transmissão;
  • Encaminhar a mensagem para o Endpoint: '{urlBase}/api/v2.0/edi' (POST), localizado no serviço edi-api;
  • Utilizar o Token do RAC/TNF para autenticação das requisições.
     

...

  • Criar e expor o Endpoint: '{urlBase}/api/v2.0/edi' para recebimento das mensagens de transmissão (POST):
    • Decorar a API com o [TNFAuthorize], de forma que a autenticação seja gerenciada pelo RAC/TNF;
    • Encaminhar mensagem para Fila de Recebimento de acordo com o modelo de documento (exemplo: eTransmissaoNFeRecebimento-Queue).
  • Criar e expor o Endpoint: '{urlBase}/api/v2.0/edi/{idReciborecibo}' para consulta do andamento do processo de transmissão:
    • Devolver a resposta para o ERP, utilizando o serviço TaskServiceResponse (método Publish), presente no transmit-framework.
       

...

  • Criar estrutura do novo projeto na Azure Devops;
  • Fluxo de recepção e transmissão irá realizar as seguintes etapasseguintes etapas:
    • Validar os documentos de acordo com o esquema XSD (fornecido pela SEFAZ);
    • Assinar os documentos validados (rejeitados na validação já ficarão salvos em base de dados com este status);
    • Transmitir os documentos validados e assinados para SEFAZ;
    • Encaminhar recibo de transmissão para fila de consulta (em caso de rejeição, lote inteiro será atualizado em base de dados com este status);
  • A cada etapa, atualizar o andamento, utilizando o serviço TaskServiceResponse (método Update), a ser criado no transmit-framework.

...

  • Fluxo de consulta de resultado de transmissão irá realizar as seguintes etapas:
    • Realizar a consulta na SEFAZ pelo recibo recebido no ato da transmissão;
    • Persistir a resposta no andamento, utilizando o serviço TaskServiceResponse (método Update), a ser criado no transmit-framework.;
    • Se o lote foi processado com sucesso na SEFAZ, persiste atualiza os documentos na collection de NF-e emitidas
    OBS: Caso exista algum documento invalido no lote, rejeitar todo lote
    • coleção 'nfe';
      • Reaproveitar o código referente aos índices das coleções;
    • Enquanto a SEFAZ
    nao
    • não disponibiliza o resultado da consulta
    , reenfileirar a mensagem
  • Reaproveitar o codigo referente aos índices das collections

03. SOLUÇÃO

    • , enfileirar a mensagem para nova tentativa.

03. SOLUÇÃO

A solução proposta segue a arquitetura descrita acima, tendo sido realizado os passos a seguir:

1-SIMULADOR DE ERP

  • Criação de requisição no Postman, para envio de transmissão, com mensagem acordada (POST);
  • Criação de requisição no Postman, para consulta do recibo retornado pela requisição anterior (GET);
  • Criação de requisição no Postman, para validar se API (v2.0) está no ar (GET).

2-EDI-API

  • Criação de EdiController (v2.0), onde foram inseridos os novos endpoints;
  • Criação de endpoint '{urlBase}/api/v2.0/edi' (que atende o método POST), que recebe a requisição de transmissão e insere a mesma na fila de transmissão (eTransmissaoNFeRecebimento-Queue);
  • Criação de endpoint '{urlBase}/api/v2.0/edi/{recibo}' (que atende o método GET), que retorna andamento da transmissão, dado o recibo;
  • Criação de endpoint '{urlBase}/api/v2.0/edi' (que atende o método GET), que valida se API está disponível e funcional.

3-NFE-WORKER

  • Criação de estrutura inicial do projeto e disponibilização dele na Azure Devops, inclusive com a inclusão deste nos pipelines de CI/CD;
  • Criação de coleção 'controlelote', hospedada na base do cliente solicitante da transmissão, para controle de ID enviado para a SEFAZ, como identificador deste;
  • Criação da coleção 'sefazservice', hospedada na base 'transmite', para hospedar URLs, templates e schemas utilizados pelos serviços de 'Autorizacao' e 'RetAutorizacao';
  • Criação de fluxo de recepção de requisição de transmissão (Background Service), que realiza os seguintes passos:
    • Obtenção de registro da coleção de 'sefazservice', referente a 'Autorizacao'; 
    • Validação de esquema XSD de todos os documentos que compõem o lote enviado, utilizando schemas do registro obtido da 'sefazservice':
      • Se documento validado, ele é inserido como recebido na base de dados;
      • Se documento não passa pela validação, ele é inserido como falha de schema;
      • Apenas documentos validados seguirão para a próxima etapa.
    • Assinatura de documentos validados (atualização de registros da base de dados para assinado);
    • Montagem de conteúdo compactado de envelope SOAP para envio a SEFAZ, com documentos assinados;
    • Envio de requisição a SEFAZ (URL do registro da 'sefazservice') e captura de retorno:
      • Se requisição foi rejeitada, atualiza documentos enviados para status rejeitado;
      • Se requisição foi recebida, atualiza documentos enviados para status transmitido;
        • Envia recibo para fila de consulta.
    • Todas as manipulações de envio e retorno de comunicação com a SEFAZ são tratadas com os templates presentes no registro da 'sefazservice';
    • Em todos os passos, acontece a atualização do andamento geral da requisição na coleção 'respostaAssincrona'.
  • Criação de fluxo de consulta de status da requisição de transmissão (Background Service), que realiza os seguintes passos:
    • Obtenção de registro da coleção de 'sefazservice', referente a 'RetAutorizacao';  
    • Montagem de requisição de consulta SOAP para envio a SEFAZ (URL do registro da 'sefazservice'), com recibo recebido pela atividade anterior (recepção e transmissão);
      • Se requisição retornar que solicitação ainda não foi processada, a mesma tarefa em andamento é adicionada novamente na fila de consulta com um intervalo de espera;
      • Se requisição retornar que solicitação foi processada:
        • Tratar retorno para separar status por documento que compõem o lote;
        • Atualizar documentos em coleção 'nfe' com status individual retornado da SEFAZ.
    • Todas as manipulações de envio e retorno de comunicação com a SEFAZ são tratadas com os templates presentes no registro da 'sefazservice';
    • Em todos os passos, acontece a atualização do andamento geral da requisição na coleção 'respostaAssincrona'

...

    • .

04. DEMAIS INFORMAÇÕES

  • Não Há.

05. ASSUNTOS RELACIONADOS

  • Não Há.