aa7b1cfc5b
- Due to https://github.com/exAspArk/batch-loader/pull/32, we changed BatchLoader.for into BatchLoader::GraphQL.for - since our results are wrapped in a BatchLoader::GraphQL, calling `sync` during authorization is required to get real object - `graphql` now has it's own authorization system. Our `authorized?` method conflicted and required renaming
22 lines
704 B
Ruby
22 lines
704 B
Ruby
# frozen_string_literal: true
|
|
|
|
module Resolvers
|
|
module FullPathResolver
|
|
extend ActiveSupport::Concern
|
|
|
|
prepended do
|
|
argument :full_path, GraphQL::ID_TYPE,
|
|
required: true,
|
|
description: 'The full path of the project, group or namespace, e.g., "gitlab-org/gitlab-ce"'
|
|
end
|
|
|
|
def model_by_full_path(model, full_path)
|
|
BatchLoader::GraphQL.for(full_path).batch(key: model) do |full_paths, loader, args|
|
|
# `with_route` avoids an N+1 calculating full_path
|
|
args[:key].where_full_path_in(full_paths).with_route.each do |model_instance|
|
|
loader.call(model_instance.full_path, model_instance)
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|