X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/12b9d77ecca3043b65015860359ce447b68fccfb..bff57ea5cd61b02b829d831e3637151b1cf4b94c:/services/api/app/controllers/arvados/v1/nodes_controller.rb diff --git a/services/api/app/controllers/arvados/v1/nodes_controller.rb b/services/api/app/controllers/arvados/v1/nodes_controller.rb index 0ca588625e..efee982e74 100644 --- a/services/api/app/controllers/arvados/v1/nodes_controller.rb +++ b/services/api/app/controllers/arvados/v1/nodes_controller.rb @@ -38,17 +38,16 @@ class Arvados::V1::NodesController < ApplicationController end def find_objects_for_index - if current_user.andand.is_admin || !current_user.andand.is_active - super - else + if !current_user.andand.is_admin && current_user.andand.is_active # active non-admin users can list nodes that are (or were # recently) working @objects = model_class.where('last_ping_at >= ?', Time.now - 1.hours) end - assigned_nodes = @objects.select(&:job_uuid) - assoc_jobs = readable_job_uuids(*assigned_nodes.map(&:job_uuid)) - assigned_nodes.each do |node| - node.job_readable = assoc_jobs.include?(node.job_uuid) + super + job_uuids = @objects.map { |n| n[:job_uuid] }.compact + assoc_jobs = readable_job_uuids(job_uuids) + @objects.each do |node| + node.job_readable = assoc_jobs.include?(node[:job_uuid]) end end