Module: Joinable::PermissionsAttributeWrapper
- Included in:
- DefaultPermissionSet, Membership, MembershipInvitation
- Defined in:
- lib/joinable/permissions_attribute_wrapper.rb
Overview
:nodoc:
Class Method Summary collapse
Instance Method Summary collapse
-
#allowed_permissions ⇒ Object
Returns an array of the permissions allowed by the joinable.
-
#doesnt_have_permission?(*levels) ⇒ Boolean
Returns true if none of the permissions specified by
levels
are present. - #grant_permissions(permissions_to_grant) ⇒ Object
-
#has_permission?(*levels) ⇒ Boolean
Returns true if the object has all the permissions specified by
levels
. -
#no_permissions? ⇒ Boolean
Returns true if the object has an empty permission set.
-
#only_permission_to?(*levels) ⇒ Boolean
Returns true if the object only has the permissions in
levels
. -
#permission_attributes=(permissions) ⇒ Object
Used by advanced permission forms which group permissions by their associated component or using a single check box per permission.
-
#permissions ⇒ Object
Returns an array of the permissions as symbols.
- #permissions=(permissions) ⇒ Object
- #permissions_string ⇒ Object
Dynamic Method Handling
This class handles dynamic methods through the method_missing method
#method_missing(method_name, *args) ⇒ Object (private)
Adds readers for component permission groups and single permissions
Used by advanced permission forms to determine how which options to select in the various fields. (eg. which option of f.select :labels_permissions to choose)
119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 |
# File 'lib/joinable/permissions_attribute_wrapper.rb', line 119 def method_missing(method_name, *args) # add permission_for accessors and mutators # NOTE: Don't mess with the method_name variable (e.g. change it to a string) # since upstream methods might assume it is a symbol. # NOTE: Ensure we enforce some characters before the '_permission' suffix because Rails 3 creates if respond_to?(:joinable_type) && joinable_type.present? if method_name.to_s =~ /.+_permissions/ return (method_name) elsif method_name.to_s =~ /.+_permission/ return (method_name) else super end else super end end |
Class Method Details
.included(base) ⇒ Object
7 8 9 |
# File 'lib/joinable/permissions_attribute_wrapper.rb', line 7 def self.included(base) base.before_save :verify_and_sort_permissions end |
Instance Method Details
#allowed_permissions ⇒ Object
Returns an array of the permissions allowed by the joinable
50 51 52 53 54 55 56 |
# File 'lib/joinable/permissions_attribute_wrapper.rb', line 50 def if self[:joinable_type] self[:joinable_type].constantize. else raise "Cannot get allowed access levels because permission is not attached to a permissable yet: #{inspect}" end end |
#doesnt_have_permission?(*levels) ⇒ Boolean
Returns true if none of the permissions specified by levels
are present
68 69 70 71 72 73 74 |
# File 'lib/joinable/permissions_attribute_wrapper.rb', line 68 def (*levels) if - levels == return true else return false end end |
#grant_permissions(permissions_to_grant) ⇒ Object
90 91 92 93 94 95 96 97 98 99 |
# File 'lib/joinable/permissions_attribute_wrapper.rb', line 90 def () case when String = .split(' ').collect(&:to_sym) when Symbol = [] end self. += end |
#has_permission?(*levels) ⇒ Boolean
Returns true if the object has all the permissions specified by levels
59 60 61 62 63 64 65 |
# File 'lib/joinable/permissions_attribute_wrapper.rb', line 59 def (*levels) if levels.all? { |level| .include? level.to_sym } return true else return false end end |
#no_permissions? ⇒ Boolean
Returns true if the object has an empty permission set
77 78 79 |
# File 'lib/joinable/permissions_attribute_wrapper.rb', line 77 def .empty? end |
#only_permission_to?(*levels) ⇒ Boolean
Returns true if the object only has the permissions in levels
82 83 84 85 86 87 88 |
# File 'lib/joinable/permissions_attribute_wrapper.rb', line 82 def (*levels) if - levels == [] return true else return false end end |
#permission_attributes=(permissions) ⇒ Object
Used by advanced permission forms which group permissions by their associated component or using a single check box per permission.
33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 |
# File 'lib/joinable/permissions_attribute_wrapper.rb', line 33 def () self. = [] # Reset permissions in anticipation for re-population .each do |key, value| key, value = key.dup, value.dup # Component Permissions if key.ends_with? "_permissions" (value) # Singular Permission elsif key.chomp! "_permission" (key) if value.to_i != 0 end end end |
#permissions ⇒ Object
Returns an array of the permissions as symbols
16 17 18 |
# File 'lib/joinable/permissions_attribute_wrapper.rb', line 16 def self[:permissions].collect(&:to_sym) end |
#permissions=(permissions) ⇒ Object
20 21 22 23 24 25 26 27 28 29 |
# File 'lib/joinable/permissions_attribute_wrapper.rb', line 20 def () case when String self[:permissions] = .split(' ') when Array self[:permissions] = else raise "Permissions were not passed to permissions writer in the appropriate format" end end |
#permissions_string ⇒ Object
11 12 13 |
# File 'lib/joinable/permissions_attribute_wrapper.rb', line 11 def self[:permissions].join(' ') end |