]> git.openstreetmap.org Git - rails.git/blobdiff - app/models/acl.rb
Merge remote-tracking branch 'openstreetmap/pull/1451'
[rails.git] / app / models / acl.rb
index e19c6988b4100e59f61e5a5c5a503c9e4c97b4f0..529ccbe3bc26640dfb057674aca5b433ec1582d3 100644 (file)
@@ -1,9 +1,23 @@
 class Acl < ActiveRecord::Base
+  validates :k, :presence => true
+
   def self.match(address, domain = nil)
     if domain
-      condition = Acl.where("address >> ? OR domain = ?", address, domain)
+      Acl.where("address >>= ? OR domain = ?", address, domain)
     else
-      condition = Acl.where("address >> ?", address)
+      Acl.where("address >>= ?", address)
     end
   end
+
+  def self.no_account_creation(address, domain = nil)
+    match(address, domain).where(:k => "no_account_creation").exists?
+  end
+
+  def self.no_note_comment(address, domain = nil)
+    match(address, domain).where(:k => "no_note_comment").exists?
+  end
+
+  def self.no_trace_download(address, domain = nil)
+    match(address, domain).where(:k => "no_trace_download").exists?
+  end
 end