module RoleAuthorization module Roles module Role def self.included(base) base.send :extend, ClassMethods base.send :include, InstanceMethods base.class_eval do validates_uniqueness_of :name serialize :user_ids end end module InstanceMethods def scope_with(scope) if scope.blank? || scope.is_a?(Symbol) || scope.is_a?(String) || scope.is_a?(Integer) scope || :all else scope.id end end def users(scope = nil) RoleAuthorization::Roles::Manager.user_klass.where(:id => user_ids[scope_with(scope)]).all end def add_user(user_id, scope = nil) unserialized_user_ids = self.user_ids unserialized_user_ids ||= Hash.new if scope.nil? || scope.is_a?(Symbol) || scope.is_a?(String) || scope.is_a?(Class) unserialized_user_ids[scope_with(scope)] ||= Array.new unserialized_user_ids[scope_with(scope)] << user_id unserialized_user_ids[scope_with(scope)].uniq! else unserialized_user_ids[scope_with(scope)] ||= Array.new unserialized_user_ids[scope_with(scope)] << user_id unserialized_user_ids[scope_with(scope)].uniq! end self.user_ids = unserialized_user_ids save end def remove_user(user_id, scope = nil) unserialized_user_ids = self.user_ids unserialized_user_ids ||= Hash.new if scope.nil? || scope.is_a?(Symbol) || scope.is_a?(String) || scope.is_a?(Class) unserialized_user_ids[scope_with(scope)] ||= Array.new unserialized_user_ids[scope_with(scope)].delete(user_id) else unserialized_user_ids[scope_with(scope)] ||= Array.new unserialized_user_ids[scope_with(scope)].delete(user_id) end self.user_ids = unserialized_user_ids save end end module ClassMethods def group(group_name) RoleAuthorization::Roles.manager.groups[group_name.to_sym] end end end end end