Sha256: 7353a167369f2709e15db8a51d7c07c56cbe450639b49af60385f340c4ef5c53
Contents?: true
Size: 1.21 KB
Versions: 2
Compression:
Stored size: 1.21 KB
Contents
module Authority class Authorizer # The base Authorizer class, from which all the authorizers in an app will # descend. Provides the authorizer with both class and instance methods # like `updatable_by?(user)`. # Exactly which methods get defined is determined from `config.abilities`; # the class is evaluated after any user-supplied config block is run # in order to make that possible. attr_reader :resource def initialize(resource) @resource = resource end # Each instance method simply calls the corresponding class method Authority.adjectives.each do |adjective| class_eval <<-RUBY, __FILE__, __LINE__ + 1 def #{adjective}_by?(user) self.class.#{adjective}_by?(user) end RUBY end # Each class method simply calls the `default` method Authority.adjectives.each do |adjective| class_eval <<-RUBY, __FILE__, __LINE__ + 1 def self.#{adjective}_by?(user) default(:#{adjective}, user) end RUBY end # Whitelisting approach: anything not specified will be forbidden def self.default(adjective, user) false end end class NoAuthorizerError < StandardError ; end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
authority-2.0.1 | lib/authority/authorizer.rb |
authority-2.0.0 | lib/authority/authorizer.rb |