32 lines
996 B
Ruby
32 lines
996 B
Ruby
# frozen_string_literal: true
|
|
|
|
module Preloaders
|
|
class GroupRootAncestorPreloader
|
|
def initialize(groups, root_ancestor_preloads = [])
|
|
@groups = groups
|
|
@root_ancestor_preloads = root_ancestor_preloads
|
|
end
|
|
|
|
def execute
|
|
return unless ::Feature.enabled?(:use_traversal_ids)
|
|
|
|
# type == 'Group' condition located on subquery to prevent a filter in the query
|
|
root_query = Namespace.joins("INNER JOIN (#{join_sql}) as root_query ON root_query.root_id = namespaces.id")
|
|
.select('namespaces.*, root_query.id as source_id')
|
|
|
|
root_query = root_query.preload(*@root_ancestor_preloads) if @root_ancestor_preloads.any?
|
|
|
|
root_ancestors_by_id = root_query.group_by(&:source_id)
|
|
|
|
@groups.each do |group|
|
|
group.root_ancestor = root_ancestors_by_id[group.id].first
|
|
end
|
|
end
|
|
|
|
private
|
|
|
|
def join_sql
|
|
Group.select('id, traversal_ids[1] as root_id').where(id: @groups.map(&:id)).to_sql
|
|
end
|
|
end
|
|
end
|