rNFe_ConsultarPorIdentificador

Realiza uma consulta de NF-e no servidor do NFePack por um identificador

Método

int CALL rNFe_ConsultarPorIdentificador(emissor_nfce* e, const char* identificador, char* chave, char* situacaoOperacao, char* status, char* protocolo, char* digval, char* codigoErro, char* descricaoErro, char* deveReabrirVenda, const char* reservado1, const char* reservado2, const char* reservado3, const char* reservado4, const char* reservado5);

Parâmetros

Nome Descrição
e
Handle para o emissor_nfe
identificador
Identificador a ser consultado.
chave
O Buffer que receberá a chave da NF-e (44 Caracteres).
situacaoOperacao
O Buffer que receberá a Situação da Operação da NF-e
1 - Sucesso
2 - Erro
3 - Denegada
4 - Sem Valor - Cancelada ou Inutilizda
5 - Não Localizada
6 - Em Processamento
(2 Caracteres máx.).
status
O Buffer que receberá o status da NF-e contido no servidor do NFePack (2 Caracteres máx.)
protocolo
O Buffer que receberá o protocolo da NF-e (30 Caracteres máx.)
digval
O Buffer que receberá o DigVal da NF-e (28 Caracteres máx.)
codigoErro
O Buffer que contém a código do erro. (5 Caracteres máx.)
descricaoErro
O Buffer que contém a descrição da rejeição, quando a NF-e está rejeitada. (513 Caracteres máx.)
deveReabrirVenda
O Buffer que contém a indicação se deve reabrir a venda usando o método eNFe_ReabrirVenda (0: Não deve, 1; Deve)
reservado1
Reservado para uso futuro
reservado2
Reservado para uso futuro
reservado3
Reservado para uso futuro
reservado4
Reservado para uso futuro
reservado5
Reservado para uso futuro

Retornos

Codigo Descrição
1 OK
10311 Erro inesperado ao consultar a nota.
10315 Problema na comunicação com o servidor. (Uma reconsulta pode resolver o problema)
10205 Erro ao processar resposta do web service de integracação. (versões do agente e retaguarda incompatíveis pode ocasionar este problema)
10318 Falha na rotina da retaguarda (parâmetros de erro serão preenchidos com o erro da retaguarda)

Exemplos

char[] chave = new char[44+1];
char[] situacaoOperacao = new char[2+1];
char[] status = new char[2+1];
char[] protocolo = new char[15+1];
char[] digVal = new char[28+1];
char[] codigoErro = new char[5+1];
char[] descricaoErro = new char[512+1];
char[] deveReabrirVenda = new char[1+1];
int retorno = rNFe_ConsultarPorIdentificador(handleEmissor,
                                             identificador,
                                             chave,
                                             situacaoOperacao,
                                             status,
                                             protocolo,
                                             digVal,
                                             codigoErro,
                                             descricaoErro,
                                             deveReabrirVenda,
                                             "", "", "", "", "");
//chave terá o valor "13141275587915020765650030000000051550351537"
//situacaoOperacao terá o valor "1"
//status terá o valor "6"
//protocolo terá o valor "113140003271818"
//digVal terá o valor "TS0tq6wlCpixyYknPEPqG4Cutas="
//codigoErro terá o valor ""
//descricaoErro terá o valor ""
//deveReabrirVenda terá o valor "0"

//-------------Exemplo com tratamentos-------------
int numeroDeTentativas = 3;
int retorno = 0;
for(int i = 0; i < numeroDeTentativas; i++) {
    retorno = rNFe_ConsultarPorIdentificador(handleEmissor,
                                             "ID_10",
                                             chave,
                                             situacaoOperacao,
                                             status,
                                             protocolo,
                                             digVal,
                                             urlConsulta,
                                             codigoErro,
                                             descricaoErro,
                                             deveReabrirVenda,
                                             "", "", "", "");
    if(retorno == 1) break;
    sleep(2);
}
if(retorno == 1) {
    tratar_resposta();
    //se não encontrar a chave da nota para o identificador o retorno é '1' e a situacaoOperacao é '5'
}
else {
    tratar_quando_nao_consegue_consultar();
}