Commit e86abb2b authored by Mario Celi's avatar Mario Celi

Remove TodosProjectPermissionPreloader field extension

Use before_connection_authorization resolver block instead
parent 8cb37e68
...@@ -30,6 +30,13 @@ module Resolvers ...@@ -30,6 +30,13 @@ module Resolvers
required: false, required: false,
description: 'Type of the todo.' description: 'Type of the todo.'
before_connection_authorization do |nodes, current_user|
Preloaders::UserMaxAccessLevelInProjectsPreloader.new(
nodes.map(&:project).compact,
current_user
).execute
end
def resolve(**args) def resolve(**args)
return Todo.none unless current_user.present? && target.present? return Todo.none unless current_user.present? && target.present?
return Todo.none if target.is_a?(User) && target != current_user return Todo.none if target.is_a?(User) && target != current_user
......
...@@ -115,9 +115,7 @@ module Types ...@@ -115,9 +115,7 @@ module Types
null: true, null: true,
description: 'Runbook for the alert as defined in alert details.' description: 'Runbook for the alert as defined in alert details.'
field :todos, description: 'To-do items of the current user for the alert.', resolver: Resolvers::TodoResolver do field :todos, description: 'To-do items of the current user for the alert.', resolver: Resolvers::TodoResolver
extension(::Gitlab::Graphql::TodosProjectPermissionPreloader::FieldExtension)
end
field :details_url, field :details_url,
GraphQL::Types::String, GraphQL::Types::String,
......
...@@ -85,9 +85,7 @@ module Types ...@@ -85,9 +85,7 @@ module Types
null: true, null: true,
description: 'Personal namespace of the user.' description: 'Personal namespace of the user.'
field :todos, resolver: Resolvers::TodoResolver, description: 'To-do items of the user.' do field :todos, resolver: Resolvers::TodoResolver, description: 'To-do items of the user.'
extension(::Gitlab::Graphql::TodosProjectPermissionPreloader::FieldExtension)
end
# Merge request field: MRs can be authored, assigned, or assigned-for-review: # Merge request field: MRs can be authored, assigned, or assigned-for-review:
field :authored_merge_requests, field :authored_merge_requests,
......
# frozen_string_literal: true
module Gitlab
module Graphql
module TodosProjectPermissionPreloader
class FieldExtension < ::GraphQL::Schema::FieldExtension
def after_resolve(value:, memo:, **rest)
todos = value.to_a
Preloaders::UserMaxAccessLevelInProjectsPreloader.new(
todos.map(&:project).compact,
current_user(rest)
).execute
value
end
private
def current_user(options)
options.dig(:context, :current_user)
end
end
end
end
end
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment