X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/5449cf4adcc1fad4b9f43426e6d3e4a8f65e6fbb..377391e8bb4294a539d5363a20af51243877243c:/app/models/acl.rb?ds=sidebyside diff --git a/app/models/acl.rb b/app/models/acl.rb index 3ff19d35f..aa503f40c 100644 --- a/app/models/acl.rb +++ b/app/models/acl.rb @@ -1,23 +1,55 @@ -class Acl < ActiveRecord::Base - def self.find_by_address(address, options) - self.with_scope(:find => {:conditions => ["#{inet_aton} & netmask = address", address]}) do - return self.find(:first, options) +# == Schema Information +# +# Table name: acls +# +# id :bigint(8) not null, primary key +# address :inet +# k :string not null +# v :string +# domain :string +# mx :string +# +# Indexes +# +# acls_k_idx (k) +# index_acls_on_address (address) USING gist +# index_acls_on_domain (domain) +# index_acls_on_mx (mx) +# + +class Acl < ApplicationRecord + validates :k, :presence => true + + def self.match(address, options = {}) + acls = Acl.where("address >>= ?", address) + + if options[:domain] + labels = options[:domain].split(".") + + until labels.empty? + acls = acls.or(Acl.where(:domain => labels.join("."))) + labels.shift + end end + + acls = acls.or(Acl.where(:mx => options[:mx])) if options[:mx] + + acls end - def self.find_all_by_address(address, options) - self.with_scope(:find => {:conditions => ["#{inet_aton} & netmask = address", address]}) do - return self.find(:all, options) - end + def self.no_account_creation(address, options = {}) + match(address, options).exists?(:k => "no_account_creation") end -private + def self.allow_account_creation(address, options = {}) + match(address, options).exists?(:k => "allow_account_creation") + end - def self.inet_aton - if self.connection.adapter_name == "MySQL" - "inet_aton(?)" - else - "?" - end + def self.no_note_comment(address, domain = nil) + match(address, :domain => domain).exists?(:k => "no_note_comment") + end + + def self.no_trace_download(address, domain = nil) + match(address, :domain => domain).exists?(:k => "no_trace_download") end end