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(); }
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(); }
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); }
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(); }