Esempio n. 1
0
        public void UpdateDB()
        {
            var             sessao       = AuxiliarNhibernate.AbrirSessao();
            ProtocoloDB_DAO ProtocoloDAO = new ProtocoloDB_DAO(sessao);

            var lista = ProtocoloDAO.BuscaParaAtualizarBanco();

            if (lista.Count > 0)
            {
                foreach (var item in lista)
                {
                    if (item.driver == StaticParametersDB.GetDriver())
                    {
                        try
                        {
                            if (!item.salvoDB)
                            {
                                var ret = Banco.UpdateDB(item);

                                if (ret == true)
                                {
                                    item.salvoDB = true;
                                    ProtocoloDAO.Salvar(item);
                                }
                            }
                        }
                        catch (Exception ex)
                        {
                        }
                    }
                }
            }

            sessao.Close();
        }
Esempio n. 2
0
        public void EnviaDB()
        {
            var             sessao       = AuxiliarNhibernate.AbrirSessao();
            ProtocoloDB_DAO ProtocoloDAO = new ProtocoloDB_DAO(sessao);

            Banco.GetData(sessao);

            var lista = ProtocoloDAO.BuscaEnvio();

            if (lista.Count > 0)
            {
                foreach (var item in lista)
                {
                    var apiXMLDB = new EnviaXML(StaticParametersDB.GetGrupo(), StaticParametersDB.GetToken(), Convert.ToBoolean(item.baseEnv));

                    if (item.driver == StaticParametersDB.GetDriver())
                    {
                        var xmlString = proc.MontaXMLDB(item.id, item.xmlEvento);
                        var response  = apiXMLDB.SendXML(xmlString, item.id);
                        if (proc.VerificaResponseXML(response) == true)
                        {
                            proc.SalvaProtocoloXML(item.id, response, 2, sessao);

                            var data      = proc.RetornaData();
                            var protocolo = new ProtocoloDB {
                                id = item.id, dtenvio = data[0], hrenvio = data[1], status = "0 - Enviado", idDB = StaticParametersDB.GetId()
                            };
                            ProtocoloDAO.Salvar(protocolo);
                            proc.GeraLogEnviaXML(item.id, "Foi enviado com sucesso!");

                            Banco.CustomUpdateDB(ProtocoloDAO.BuscarPorIDEvento(item.id), 3);
                        }
                        else
                        {
                            proc.GeraLogEnviaXML(item.id, "Não foi enviado");
                        }
                    }
                }
            }

            proc.RemoveFileBuffer();

            sessao.Close();
        }
Esempio n. 3
0
        public static void Setcurrent(long?id)
        {
            foreach (var b in ListBanco)
            {
                if (id == b.Id)
                {
                    current = b;
                }
            }

            Processos process = new Processos();

            StaticParametersDB.SetDriver(current.Driver);
            StaticParametersDB.SetHost(current.Host);
            StaticParametersDB.SetPort(current.Port);
            StaticParametersDB.SetServiceName(current.ServiceName);
            StaticParametersDB.SetUser(current.User);
            StaticParametersDB.SetPassword(AESThenHMAC.SimpleDecryptWithPassword(current.Password, process.GetMacAdress()));
            StaticParametersDB.SetTrustedCon(current.Trusted_Conn);
            StaticParametersDB.SetId(current.Id.ToString());
            StaticParametersDB.SetGrupo(current.Grupo);
            StaticParametersDB.SetToken(current.Token);
        }
Esempio n. 4
0
        public void ConsultaDB()
        {
            var             sessao       = AuxiliarNhibernate.AbrirSessao();
            ProtocoloDB_DAO ProtocoloDAO = new ProtocoloDB_DAO(sessao);

            var lista = ProtocoloDAO.BuscaConsulta();

            if (lista.Count > 0)
            {
                foreach (var item in lista)
                {
                    if (item.driver == StaticParametersDB.GetDriver())
                    {
                        var apiConXMLDB = new ConsultaXML(StaticParametersDB.GetGrupo(), StaticParametersDB.GetToken());
                        var retorno     = apiConXMLDB.ConsultaProtocolo(item.nroProt, item.baseEnv, item.id);

                        try
                        {
                            if (proc.VerificaConsultaXML(retorno) == true)
                            {
                                proc.GeraLogConsultaXML(item.id, retorno, item.nroProt, 2);

                                if (proc.VerificaSeTemRecibo(retorno, item.id) == true)
                                {
                                    var xmlRec    = proc.ExtraiXMLRecibo(item.id, retorno);
                                    var nrRec     = proc.ExtraiInfoXML(xmlRec, "nrRecibo");
                                    var nrProtgov = proc.ExtraiInfoXML(xmlRec, "protocoloEnvioLote");

                                    var data = proc.RetornaData();
                                    var prot = new ProtocoloDB {
                                        id = item.id, xmlRec = xmlRec, nroRec = nrRec, consultado = true, dtconsulta = data[0], hrconsulta = data[1], nroProtGov = nrProtgov, status = "2 - Aprovado", idDB = StaticParametersDB.GetId()
                                    };
                                    ProtocoloDAO.Salvar(prot);
                                }
                                else
                                {
                                    var erros = proc.ExtraiErrosXmlDB(retorno, item.id);
                                    if (!erros.Equals(""))
                                    {
                                        var data = proc.RetornaData();
                                        var prot = new ProtocoloDB {
                                            id = item.id, erros = erros, consultado = true, dtconsulta = data[0], hrconsulta = data[1], status = "3 - Rejeitado", idDB = StaticParametersDB.GetId()
                                        };
                                        ProtocoloDAO.Salvar(prot);
                                    }
                                    else
                                    {
                                        throw new Exception($"Erro na consulta do item {item.id}, Retorno: {retorno}");
                                    }
                                }
                            }
                            else
                            {
                                var data = proc.RetornaData();
                                var prot = new ProtocoloDB {
                                    id = item.id, dtconsulta = data[0], hrconsulta = data[1], status = "1 - Aguardando Governo/iVeS", idDB = StaticParametersDB.GetId()
                                };
                                ProtocoloDAO.Salvar(prot);
                                Banco.CustomUpdateDB(ProtocoloDAO.BuscarPorIDEvento(item.id), 4);
                            }
                        }
                        catch (Exception e)
                        {
                            ex.Exception(e.Message, item.id, "Consulta", "Tente consultar novamente em alguns minutos", e);
                        }
                    }
                }
            }

            proc.RemoveFileBuffer();

            sessao.Close();
        }