Class: RoleCore::PermissionSet
- Inherits:
-
OptionsModel::Base
- Object
- OptionsModel::Base
- RoleCore::PermissionSet
- Defined in:
- lib/role_core/permission_set.rb
Class Method Summary collapse
- .draw(**constraints, &block) ⇒ Object
- .i18n_scope ⇒ Object
- .permission_class ⇒ Object
- .permission_class=(klass) ⇒ Object
- .register_permission(name, default = false, **options, &block) ⇒ Object
- .registered_permissions ⇒ Object
- .use_relative_model_naming? ⇒ Boolean
Instance Method Summary collapse
Class Method Details
.draw(**constraints, &block) ⇒ Object
39 40 41 42 43 44 45 46 47 |
# File 'lib/role_core/permission_set.rb', line 39 def draw(**constraints, &block) unless block_given? raise ArgumentError, "must provide a block" end Mapper.new(self, constraints).instance_exec(&block) self end |
.i18n_scope ⇒ Object
19 20 21 |
# File 'lib/role_core/permission_set.rb', line 19 def i18n_scope :role_core end |
.permission_class ⇒ Object
27 28 29 |
# File 'lib/role_core/permission_set.rb', line 27 def @permission_class || RoleCore. end |
.permission_class=(klass) ⇒ Object
31 32 33 34 35 36 37 |
# File 'lib/role_core/permission_set.rb', line 31 def (klass) unless klass && klass < Permission raise ArgumentError, "#{klass} should be sub-class of #{Permission}." end @permission_class = klass end |
.register_permission(name, default = false, **options, &block) ⇒ Object
53 54 55 56 57 58 |
# File 'lib/role_core/permission_set.rb', line 53 def (name, default = false, **, &block) raise ArgumentError, "`name` can't be blank" if name.blank? attribute name, :boolean, default: default [name] = .new name, , &block end |
.registered_permissions ⇒ Object
49 50 51 |
# File 'lib/role_core/permission_set.rb', line 49 def @registered_permissions ||= ActiveSupport::HashWithIndifferentAccess.new end |
.use_relative_model_naming? ⇒ Boolean
23 24 25 |
# File 'lib/role_core/permission_set.rb', line 23 def use_relative_model_naming? true end |
Instance Method Details
#computed_permissions(include_nesting: true) ⇒ Object
9 10 11 12 13 14 15 16 |
# File 'lib/role_core/permission_set.rb', line 9 def (include_nesting: true) = self.class..slice(*).values if include_nesting && nested_attributes.any? .concat nested_attributes.values.map(&:computed_permissions).flatten! end ComputedPermissions.new() end |
#permitted_permission_names ⇒ Object
5 6 7 |
# File 'lib/role_core/permission_set.rb', line 5 def attributes.select { |_, v| v }.keys end |