class AccessRequestsFinder attr_accessor :source # Arguments: # source - a Group or Project def initialize(source) @source = source end def execute(*args) execute!(*args) rescue Gitlab::Access::AccessDeniedError [] end def execute!(current_user) raise Gitlab::Access::AccessDeniedError unless can_see_access_requests?(current_user) source.requesters end private def can_see_access_requests?(current_user) source && Ability.allowed?(current_user, :"admin_#{source.class.to_s.underscore}", source) end end