//public int NotasFiscalEntradaInsert(NFE _NFE) //{ // List<OracleParameter> lstParam = new List<OracleParameter>(); // lstParam.Add(new OracleParameter("XML_NFE", OracleDbType.Clob, _NFE.XML_NFE, ParameterDirection.Input)); // lstParam.Add(new OracleParameter("XML_AUT", OracleDbType.Clob, _NFE.XML_AUT, ParameterDirection.Input)); // lstParam.Add(new OracleParameter("XML_CANC", OracleDbType.Clob, _NFE.XML_CANC, ParameterDirection.Input)); // lstParam.Add(new OracleParameter("XML_DADOSADIC", OracleDbType.Clob, _NFE.XML_DADOSADIC, ParameterDirection.Input)); // lstParam.Add(new OracleParameter("IDE_SERIE", _NFE.IDE_SERIE)); // lstParam.Add(new OracleParameter("IDE_NNF", _NFE.IDE_NNF)); // lstParam.Add(new OracleParameter("IDE_DEMI", OracleDbType.Date, _NFE.IDE_DEMI, ParameterDirection.Input)); // lstParam.Add(new OracleParameter("EMIT_CNPJ", _NFE.EMIT_CNPJ)); // lstParam.Add(new OracleParameter("DEST_CNPJ", _NFE.DEST_CNPJ)); // lstParam.Add(new OracleParameter("DEST_CPF", _NFE.DEST_CPF)); // lstParam.Add(new OracleParameter("IDE_CUF", _NFE.IDE_CUF)); // lstParam.Add(new OracleParameter("IDE_MOD", _NFE.IDE_MOD)); // lstParam.Add(new OracleParameter("IDE_CNF", _NFE.IDE_CNF)); // lstParam.Add(new OracleParameter("EMIT_IE", _NFE.EMIT_IE)); // lstParam.Add(new OracleParameter("DEST_IE", _NFE.DEST_IE)); // lstParam.Add(new OracleParameter("DEST_ENDERDEST_UF", _NFE.DEST_ENDERDEST_UF)); // lstParam.Add(new OracleParameter("TOTAL_ICMSTOT_VBC", _NFE.TOTAL_ICMSTOT_VBC)); // lstParam.Add(new OracleParameter("TOTAL_ICMSTOT_VBCST", _NFE.TOTAL_ICMSTOT_VBCST)); // lstParam.Add(new OracleParameter("TOTAL_ICMSTOT_VPROD", _NFE.TOTAL_ICMSTOT_VPROD)); // lstParam.Add(new OracleParameter("TOTAL_ICMSTOT_VICMS", _NFE.TOTAL_ICMSTOT_VICMS)); // lstParam.Add(new OracleParameter("TOTAL_ICMSTOT_VST", _NFE.TOTAL_ICMSTOT_VST)); // lstParam.Add(new OracleParameter("TOTAL_ISSQNTOT_VBC", _NFE.TOTAL_ISSQNTOT_VBC)); // lstParam.Add(new OracleParameter("TRANSP_TRANSPORTA_CNPJ", _NFE.TRANSP_TRANSPORTA_CNPJ)); // lstParam.Add(new OracleParameter("TRANSP_IE", _NFE.TRANSP_IE)); // lstParam.Add(new OracleParameter("TRANSP_VEICTRANSP_PLACA", _NFE.TRANSP_VEICTRANSP_PLACA)); // lstParam.Add(new OracleParameter("IDE_ID", _NFE.IDE_ID)); // lstParam.Add(new OracleParameter("IDE_TPEMIS", _NFE.IDE_TPEMIS)); // lstParam.Add(new OracleParameter("STATUSNFE", _NFE.STATUSNFE)); // lstParam.Add(new OracleParameter("DOCSEQUENCE", _NFE.DOCSEQUENCE)); // lstParam.Add(new OracleParameter("IDEID1", _NFE.IDEID1)); // lstParam.Add(new OracleParameter("IDEID2", _NFE.IDEID2)); // lstParam.Add(new OracleParameter("IDEID3", _NFE.IDEID3)); // lstParam.Add(new OracleParameter("IDE_ID_RELATED", _NFE.IDE_ID_RELATED)); // return Convert.ToInt32(OracleHelper.ExecProcedureScalarTrans("PK_NFE.SP_INSERT_NFE", lstParam, CommandType.StoredProcedure, OracleHelper.BancoOracle.optimus)); //} public int NotasFiscalEntradaInsert(NFE _NFE, string datasource, string schema) { List <OracleParameter> lstParam = new List <OracleParameter>(); lstParam.Add(new OracleParameter("XML_NFE", OracleDbType.Clob, _NFE.XML_NFE, ParameterDirection.Input)); lstParam.Add(new OracleParameter("XML_AUT", OracleDbType.Clob, _NFE.XML_AUT, ParameterDirection.Input)); lstParam.Add(new OracleParameter("XML_CANC", OracleDbType.Clob, _NFE.XML_CANC, ParameterDirection.Input)); lstParam.Add(new OracleParameter("XML_DADOSADIC", OracleDbType.Clob, _NFE.XML_DADOSADIC, ParameterDirection.Input)); lstParam.Add(new OracleParameter("IDE_SERIE", _NFE.IDE_SERIE)); lstParam.Add(new OracleParameter("IDE_NNF", _NFE.IDE_NNF)); lstParam.Add(new OracleParameter("IDE_DEMI", OracleDbType.Date, _NFE.IDE_DEMI, ParameterDirection.Input)); lstParam.Add(new OracleParameter("EMIT_CNPJ", _NFE.EMIT_CNPJ)); lstParam.Add(new OracleParameter("DEST_CNPJ", _NFE.DEST_CNPJ)); lstParam.Add(new OracleParameter("DEST_CPF", _NFE.DEST_CPF)); lstParam.Add(new OracleParameter("IDE_CUF", _NFE.IDE_CUF)); lstParam.Add(new OracleParameter("IDE_MOD", _NFE.IDE_MOD)); lstParam.Add(new OracleParameter("IDE_CNF", _NFE.IDE_CNF)); lstParam.Add(new OracleParameter("EMIT_IE", _NFE.EMIT_IE)); lstParam.Add(new OracleParameter("DEST_IE", _NFE.DEST_IE)); lstParam.Add(new OracleParameter("DEST_ENDERDEST_UF", _NFE.DEST_ENDERDEST_UF)); lstParam.Add(new OracleParameter("TOTAL_ICMSTOT_VBC", _NFE.TOTAL_ICMSTOT_VBC)); lstParam.Add(new OracleParameter("TOTAL_ICMSTOT_VBCST", _NFE.TOTAL_ICMSTOT_VBCST)); lstParam.Add(new OracleParameter("TOTAL_ICMSTOT_VPROD", _NFE.TOTAL_ICMSTOT_VPROD)); lstParam.Add(new OracleParameter("TOTAL_ICMSTOT_VICMS", _NFE.TOTAL_ICMSTOT_VICMS)); lstParam.Add(new OracleParameter("TOTAL_ICMSTOT_VST", _NFE.TOTAL_ICMSTOT_VST)); lstParam.Add(new OracleParameter("TOTAL_ISSQNTOT_VBC", _NFE.TOTAL_ISSQNTOT_VBC)); lstParam.Add(new OracleParameter("TRANSP_TRANSPORTA_CNPJ", _NFE.TRANSP_TRANSPORTA_CNPJ)); lstParam.Add(new OracleParameter("TRANSP_IE", _NFE.TRANSP_IE)); lstParam.Add(new OracleParameter("TRANSP_VEICTRANSP_PLACA", _NFE.TRANSP_VEICTRANSP_PLACA)); lstParam.Add(new OracleParameter("IDE_ID", _NFE.IDE_ID)); lstParam.Add(new OracleParameter("IDE_TPEMIS", _NFE.IDE_TPEMIS)); lstParam.Add(new OracleParameter("STATUSNFE", _NFE.STATUSNFE)); lstParam.Add(new OracleParameter("DOCSEQUENCE", _NFE.DOCSEQUENCE)); lstParam.Add(new OracleParameter("IDEID1", _NFE.IDEID1)); lstParam.Add(new OracleParameter("IDEID2", _NFE.IDEID2)); lstParam.Add(new OracleParameter("IDEID3", _NFE.IDEID3)); lstParam.Add(new OracleParameter("IDE_ID_RELATED", _NFE.IDE_ID_RELATED)); return(Convert.ToInt32(OracleHelper.ExecProcedureScalarTrans("PK_NFE.SP_INSERT_NFE", lstParam, CommandType.StoredProcedure, OracleHelper.BancoOracle.optimus, datasource, schema))); }
public void EnviarEmailCliente() { WorkFlowServico _WorkFlowServico = new WorkFlowServico("NFESaidaMail"); _WorkFlowServico.AddEvento("INÍCIO PROCESSO"); NFEHelper nfh = new NFEHelper(); DataTable dt = null; try { //Verificar se a Internet está ativa if (RJS.Optimus.Biblioteca.RJSOptimusNetwork.IsConnected()) { _WorkFlowServico.AddEvento("INÍCIO nfh.NotasFiscaisEnviarEmail()"); if (multiplasfiliais.Equals("TRUE")) { dt = nfh.NotaFiscalEnviarEmailFilial(cdentifilial, datasource, schema); } else { dt = nfh.NotaFiscalEnviarEmail(datasource, schema); } _WorkFlowServico.AddEvento("FIM nfh.NotasFiscaisEnviarEmail()"); string xml = string.Empty; string emailCliente = string.Empty; string pasta = string.Empty; string chaveNfe = string.Empty; string TxFileNfe = string.Empty; string TxFileNfeAut = string.Empty; int CdNotaFiscalSaida = 0; foreach (DataRow dtr in dt.Rows) { //DADOS emailCliente = dtr["TXEMAIL"].ToString(); CdNotaFiscalSaida = Convert.ToInt32(dtr["CDNOTAFISCALSAIDA"]); pasta = dtr["CDENTIFILIAL"].ToString(); chaveNfe = dtr["NRNFECHAVE"].ToString(); TxFileNfe = dtr["TXFILENFE"].ToString(); TxFileNfeAut = dtr["TXFILENFEAUT"].ToString(); //não enviar para a lista de dominios informado //mktp.extra.com.br if (EnviarParaDominio(emailCliente)) { #region Gravar o arquivo na pasta para o PHP Ler _WorkFlowServico.AddEvento("NRNOTA: " + CdNotaFiscalSaida.ToString() + " CHAVE NFE: " + chaveNfe); string NomeDoArquivo = string.Format("{0}\\{1}\\{2}.xml", PastaNfePHP, pasta, chaveNfe); _WorkFlowServico.AddEvento("NomeDoArquivo: " + NomeDoArquivo); string NomeDoArquivoPdf = string.Format("{0}\\{1}\\{2}.pdf", PastaNfePHP, pasta, chaveNfe); _WorkFlowServico.AddEvento("NomeDoArquivoPdf: " + NomeDoArquivoPdf); //Verifica se o arquivo existe if (!System.IO.File.Exists(NomeDoArquivo)) { //Montar o XML StringBuilder XML_NFE = new StringBuilder(); XML_NFE.AppendLine(TxFileNfe); _WorkFlowServico.AddEvento("PASTA: " + string.Concat(PastaNfePHP, "\\", pasta)); //Se não existe o diretorio cria um novo if (!System.IO.Directory.Exists(string.Concat(PastaNfePHP, "\\", pasta))) { System.IO.Directory.CreateDirectory(string.Concat(PastaNfePHP, "\\", pasta)); } //Se existe exclui o arquivo if (System.IO.File.Exists(NomeDoArquivo)) { System.IO.File.Delete(NomeDoArquivo); } _WorkFlowServico.AddEvento("INÍCIO GRAVAÇÃO DO ARQUIVO"); _WorkFlowServico.AddEvento("ARQUIVO: " + NomeDoArquivo); StreamWriter sw = new StreamWriter(NomeDoArquivo, false, Encoding.GetEncoding(1252)); sw.Write(XML_NFE); sw.Close(); _WorkFlowServico.AddEvento("FIM GRAVAÇÃO DO ARQUIVO"); } //CARREGAR O XML PARA PEGAR OS DADOS NFE _NFEtrocar = Util.CarregarNfe(NomeDoArquivo); _WorkFlowServico.AddEvento("CARREGA O XML PARA PERGAR OS DADOS:" + NomeDoArquivo); #endregion _WorkFlowServico.AddEvento("INÍCIO DOWNLOAD DO PDF"); #region download do pdf bool pdfOK = false; int i = 0; for (i = 1; i < 5; i++) { if (!pdfOK) { _WorkFlowServico.AddEvento("TENTATIVA Nº:" + i.ToString()); //Log.For(this, PastaLogCliente).Info("TENTATIVA Nº:" + i.ToString()); //gerar o PDF e gravar o PDF if (i == 1) { _WorkFlowServico.AddEvento("URL: " + string.Format(urlDanfe, pasta, chaveNfe, schema)); _WorkFlowServico.AddEvento("ARQUIVO: " + NomeDoArquivoPdf); //Log.For(this, PastaLogCliente).Info("PDF URL: " + string.Format(urlDanfe, pasta, chaveNfe, cliente)); //Log.For(this, PastaLogCliente).Info("ARQUIVO: " + NomeDoArquivoPdf); } if (!System.IO.File.Exists(NomeDoArquivoPdf))//se nao existe faz o download { try { Util.DownloadFile(string.Format(urlDanfe, pasta, chaveNfe, schema), NomeDoArquivoPdf); _WorkFlowServico.AddEvento("BAIXOU NA TENTATIVA:" + i.ToString()); } catch (Exception exw) { Util.DownloadFile(string.Format(urlDanfe, pasta, chaveNfe, schema), NomeDoArquivoPdf); if (!System.IO.File.Exists(NomeDoArquivoPdf)) { _WorkFlowServico.AddEvento("NAO BAIXOU NA EXECEPTION :" + exw.ToString()); } else { _WorkFlowServico.AddEvento("BAIXOU NA EXECEPTION :" + exw.ToString()); } } if (!System.IO.File.Exists(NomeDoArquivoPdf)) { _WorkFlowServico.AddEvento("NAO CONSEGUIU BAIXAR:" + NomeDoArquivoPdf); } else { _WorkFlowServico.AddEvento("FIM DOWNLOAD DO PDF TENTATIVA Nº:" + i.ToString()); FileInfo fi = new FileInfo(NomeDoArquivoPdf); if (fi.Length < 6144)// menor que 6kb { if (System.IO.File.Exists(NomeDoArquivoPdf)) { System.IO.File.Delete(NomeDoArquivoPdf); } Util.DownloadFile(string.Format(urlDanfe, pasta, chaveNfe, schema), NomeDoArquivoPdf); } else { pdfOK = true; } } } } } #endregion RJSOptimusEmail email = new RJSOptimusEmail(smtp, Convert.ToInt32(porta), usuario, senha, EnableSSL); FileInfo fiPdf = new FileInfo(NomeDoArquivoPdf); #region Envio do email if (fiPdf.Length < 6144) { _WorkFlowServico.AddEvento("ERRO GERAR PDF (TAMANHO):" + NomeDoArquivoPdf); Log.For(this, PastaLogCliente).Error(_WorkFlowServico.FinishWorkFlow()); objemailadm.SUBJECT = string.Format("ERRO GERAR PDF (TAMANHO) {0} Cnpj:{1} SCHEMA{2}:.", cliente, cnpjcliente, schema); objemailadm.BODY = fiPdf.FullName; Util.EnviaEmail(objemailadm, "*****@*****.**"); } else { //Enviar o e-mail _WorkFlowServico.AddEvento("INÍCIO ENVIO E-MAIL"); if (smtp.Trim() == "smtp.optimuserp.com.br") { email.From = "*****@*****.**"; } else { email.From = emailEmpresa; } email.From = emailEmpresa; bool EmailClienteValido = true; email.Subject = MsgSubject.Replace("#NRNOTA#", _NFEtrocar.IDE_NNF.ToString()). Replace("#CHAVE#", _NFEtrocar.IDE_ID). Replace("#DTEMISSAO#", _NFEtrocar.IDE_DEMI.ToString("dd/MM/yyyy")). Replace("#SERIE#", _NFEtrocar.IDE_SERIE). Replace("#RAZAO#", _NFEtrocar.RAZAOSOCIAL). Replace("#CODPEDIDO#", _NFEtrocar.CODPEDIDO). Replace("#NMCLIENTE#", _NFEtrocar.DEST_NOME);; //if (Util.ValidarEmail(emailCliente)) //{ email.To = emailCliente; string BodyTemplate = MsgPattern.ToString(); //Pegar do template //se vier o nome do arquivo carrega se nao pega o texto que veio normal if (BodyTemplate.Contains(".html")) { string pastaTemplate = ConfigurationManager.AppSettings.Get("PASTA_TEMPLATE_HTML").ToString(); string Body = System.IO.File.ReadAllText(pastaTemplate + BodyTemplate); BodyTemplate = Body; } BodyTemplate = BodyTemplate.Replace("#CNPJ#", Convert.ToUInt64(_NFEtrocar.EMIT_CNPJ).ToString(@"00\.000\.000\/0000\-00")); BodyTemplate = BodyTemplate.Replace("#NRNOTA#", _NFEtrocar.IDE_NNF.ToString()). Replace("#CHAVE#", _NFEtrocar.IDE_ID). Replace("#DTEMISSAO#", _NFEtrocar.IDE_DEMI.ToString("dd/MM/yyyy")). Replace("#SERIE#", _NFEtrocar.IDE_SERIE). Replace("#RAZAO#", _NFEtrocar.RAZAOSOCIAL). Replace("#CODPEDIDO#", _NFEtrocar.CODPEDIDO). Replace("#NMCLIENTE#", _NFEtrocar.DEST_NOME); email.Body = BodyTemplate; _NFEtrocar = null; try { if (!string.IsNullOrEmpty(emailAdmin)) { email.ListaEmailsBCC.Add(emailAdmin); } if (!string.IsNullOrEmpty(enviarCopiaCliente) && EmailClienteValido) { string[] emailscliente = enviarCopiaCliente.Split(';'); foreach (string emailcli in emailscliente) { email.ListaEmailsBCC.Add(emailcli); } } email.AddAnexo(new System.Net.Mail.Attachment(NomeDoArquivo)); //XML email.AddAnexo(new System.Net.Mail.Attachment(NomeDoArquivoPdf)); //PDF email.IsBodyHtml = true; email.Enviar(); //Atualiza o status da NFE como e-mail enviado nfh.NotaFiscalUpdateEmailEnviado(CdNotaFiscalSaida, 3, datasource, schema);//ele tentar enviar 2x #region Enviar e-mail para transportador if (EnviarEmailTransportador) { _WorkFlowServico.AddEvento("INÍCIO ENVIO E-MAIL TRANSPORTADOR"); List <string> EmailsTransportador = new List <string>(); //Carrega o xml e pega o CNPJ do transportador string _CNPJ = Util.PegarCNPJTransportador(NomeDoArquivo); if (!string.IsNullOrEmpty(_CNPJ)) { //Verifica se ja esta na base antes de buscar o transportador if (CacheLayer.Exists(_CNPJ)) { EmailsTransportador = CacheLayer.Get <List <string> >(_CNPJ); _WorkFlowServico.AddEvento("ACHOU NO CACHE"); } else { NFEHelper nh = new NFEHelper(); //Busca na base os e-mail do transportador EmailsTransportador = nh.RetornaEmailTransportadora(_CNPJ, datasource, schema); if (EmailsTransportador.Count > 0) { CacheLayer.Add(EmailsTransportador, _CNPJ); _WorkFlowServico.AddEvento("ACHOU OS EMAILS : " + EmailsTransportador.Count.ToString()); } } if (EmailsTransportador.Count > 0) { try { RJSOptimusEmail emailtransp = new RJSOptimusEmail(smtp, Convert.ToInt32(porta), usuario, senha, EnableSSL); if (!string.IsNullOrEmpty(emailAdmin)) { emailtransp.ListaEmailsBCC.Add(emailAdmin); } if (smtp.Trim() == "smtp.optimuserp.com.br") { emailtransp.From = "*****@*****.**"; } else { emailtransp.From = emailEmpresa; } emailtransp.Subject = MsgSubject; emailtransp.Body = "Nota fiscal eletronica"; //TODO lista de e-mails foreach (string emailtranspenviar in EmailsTransportador) { //emailtransp.ListaEmailsBCC.Add(emailtranspenviar); _WorkFlowServico.AddEvento("EMAIL: " + emailtranspenviar); emailtransp.ListaEmailsObj.Add(new System.Net.Mail.MailAddress(emailtranspenviar)); } emailtransp.AddAnexo(new System.Net.Mail.Attachment(NomeDoArquivo));//XML emailtransp.IsBodyHtml = true; emailtransp.Enviar(); _WorkFlowServico.AddEvento("FIM ENVIO E-MAIL TRANSPORTADOR"); } catch (Exception ext) { _WorkFlowServico.AddEvento("ERRO ENVIO E-MAIL TRANSP:" + ext.ToString()); } } else { _WorkFlowServico.AddEvento("NÃO RETORNOU E-MAIL TRANSP CNPJ: " + _CNPJ); } } else { _WorkFlowServico.AddEvento("NÃO ACHOU TRANSP " + NomeDoArquivo); } } #endregion _WorkFlowServico.AddEvento("FIM ENVIO E-MAIL "); Log.For(this, PastaLogCliente).Info(_WorkFlowServico.FinishWorkFlow()); } catch (Exception exx) { nfh.NotaFiscalUpdateEmailEnviado(CdNotaFiscalSaida, datasource, schema); try { Log.For(this, PastaLogCliente).Error(_WorkFlowServico.FinishWorkFlow() + Environment.NewLine + exx.ToString()); string chavecache = Cache[CdNotaFiscalSaida.ToString()] as string; if (string.IsNullOrEmpty(chavecache)) { Cache.Insert( CdNotaFiscalSaida.ToString(), CdNotaFiscalSaida.ToString(), null, Cache.NoAbsoluteExpiration, TimeSpan.FromSeconds(900)); objemailadm.SUBJECT = string.Format("ERRO ENVIAR E-MAIL CLIENTE: {0} Cnpj: {1} E-MAIL CLIENTE: {2} CDNOTAFISCALSAIDA: {3} SCHEMA: {4}.", cliente, cnpjcliente, emailCliente, CdNotaFiscalSaida, schema); objemailadm.BODY = exx.ToString(); Util.EnviaEmail(objemailadm, "*****@*****.**"); } } catch (Exception exxx) { Log.For(this, PastaLogCliente).Error(_WorkFlowServico.FinishWorkFlow() + Environment.NewLine + exxx.ToString()); } } } #endregion } else { nfh.NotaFiscalUpdateEmailEnviado(CdNotaFiscalSaida, 3, datasource, schema); }//fim tratamento do dominio } } else { //Internet fora do ar _WorkFlowServico.AddEvento("SEM CONEXÃO COM A INTERNET"); Log.For(this, PastaLogCliente).Error(_WorkFlowServico.FinishWorkFlow()); } } catch (Exception ex) { try { Log.For(this, PastaLogCliente).Error(_WorkFlowServico.FinishWorkFlow() + Environment.NewLine + ex.ToString()); objemailadm.SUBJECT = string.Format("ERRO CATCH GERAL ENVIAR E-MAIL. CLIENTE: {0} Cnpj: {1}.", cliente, cnpjcliente); objemailadm.BODY = _WorkFlowServico.FinishWorkFlow() + Environment.NewLine + ex.ToString(); Util.EnviaEmail(objemailadm, "*****@*****.**"); } catch (Exception exs) { RJS.Optimus.Biblioteca.RJSOptimusLog.GravaLogEventViewer("RJS.Optimus.Win.Int.Servicos.NFEOptimus", string.Concat(_WorkFlowServico.FinishWorkFlow(), Environment.NewLine, exs.ToString()), System.Diagnostics.EventLogEntryType.Error); } } }
public void BuscarXMLnaPasta() { WorkFlowServico _WorkFlowServico = new WorkFlowServico("NFEEntrada.xmlPasta"); NFEHelper nfh = new NFEHelper(); System.IO.DirectoryInfo dirInfoAuto = new DirectoryInfo(pastaTmpEntrada); System.IO.FileInfo[] ArquivosRetornoNfe = dirInfoAuto.GetFiles("*.xml", SearchOption.TopDirectoryOnly); foreach (FileInfo fi2 in ArquivosRetornoNfe.ToList()) { try { NFE _NFE = Util.CarregarNfe(pastaTmpEntrada + "\\" + fi2.Name); //Validar se já existe na tabela NFE string P_DEST_CNPJ = _NFE.dEST_CNPJ; string P_EMIT_CNPJ = _NFE.EMIT_CNPJ; string p_DEST_CPF = _NFE.DEST_CPF; int P_IDE_NNF = _NFE.IDE_NNF; int P_IDE_SERIE = Convert.ToInt32(_NFE.IDE_SERIE); DateTime P_IDE_DEMI = _NFE.IDE_DEMI; //Util ut = new Util(); //Primeira Validação com o XSD da sefaz //ut.ValidaXMLNFE(pastaTmpEntrada + "\\" + attach.Name, pastaSchema); //Caso não esteja valido deleta o arquivo //if (string.IsNullOrEmpty(ut.MsgValidacaoXML)) //{ //TODO: //Verificar se a nota é valida na SEFAZ //Carregar as informações do XML //} //else //{ // _WorkFlowServico.AddEvento(string.Format("XML INVÁLIDO: {0} ERRO:{1}", attach.Name, ut.MsgValidacaoXML)); // System.IO.File.Move(string.Concat(pastaTmpEntrada, "\\", attach.Name), string.Concat(pastaEntradaERRO, "\\", attach.Name)); //} if (nfh.NotaFiscalEntradaValidar(string.IsNullOrEmpty(P_DEST_CNPJ) ? p_DEST_CPF : P_DEST_CNPJ, P_EMIT_CNPJ, P_IDE_NNF, P_IDE_SERIE, P_IDE_DEMI, datasource, schema) == 0) { //Gravar na tabela NFE do ORACLE nfh.NotasFiscalEntradaInsert(_NFE, datasource, schema); //Insert com sucesso if (System.IO.File.Exists(string.Concat(pastaEntradaOK, "\\", fi2.Name))) { System.IO.File.Delete(string.Concat(pastaEntradaOK, "\\", fi2.Name)); } System.IO.File.Move(string.Concat(pastaTmpEntrada, "\\", fi2.Name), string.Concat(pastaEntradaOK, "\\", fi2.Name)); _WorkFlowServico.AddEvento(string.Format("NF Nº{0} CNPJ_EMIT:{1} SERIE:{2} CNPJ_CPF_DEST:{3}.", _NFE.IDE_NNF.ToString(), _NFE.EMIT_CNPJ.ToString(), _NFE.IDE_SERIE.ToString(), _NFE.DEST_CNPJ != null ? _NFE.DEST_CNPJ.ToString() : _NFE.DEST_CPF.ToString())); //chaveserro.AppendLine(pastaTmpEntrada + "\\" + fi2.Name + "OK"); } else { _WorkFlowServico.AddEvento(string.Format("NF Nº{0} CNPJ_EMIT:{1} SERIE:{2} CNPJ_DEST:{3} JÁ IMPORTADA.", _NFE.IDE_NNF.ToString(), _NFE.EMIT_CNPJ.ToString(), _NFE.IDE_SERIE.ToString(), _NFE.DEST_CNPJ == null ? _NFE.DEST_CPF : _NFE.DEST_CNPJ)); System.IO.File.Delete(string.Concat(pastaTmpEntrada, "\\", fi2.Name)); //chaveserro.AppendLine(pastaTmpEntrada + "\\" + fi2.Name + "JA"); } } catch (Exception ex) { //chaveserro.AppendLine(pastaTmpEntrada + "\\" + fi2.Name + " -->EX:" + ex.ToString()); Log.For(this, PastaLogCliente).Error(pastaTmpEntrada + "\\" + fi2.Name + " -->EX:" + ex.ToString()); try { System.IO.File.Move(string.Concat(pastaTmpEntrada, "\\", fi2.Name), string.Concat(pastaEntradaERRO, "\\", fi2.Name)); objemailadm.SUBJECT = "ERRO NFE ENTRADA BUSCAR NA PASTA" + cnpjEmpresa.ToString() + " SCHEMA:" + schema; objemailadm.BODY = ex.ToString(); Util.EnviaEmail(objemailadm, "*****@*****.**"); } catch (Exception exs) { Log.For(this, PastaLogCliente).Error(pastaTmpEntrada + "\\" + fi2.Name + " ao tentar mover-->EX:" + exs.ToString()); } } } if (ArquivosRetornoNfe.Count() > 0) { Log.For(this, PastaLogCliente).Info(_WorkFlowServico.FinishWorkFlow()); //string aaaa = chaveserro.ToString(); } }