Class: Types::PermissionTypes::BasePermissionType
Direct Known Subclasses
Ci::Job, Ci::Pipeline, Ci::PipelineSchedules, Ci::Runner, ContainerRepository, ContainerRepositoryTag, CustomEmoji, Deployment, Environment, Group, Issue, MergeRequest, Note, OrganizationUser, Package, Project, Snippet, Timelog, User, Wikis::WikiPage, WorkItem
Constant Summary
collapse
- RESOLVING_KEYWORDS =
[:resolver, :method, :hash_key, :function].to_set.freeze
Class Method Summary
collapse
can?, can_all?, can_any?
Methods inherited from BaseObject
accepts, assignable?, authorization, authorization_scopes, authorize, authorized?, #current_user, #id
#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: "If `true`, the user can perform `#{name}` on this resource",
null: false)
field(**kword_args, &block) end
|