Class: ReUser::Role
- Inherits:
-
Object
- Object
- ReUser::Role
- Defined in:
- lib/reuser/role.rb
Instance Attribute Summary collapse
-
#name ⇒ Object
readonly
Returns the value of attribute name.
Instance Method Summary collapse
- #can(*permissions) ⇒ Object
- #can?(permission) ⇒ Boolean
- #could(permission, &block) ⇒ Object
- #could?(permission, block_args) ⇒ Boolean
-
#initialize(name, permissions = []) ⇒ Role
constructor
A new instance of Role.
- #permissions ⇒ Object
Constructor Details
#initialize(name, permissions = []) ⇒ Role
Returns a new instance of Role.
9 10 11 12 13 |
# File 'lib/reuser/role.rb', line 9 def initialize name, =[] @name = name @permissions = {} self.can * end |
Instance Attribute Details
#name ⇒ Object (readonly)
Returns the value of attribute name.
3 4 5 |
# File 'lib/reuser/role.rb', line 3 def name @name end |
Instance Method Details
#can(*permissions) ⇒ Object
15 16 17 18 19 |
# File 'lib/reuser/role.rb', line 15 def can * .each do || @permissions[] = lambda {|*args| true } end end |
#can?(permission) ⇒ Boolean
21 22 23 |
# File 'lib/reuser/role.rb', line 21 def can? @permissions[].is_a? Proc end |
#could(permission, &block) ⇒ Object
25 26 27 28 |
# File 'lib/reuser/role.rb', line 25 def could , &block raise "#could requires a block" unless block_given? @permissions[] = block end |
#could?(permission, block_args) ⇒ Boolean
30 31 32 |
# File 'lib/reuser/role.rb', line 30 def could? , block_args @permissions[].call(block_args) end |
#permissions ⇒ Object
5 6 7 |
# File 'lib/reuser/role.rb', line 5 def @permissions.keys end |