Class: Ibrain::RoleConfiguration

Inherits:
Object
  • Object
show all
Defined in:
lib/ibrain/core/role_configuration.rb

Overview

A class responsible for associating Role with a list of permission sets.

Examples:

Adding order, data, and user display to customer service users.

Ibrain::RoleConfiguration.configure do |config|
  config.assign_permissions :customer_service, [
    Ibrain::PermissionSets::UserDisplay,
  ]
end

See Also:

Defined Under Namespace

Classes: Role

Instance Attribute Summary collapse

Instance Method Summary collapse

Instance Attribute Details

#rolesObject

Returns the value of attribute roles.



30
31
32
# File 'lib/ibrain/core/role_configuration.rb', line 30

def roles
  @roles
end

Instance Method Details

#activate_permissions!(ability, user) ⇒ Object

Given a CanCan::Ability, and a user, determine what permissions sets can be activated on the ability, then activate them.

This performs can/cannot declarations on the ability, and can modify its internal permissions.

Parameters:

  • ability (CanCan::Ability)

    the ability to invoke declarations on

  • user (#roles)

    the user that holds the roles association.



40
41
42
43
44
45
46
47
48
49
50
51
# File 'lib/ibrain/core/role_configuration.rb', line 40

def activate_permissions!(ability, user)
  ibrain_roles = ['default'] | user.roles.map(&:name)
  applicable_permissions = Set.new

  ibrain_roles.each do |role_name|
    applicable_permissions |= roles[role_name].permission_sets
  end

  applicable_permissions.each do |permission_set|
    permission_set.new(ability).activate!
  end
end

#assign_permissions(role_name, permission_sets) ⇒ Object

Assign permission sets for a Ibrain::Role that has the name of role_name

Parameters:



65
66
67
68
69
70
# File 'lib/ibrain/core/role_configuration.rb', line 65

def assign_permissions(role_name, permission_sets)
  name = role_name.to_s

  roles[name].permission_sets.concat permission_sets
  roles[name]
end