Class: Types::PermissionTypes::BasePermissionType

Inherits:
BaseObject
  • Object
show all
Extended by:
Gitlab::Allowable
Defined in:
app/graphql/types/permission_types/base_permission_type.rb

Constant Summary collapse

RESOLVING_KEYWORDS =
[:resolver, :method, :hash_key, :function].to_set.freeze

Class Method Summary collapse

Methods included from Gitlab::Allowable

can?

Methods inherited from BaseObject

accepts, assignable?, authorization, authorize, authorized?, #current_user, #id

Methods included from Gitlab::Graphql::Present

#present, #unpresented

Class Method Details

.abilities(*abilities) ⇒ Object



10
11
12
# File 'app/graphql/types/permission_types/base_permission_type.rb', line 10

def self.abilities(*abilities)
  abilities.each { |ability| ability_field(ability) }
end

.ability_field(ability, **kword_args, &block) ⇒ Object



14
15
16
17
18
# File 'app/graphql/types/permission_types/base_permission_type.rb', line 14

def self.ability_field(ability, **kword_args, &block)
  define_field_resolver_method(ability) unless resolving_keywords?(kword_args)

  permission_field(ability, **kword_args, &block)
end

.define_field_resolver_method(ability) ⇒ Object



30
31
32
33
34
35
36
# File 'app/graphql/types/permission_types/base_permission_type.rb', line 30

def self.define_field_resolver_method(ability)
  unless respond_to?(ability)
    define_method ability.to_sym do |*args|
      Ability.allowed?(context[:current_user], ability, object, args.to_h)
    end
  end
end

.permission_field(name, **kword_args, &block) ⇒ Object



20
21
22
23
24
25
26
27
28
# File 'app/graphql/types/permission_types/base_permission_type.rb', line 20

def self.permission_field(name, **kword_args, &block)
  kword_args = kword_args.reverse_merge(
    name: name,
    type: GraphQL::Types::Boolean,
    description: "Indicates the user can perform `#{name}` on this resource",
    null: false)

  field(**kword_args, &block) # rubocop:disable Graphql/Descriptions
end