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