debian-mirror-gitlab/app/graphql/types/base_field.rb

47 lines
1.5 KiB
Ruby
Raw Normal View History

2018-12-05 23:21:45 +05:30
# frozen_string_literal: true
2018-11-08 19:23:39 +05:30
module Types
class BaseField < GraphQL::Schema::Field
prepend Gitlab::Graphql::Authorize
2019-07-07 11:18:12 +05:30
DEFAULT_COMPLEXITY = 1
def initialize(*args, **kwargs, &block)
2019-07-31 22:56:46 +05:30
kwargs[:complexity] ||= field_complexity(kwargs[:resolver_class])
2019-07-07 11:18:12 +05:30
super(*args, **kwargs, &block)
end
2019-07-31 22:56:46 +05:30
private
def field_complexity(resolver_class)
if resolver_class
field_resolver_complexity
else
DEFAULT_COMPLEXITY
end
end
def field_resolver_complexity
# Complexity can be either integer or proc. If proc is used then it's
# called when computing a query complexity and context and query
# arguments are available for computing complexity. For resolvers we use
# proc because we set complexity depending on arguments and number of
# items which can be loaded.
proc do |ctx, args, child_complexity|
page_size = @max_page_size || ctx.schema.default_max_page_size
limit_value = [args[:first], args[:last], page_size].compact.min
# Resolvers may add extra complexity depending on used arguments
complexity = child_complexity + self.resolver&.try(:resolver_complexity, args).to_i
# Resolvers may add extra complexity depending on number of items being loaded.
multiplier = self.resolver&.try(:complexity_multiplier, args).to_f
complexity += complexity * limit_value * multiplier
complexity.to_i
end
end
2018-11-08 19:23:39 +05:30
end
end