Fluxo - Cancelamento/Inutilização da NF-e
O cancelamento permite ao contribuinte anular uma nota fiscal que já foi autorizada, mas para a qual não houve circulação de mercadoria. Já a inutilização permite declarar que uma determinada numeração de nota não foi utilizada, garantindo que a SEFAZ não suspeite de fraude. Para ambos os casos temos o embasamento na legislação:
Cancelamento
Cláusula décima segunda Em prazo não superior a vinte e quatro horas, contado do momento em que foi concedida a Autorização de Uso da NF-e, de que trata o inciso III da cláusula sétima, o emitente poderá solicitar o cancelamento da respectiva NF-e, desde que não tenha havido a circulação da mercadoria ou a prestação de serviço e observadas as normas constantes na cláusula décima terceira.
Inutilização
Cláusula décima quarta O contribuinte deverá solicitar, mediante Pedido de Inutilização de Número da NF-e, até o 10 (décimo) dia do mês subsequente, a inutilização de números de NF-e não utilizados, na eventualidade de quebra de sequência da numeração da NF-e.
Aí surge a pergunta:
"Como sei qual devo utilizar? Tenho que mandar para APIs diferentes?"
Isso a InvoiSys simplifica para você!
Nossa API pode ser utilizada tanto para o cancelamento quanto para a inutilização do documento e mais, você não precisa mapear do seu lado quando deve ser um e quando deve ser outro.
Logo abaixo vamos descrever para você todo o fluxo para a emissão do cancelamento/inutilização.
APIs Essenciais 💡
Cancelamento NF-e por número e série: /api/nfe/cancelarnfecnpj
APIs Opcionais 🥈
Consulta do Documento por Chave de Acesso: /api/nfe/getbychavesSTD/{chave}
Obter o XML da NF-e: /api/nfe/obterxml
Etapas e APIs
Para detalharmos melhor a operação, a separamos em tópicos, porém você consegue ver o fluxo completo aqui 📝.
1) Emitindo o cancelamento/inutilização
Da mesma maneira que no Envio Normal da NF-e, também precisamos nos atentar para termos um token de acesso válido.
Tendo ele em mãos devemos então escolher qual API utilizaremos. Atualmente temos duas, a API - Cancelar NF-e por Id Estabelecimento e API - Cancelar NF-e por CNPJ Estabelecimento.
Depois de decidirmos qual API utilizaremos, devemos preparar o JSON com as informações e então realizar a chamada da API.
Ao receber a chamada, a InvoiSys verificará na SEFAZ se será necessário fazer a inutilização ou o cancelamento do documento. E será com base nessa resposta que o retorno chamada será elaborado.
2) Retorno da chamada
Conforme falamos no tópico anterior, o retorno da chamada da API variará de acordo com o status do documento na SEFAZ. É com base nesse retorno que entendemos o que deve ser feito após a emissão do mesmo.
Assim como no Envio Normal, nele existem algumas informações que podem ser interessantes você guardar, como a chaveDeAcesso
e, opcionalmente, o id
do documento criado em nossa base, pois são utilizados em outras APIs.
Com base no retorno podemos chegar a 3 cenários:
a) Cancelamento ou inutilização da NF-e (Sucesso); b) Rejeição no cancelamento; c) Exceção na comunicação com a SEFAZ
a) Cancelamento ou inutilização da NF-e (Sucesso)
São os dois cenários de sucesso na chamada da API. Para isso devemos observar:
Tags do bloco
acoes
: Retornofalse
.
A seguir vamos entender como analisar se foi um cancelamento ou uma inutilização.
Cancelamento
Para o identificarmos, podemos checar os seguintes blocos:
dadosDoDocumento:
codigoStatusSEFAZ
: Retorno101
;descricaoStatusSEFAZ
: RetornoCancelamento de NF-e homologado
.
status: key
: Retorno1
(ao consultar via chave);status: value
: Retornocancelado
(ao consultar via chave).
Veja no exemplo abaixo:
Inutilização
Já no caso de inutilização, veremos as seguintes informações:
dadosDoDocumento:
codigoStatusSEFAZ
: Retorno102
descricaoStatusSEFAZ
: RetornoInutilização de número homologado
.
status: key
: Retorno1
(ao consultar via chave);status: value
: Retornoinutilizado
(ao consultar via chave).
Veja no exemplo abaixo:
b) Rejeição no cancelamento
Caso o cancelamento seja enviado após o período de 24 horas, a SEFAZ poderá rejeitá-lo, sendo assim, o status da na nota se manterá como autorizado.
Quando isso ocorrer, em nosso retorno você verá o seguinte em nosso retorno:
acoes: corrigirDocumento
: Retornotrue
;dadosDoDocumento: erro
: Retornotrue
;excecao
: Retorno com string descrevendo a rejeição.
Você verificará que no exemplo acima o codigoStatusSEFAZ
permanece como 100
, pois entendemos que, mesmo com a rejeição no cancelamento, o status final da nota é de autorizado.
Minha nota passou do prazo! E agora?
Existem algumas maneiras de lidar com esse cenário, como, por exemplo, fazer uma solicitação formal para a SEFAZ da sua UF pedindo o cancelamento extemporâneo se esta disponibilizar.
Nós recomendamos que, quando isso acontecer, verifique com o departamento fiscal ou contabilidade sobre o que poderá ser feito.
c) Exceção na comunicação com a SEFAZ
Assim como falamos no Envio Normal, no cancelamento também podem haver exceções na comunicação com a SEFAZ.Quando isso ocorrer, você deverá observar a tag abaixo:
acoes: tentarNovamenteMaisTarde
: Retornotrue
.
O que posso fazer?
Tenha uma rotina que, dentro do período válido para o cancelamento (24 horas), seu software tente fazer envios em períodos espaçados de tempo. Dessa forma, nós evitamos tentar consumir os serviços da SEFAZ enquanto está intermitente
Terminamos esta etapa 😁. Para seguir, basta selecionar a card abaixo
Last updated
Was this helpful?