2018-11-20 20:47:30 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2018-03-17 18:26:18 +05:30
|
|
|
# Returns and caches in thread max member access for a resource
|
|
|
|
#
|
|
|
|
module BulkMemberAccessLoad
|
|
|
|
extend ActiveSupport::Concern
|
|
|
|
|
|
|
|
included do
|
|
|
|
# Determine the maximum access level for a group of resources in bulk.
|
|
|
|
#
|
|
|
|
# Returns a Hash mapping resource ID -> maximum access level.
|
|
|
|
def max_member_access_for_resource_ids(resource_klass, resource_ids, memoization_index = self.id, &block)
|
|
|
|
raise 'Block is mandatory' unless block_given?
|
|
|
|
|
|
|
|
resource_ids = resource_ids.uniq
|
|
|
|
key = max_member_access_for_resource_key(resource_klass, memoization_index)
|
|
|
|
access = {}
|
|
|
|
|
2018-12-05 23:21:45 +05:30
|
|
|
if Gitlab::SafeRequestStore.active?
|
|
|
|
Gitlab::SafeRequestStore[key] ||= {}
|
|
|
|
access = Gitlab::SafeRequestStore[key]
|
2018-03-17 18:26:18 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
# Look up only the IDs we need
|
2020-11-24 15:15:51 +05:30
|
|
|
resource_ids -= access.keys
|
2018-03-17 18:26:18 +05:30
|
|
|
|
|
|
|
return access if resource_ids.empty?
|
|
|
|
|
|
|
|
resource_access = yield(resource_ids)
|
|
|
|
|
|
|
|
access.merge!(resource_access)
|
|
|
|
|
|
|
|
missing_resource_ids = resource_ids - resource_access.keys
|
|
|
|
|
|
|
|
missing_resource_ids.each do |resource_id|
|
|
|
|
access[resource_id] = Gitlab::Access::NO_ACCESS
|
|
|
|
end
|
|
|
|
|
|
|
|
access
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def max_member_access_for_resource_key(klass, memoization_index)
|
|
|
|
"max_member_access_for_#{klass.name.underscore.pluralize}:#{memoization_index}"
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|