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

50 lines
1.6 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|
# Resolvers may add extra complexity depending on used arguments
2019-09-04 21:01:54 +05:30
complexity = child_complexity + self.resolver&.try(:resolver_complexity, args, child_complexity: child_complexity).to_i
field_defn = to_graphql
2019-07-31 22:56:46 +05:30
2019-09-04 21:01:54 +05:30
if field_defn.connection?
# Resolvers may add extra complexity depending on number of items being loaded.
page_size = field_defn.connection_max_page_size || ctx.schema.default_max_page_size
limit_value = [args[:first], args[:last], page_size].compact.min
multiplier = self.resolver&.try(:complexity_multiplier, args).to_f
complexity += complexity * limit_value * multiplier
end
2019-07-31 22:56:46 +05:30
complexity.to_i
end
end
2018-11-08 19:23:39 +05:30
end
end