Ir para o conteúdo principal

Painel de documentos do Gov.Doc não está carregando

O Problema

O sistema Gov.Doc, sistema de edição de documentos oficiais, possui um painel para exibir alguns números referentes a criação de documentos para usuários com perfil de administrador, contudo na tentativa de acessar tais informações é apresentado o erro 504 Gateway Time-out

Em avaliação ao código desenvolvido se percebeu numa consulta(imagem 1) ao banco de dados que está apresentando uma demora, devido a estar retornando todos os campos da entidade Documentos para assim gerar os quantitativos do painel. 

Imagem 1

 public async Task<IActionResult> Painel()
        {
            var documentos = await db.Documentos.ToListAsync();

            var documentosPorSistema = documentos.Select(documento => new DocumentoPorSistemaDto(documento.SistemaOrigemId)).ToList();
            foreach (var documento in documentosPorSistema)
            {
                var sistema = await apiDoSauron.BuscarSistemaDeOrigem(documento.ClientId);
                documento.NomeDoSistema = sistema.Description;
            }

            var totalDeDocumentosPorTipo = documentos.GroupBy(x => x.TipoDeDocumento).OrderBy(tipoDeDocumento => tipoDeDocumento.Key);

            var documentosGeradosPorSistema = documentosPorSistema.GroupBy(x => x.NomeDoSistema).OrderBy(nomeDoSistema => nomeDoSistema.Key);
            
            var painelViewModel = new PainelViewModel(totalDeDocumentosPorTipo, documentosGeradosPorSistema);

            ViewData["TotalDeDocumentosGerados"] = documentos.Count;
            
            return View(painelViewModel);
        }

Solução proposta

Diante da necessidade de prover um acesso mais rápido as informações do painel, o time Tambaqui propõem as seguintes mudanças:

  • Alteração da consulta para utilizar apenas os campos da entidade Documentos necessários para o processamento das informações do painel;
  • Elaboração de um SPYKE para avaliar os impactos de armazenar o conteúdo do corpo do documento no Storage Amazon da SETIC, onde com o resultado desse estudo será possível mensurar "o que fazer?" e "como fazer?".