Exemplo n.º 1
0
        /// <summary>
        /// Roda Rmenu todos de uma vez e retorna a ultima versão
        /// </summary>
        private async Task <bool> AtualizarSql(PostoContext context, bool backup)
        {
            return(await Task.Run(async() =>
            {
                try
                {
                    await BuscaVersoes();

                    Rmenu = "";

                    TelaPrincipal.AbaAtualizacao.LabelContent = "Baixando o Rmenu...";
                    ListaSql.ForEach(row =>
                    {
                        Rmenu += Encoding.ASCII.GetString(Ftp.Download((PathSql + row.Arquivo), TelaPrincipal));
                    });

                    if (backup)
                    {
                        TelaPrincipal.AbaAtualizacao.ProgressoBarra2 = 17;

                        if (Rmenu != "")
                        {
                            if (ConfiguracaoModel.DiretorioPostgreSql == "")
                            {
                                throw new Exception("Não definido o diretório para do postgres para a rotina de backup do banco.");
                            }
                            else
                            {
                                TelaPrincipal.AbaAtualizacao.LabelContent = "Gerando backup do banco de dados";

                                if (!await ExecutaBackup())
                                {
                                    throw new Exception("Ocorreu um erro ao tentar gerar backup antes de atualizar o sistema.");
                                }
                            }
                        }
                    }

                    TelaPrincipal.AbaAtualizacao.ProgressoBarra2 = 25;
                    TelaPrincipal.AbaAtualizacao.IsIndeterminateBarra1 = true;
                    TelaPrincipal.AbaAtualizacao.LabelContent = "Executando Rmenu de v." + AtualizarModel.Versao.ToString() + " até v." + UltimaVersao.ToString() + "";

                    context.Query(Rmenu).ExecuteNonQuery();

                    TelaPrincipal.Indicadores.AtualizouBanco = true;
                    TelaPrincipal.AbaAtualizacao.IsIndeterminateBarra1 = false;
                }
                catch (Exception e)
                {
                    context.RollBack();
                    log.Error(e.Message);
                    TelaPrincipal.AbaAtualizacao.LabelContent = "Problemas ao rodar o Rmenu.";

                    return false;
                }
                finally
                {
                    context.Commit();

                    if (UltimaVersao <= 0)
                    {
                        UltimaVersao = AtualizarModel.Versao.GetValueOrDefault();
                    }
                }
                return true;
            }));
        }