Sha256: 42b726c7342c86a419242d6736dc097f7e5d3d3a82575e36b5713caa87cd558c
Contents?: true
Size: 1.79 KB
Versions: 2
Compression:
Stored size: 1.79 KB
Contents
# frozen_string_literal: true require 'proxes/db' require 'proxes/models/permission' require 'proxes/services/logger' require 'proxes/helpers/indices' module ProxES class RequestPolicy include Helpers::Indices attr_reader :user, :record def initialize(user, record) @user = user @record = record end def method_missing(method_sym, *arguments, &block) if method_sym.to_s[-1] == '?' return false if user.nil? if record.indices? return true if index_allowed? else return true if action_allowed? method_sym[0..-2].upcase end false else super end end def index_allowed? patterns = Permission.for_user(user, 'INDEX').map do |permission| permission.pattern.gsub(/\{user.(.*)\}/) { |match| user.send(Regexp.last_match[1].to_sym) } end return filter(record.index, patterns).count.positive? end def action_allowed?(action) # Give me all the user's permissions that match the verb Permission.for_user(user, action).each do |permission| return true if record.path =~ %r{#{permission.pattern}} end false end def respond_to_missing?(name, _include_private = false) name[-1] == '?' end def logger @logger ||= ProxES::Services::Logger.instance end class Scope include Helpers::Indices attr_reader :user, :scope def initialize(user, scope) @user = user @scope = scope end def logger @logger ||= ProxES::Services::Logger.instance end end end end require 'proxes/policies/request/root_policy' require 'proxes/policies/request/stats_policy' require 'proxes/policies/request/search_policy' require 'proxes/policies/request/snapshot_policy'
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
proxes-0.4.0 | lib/proxes/policies/request_policy.rb |
proxes-0.3.6 | lib/proxes/policies/request_policy.rb |