public override void Execute() { try { int emp = Empresas.FindEmpresaByThread(); DadosNFeClass oDadosNfe = LerXMLNFe(ConteudoXML); AssinarValidarXMLNFe(ConteudoXML); //Montar lote de nfe FluxoNfe oFluxoNfe = new FluxoNfe(); string cError = ""; try { if (!oFluxoNfe.NFeComLote(oDadosNfe.chavenfe)) { XmlDocument xmlLote = LoteNfe(ConteudoXML, NomeArquivoXML, oDadosNfe.versao); TaskNFeRecepcao nfeRecepcao = new TaskNFeRecepcao(xmlLote); nfeRecepcao.Execute(); } } catch (IOException ex) { cError = (ex.InnerException != null ? ex.InnerException.Message : ex.Message); } catch (Exception ex) { cError = (ex.InnerException != null ? ex.InnerException.Message : ex.Message); } if (!string.IsNullOrEmpty(cError)) { try { // grava o arquivo de erro oAux.GravarArqErroERP(Path.GetFileNameWithoutExtension(NomeArquivoXML) + ".err", cError); // move o arquivo para a pasta de erro oAux.MoveArqErro(NomeArquivoXML); } catch { // A principio não vou fazer nada Wandrey 24/04/2011 } } } catch { } }
public override void Execute() { int emp = Empresas.FindEmpresaByThread(); List <string> arquivosNFe = new List <string>(); //Aguardar a assinatura de todos os arquivos da pasta de lotes arquivosNFe = oAux.ArquivosPasta(Empresas.Configuracoes[emp].PastaXmlEmLote, "*" + Propriedade.Extensao(Propriedade.TipoEnvio.NFe).EnvioXML); if (arquivosNFe.Count == 0) { if (NomeArquivoXML.IndexOf(Propriedade.Extensao(Propriedade.TipoEnvio.MontarLote).EnvioTXT) >= 0) { try { StringBuilder xml = new StringBuilder(); xml.Append("<?xml version=\"1.0\" encoding=\"UTF-8\"?>"); xml.Append("<MontarLoteNFe>"); foreach (var filename in File.ReadAllLines(NomeArquivoXML, Encoding.Default)) { xml.AppendFormat("<ArquivoNFe>{0}</ArquivoNFe>", filename + (filename.ToLower().EndsWith(Propriedade.Extensao(Propriedade.TipoEnvio.NFe).EnvioXML) ? "" : Propriedade.Extensao(Propriedade.TipoEnvio.NFe).EnvioXML)); } xml.Append("</MontarLoteNFe>"); File.WriteAllText(Path.Combine(Empresas.Configuracoes[emp].PastaXmlEmLote, Path.GetFileName(NomeArquivoXML.Replace(Propriedade.Extensao(Propriedade.TipoEnvio.MontarLote).EnvioTXT, Propriedade.Extensao(Propriedade.TipoEnvio.MontarLote).EnvioXML))), xml.ToString()); //Deletar o arquivo de solicitação de montagem do lote de NFe FileInfo oArquivo = new FileInfo(NomeArquivoXML); oArquivo.Delete(); } catch (Exception ex) { try { TFunctions.GravarArqErroServico(NomeArquivoXML, Propriedade.Extensao(Propriedade.TipoEnvio.MontarLote).EnvioTXT, Propriedade.ExtRetorno.MontarLote_ERR, ex); } catch { //Se deu algum erro na hora de gravar o arquivo de erro de retorno para o ERP, infelizmente não poderemos fazer nada //pois deve estar ocorrendo alguma falha de rede, hd, permissão de acesso a pasta ou arquivos, etc. Wandrey 22/03/2010 //TODO: Não poderia gravar algum LOG para análise? Erro de rede normalmente é erro de IO } } } else { List <ArquivoXMLDFe> notas = new List <ArquivoXMLDFe>(); FileStream fsArquivo = null; FluxoNfe fluxoNfe = new FluxoNfe(); try { try { XmlDocument doc = new XmlDocument(); //Criar instância do XmlDocument Class fsArquivo = new FileStream(NomeArquivoXML, FileMode.Open, FileAccess.Read, FileShare.ReadWrite); //Abrir um arquivo XML usando FileStream doc.Load(fsArquivo); //Carregar o arquivo aberto no XmlDocument string versaoXml = string.Empty; XmlNodeList documentoList = doc.GetElementsByTagName("MontarLoteNFe"); //Pesquisar o elemento Documento no arquivo XML foreach (XmlNode documentoNode in documentoList) { XmlElement documentoElemento = (XmlElement)documentoNode; int QtdeArquivo = documentoElemento.GetElementsByTagName("ArquivoNFe").Count; for (int d = 0; d < QtdeArquivo; d++) { string arquivoNFe = Empresas.Configuracoes[emp].PastaXmlEmLote + "\\temp\\" + documentoElemento.GetElementsByTagName("ArquivoNFe")[d].InnerText; if (File.Exists(arquivoNFe)) { XmlDocument conteudoXMLNFe = new XmlDocument(); conteudoXMLNFe.Load(arquivoNFe); DadosNFeClass oDadosNfe = LerXMLNFe(conteudoXMLNFe); if (string.IsNullOrEmpty(versaoXml)) { versaoXml = oDadosNfe.versao; } if (!fluxoNfe.NFeComLote(oDadosNfe.chavenfe)) { notas.Add(new ArquivoXMLDFe() { NomeArquivoXML = arquivoNFe, ConteudoXML = conteudoXMLNFe }); } else { throw new Exception("Arquivo: " + arquivoNFe + " já está no fluxo de envio e não será incluido em novo lote."); } } else { throw new Exception("Arquivo: " + arquivoNFe + " não existe e não será incluido no lote!"); } } } fsArquivo.Close(); XmlDocument xmlLote = LoteNfe(notas, versaoXml); TaskNFeRecepcao nfeRecepcao = new TaskNFeRecepcao(xmlLote); nfeRecepcao.Execute(); } catch { if (fsArquivo != null) { fsArquivo.Close(); } } //Deletar o arquivo de solicitão de montagem do lote de NFe FileInfo oArquivo = new FileInfo(NomeArquivoXML); oArquivo.Delete(); } catch (Exception ex) { try { TFunctions.GravarArqErroServico(NomeArquivoXML, Propriedade.Extensao(Propriedade.TipoEnvio.MontarLote).EnvioXML, Propriedade.ExtRetorno.MontarLote_ERR, ex); } catch { //Se deu algum erro na hora de gravar o arquivo de erro de retorno para o ERP, infelizmente não poderemos fazer nada //pois deve estar ocorrendo alguma falha de rede, hd, permissão de acesso a pasta ou arquivos, etc. Wandrey 22/03/2010 //TODO: Não poderia gravar algum LOG para análise? Erro de rede normalmente é erro de IO } } } } }