public async Task <IList <NotadeCompraDTO> > Handle(ListarNotasparaAprovacaoQuery request, CancellationToken cancellationToken) { var listaresultado = new List <NotadeCompraDTO>(); var usuario = _context.Usuarios.SingleOrDefault(x => x.Id == request.IdUsuario); if (usuario == null) { return(listaresultado); } //teste adm if (usuario.Papel == PapelAprovacao.Adm) { return(await _context.NotadeCompras.ProjectTo <NotadeCompraDTO>(_mapper.ConfigurationProvider).OrderBy(o => o.DataEmissao).ToListAsync(cancellationToken)); } var listadenotas = _context.NotadeCompras.Where(GetQuery(request, usuario)).OrderBy(o => o.DataEmissao).ToList(); foreach (var nota in listadenotas) { if (_context.AutorizacaoHistoricos.Any(x => x.Nota.Id == nota.Id && x.Usuario.Id == usuario.Id)) { continue; } var hist = _context.AutorizacaoHistoricos.Where(x => x.Nota.Id == nota.Id).ToList(); if (ValidacoeseVerificacoes.VerificarConfiguracaoAutorizacaoDiponivel(_context, nota, hist, usuario)) { listaresultado.Add(_mapper.Map <NotadeCompraDTO>(nota)); continue; } } return(listaresultado); }