debian-mirror-gitlab/app/graphql/resolvers/labels_resolver.rb
2023-06-20 00:43:36 +05:30

59 lines
1.7 KiB
Ruby

# frozen_string_literal: true
module Resolvers
class LabelsResolver < BaseResolver
include Gitlab::Graphql::Authorize::AuthorizeResource
authorize :read_label
type Types::LabelType.connection_type, null: true
argument :search_term, GraphQL::Types::String,
required: false,
description: 'Search term to find labels with.'
argument :include_ancestor_groups, GraphQL::Types::Boolean,
required: false,
description: 'Include labels from ancestor groups.',
default_value: false
before_connection_authorization do |nodes, current_user|
if Feature.enabled?(:preload_max_access_levels_for_labels_finder)
Preloaders::LabelsPreloader.new(nodes, current_user).preload_all
end
end
def resolve(**args)
return Label.none if parent.nil?
authorize!(parent)
# LabelsFinder uses `search` param, so we transform `search_term` into `search`
args[:search] = args.delete(:search_term)
# Optimization:
# Rely on the LabelsPreloader rather than the default parent record preloading in the
# finder because LabelsPreloader preloads more associations which are required for the
# permission check.
args[:preload_parent_association] = false if Feature.disabled?(:preload_max_access_levels_for_labels_finder)
LabelsFinder.new(current_user, parent_param.merge(args)).execute
end
private
def parent
object.respond_to?(:sync) ? object.sync : object
end
def parent_param
key = case parent
when Group then :group
when Project then :project
else raise "Unexpected parent type: #{parent.class}"
end
{ "#{key}": parent }
end
end
end