]> git.openstreetmap.org Git - rails.git/blobdiff - app/models/acl.rb
Merge remote-tracking branch 'openstreetmap/pull/1122'
[rails.git] / app / models / acl.rb
index dbcb38993b6b905f0e5be691147387488c6f5023..8bb4ae4b9dd8ebf294419aa141ebeaea5f4d7994 100644 (file)
@@ -1,13 +1,21 @@
 class Acl < ActiveRecord::Base
-  def self.find_by_address(address, options)
-    self.with_scope(:find => {:conditions => ["? & netmask = address", address]}) do
-      return self.find(:first, options)
+  def self.match(address, domain = nil)
+    if domain
+      Acl.where("address >>= ? OR domain = ?", address, domain)
+    else
+      Acl.where("address >>= ?", address)
     end
   end
 
-  def self.find_all_by_address(address, options)
-    self.with_scope(:find => {:conditions => ["? & netmask = address", address]}) do
-      return self.find(:all, options)
-    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