Ejemplo n.º 1
0
        //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)));
        }
Ejemplo n.º 2
0
        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);
                }
            }
        }
Ejemplo n.º 3
0
        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();
            }
        }