Class: Resolvers::LabelsResolver

Inherits:
BaseResolver
  • Object
show all
Includes:
Gitlab::Graphql::Authorize::AuthorizeResource
Defined in:
app/graphql/resolvers/labels_resolver.rb

Direct Known Subclasses

GroupLabelsResolver

Constant Summary

Constants included from Gitlab::Graphql::Authorize::AuthorizeResource

Gitlab::Graphql::Authorize::AuthorizeResource::ConfigurationError, Gitlab::Graphql::Authorize::AuthorizeResource::RESOURCE_ACCESS_ERROR

Instance Method Summary collapse

Methods included from Gitlab::Graphql::Authorize::AuthorizeResource

#authorize!, #authorized_find!, #authorized_resource?, #find_object, #raise_resource_not_available_error!

Methods inherited from BaseResolver

as_single, authorization, authorized?, before_connection_authorization, before_connection_authorization_block, calculate_ext_conn_complexity, calls_gitaly!, calls_gitaly?, complexity, complexity_multiplier, #current_user, last, #object, #offset_pagination, requires_argument!, requires_argument?, resolver_complexity, #select_result, single, #single?, single_definition_blocks, singular_type, when_single

Methods included from Gitlab::Utils::Override

#extended, extensions, #included, #method_added, #override, #prepended, #queue_verification, verify!

Instance Method Details

#resolve(**args) ⇒ Object



40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
# File 'app/graphql/resolvers/labels_resolver.rb', line 40

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)

  # If `title` is used, remove `search_in`
  args.delete(:search_in) if args[:title]

  # 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.
  LabelsFinder.new(current_user, parent_param.merge(args)).execute
end