Sha256: eefbb4907b493e03694c635d1749ad069d654c7233f1a0c7908dcc808fd21e04
Contents?: true
Size: 1.23 KB
Versions: 1
Compression:
Stored size: 1.23 KB
Contents
module Surrounded module AccessControl def self.extended(base) base.send(:include, AccessMethods) base.const_set(:'AccessError', Class.new(StandardError)) end private def disallow(*names, &block) names.map do |name| define_method("disallow_#{name}?", &block) end end def redo_method(name) class_eval %{ def #{name} begin apply_roles if __apply_role_policy == :trigger method_restrictor = "disallow_#{name}?" if self.respond_to?(method_restrictor, true) && self.send(method_restrictor) raise ::Surrounded::Context::AccessError.new("access to #{self.name}##{name} is not allowed") end self.send("__trigger_#{name}") ensure remove_roles if __apply_role_policy == :trigger end end } end module AccessMethods def all_triggers self.class.triggers end def triggers all_triggers.select {|name| method_restrictor = "disallow_#{name}?" !self.respond_to?(method_restrictor, true) || !self.send(method_restrictor) }.to_set end end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
surrounded-0.7.1 | lib/surrounded/access_control.rb |