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
. -
#method_missing(method_name, *args, &block) ⇒ Object
Adds readers for component permission groups and single permissions.
-
#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
- #respond_to?(method_name, include_private = false) ⇒ Boolean
Dynamic Method Handling
This class handles dynamic methods through the method_missing method
#method_missing(method_name, *args, &block) ⇒ Object
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)
105 106 107 108 109 110 111 112 113 114 115 |
# File 'lib/joinable/permissions_attribute_wrapper.rb', line 105 def method_missing(method_name, *args, &block) # NOTE: As of Rails 4, respond_to? must be checked inside the case statement otherwise it breaks regular AR attribute accessors case method_name.to_s when /.+_permissions/ return (method_name) if respond_to?(:joinable_type) && joinable_type.present? when /.+_permission/ return (method_name) if respond_to?(:joinable_type) && joinable_type.present? end super 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 Array.wrap(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, Symbol self[:permissions] = .to_s.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 |
#respond_to?(method_name, include_private = false) ⇒ Boolean
117 118 119 120 121 122 123 124 |
# File 'lib/joinable/permissions_attribute_wrapper.rb', line 117 def respond_to?(method_name, include_private = false) case method_name.to_s when /.+_permissions?/ return true if respond_to?(:joinable_type) && joinable_type.present? end super end |