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
38 lines
1.1 KiB
Ruby
38 lines
1.1 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
module Resolvers
|
|
class MergeRequestsResolver < BaseResolver
|
|
argument :iid, GraphQL::STRING_TYPE,
|
|
required: false,
|
|
description: 'The IID of the merge request, e.g., "1"'
|
|
|
|
argument :iids, [GraphQL::STRING_TYPE],
|
|
required: false,
|
|
description: 'The list of IIDs of issues, e.g., [1, 2]'
|
|
|
|
type Types::MergeRequestType, null: true
|
|
|
|
alias_method :project, :object
|
|
|
|
def resolve(**args)
|
|
return unless project.present?
|
|
|
|
args[:iids] ||= [args[:iid]].compact
|
|
|
|
args[:iids].map { |iid| batch_load(iid) }
|
|
.select(&:itself) # .compact doesn't work on BatchLoader
|
|
end
|
|
|
|
# rubocop: disable CodeReuse/ActiveRecord
|
|
def batch_load(iid)
|
|
BatchLoader::GraphQL.for(iid.to_s).batch(key: project) do |iids, loader, args|
|
|
arg_key = args[:key].respond_to?(:sync) ? args[:key].sync : args[:key]
|
|
|
|
arg_key.merge_requests.where(iid: iids).each do |mr|
|
|
loader.call(mr.iid.to_s, mr)
|
|
end
|
|
end
|
|
end
|
|
# rubocop: enable CodeReuse/ActiveRecord
|
|
end
|
|
end
|