]> git.openstreetmap.org Git - rails.git/blobdiff - app/models/acl.rb
Merge pull request #35 from tomhughes/routing
[rails.git] / app / models / acl.rb
index 04f04d8f96d2b93ae8eb94eb0a6d36dc133a855f..e2f163ea585bf8bd5453208c7da72dc24d360548 100644 (file)
@@ -1,3 +1,21 @@
 class Acl < ActiveRecord::Base
-  scope :address, lambda { |address| where("? & netmask = address", address) }
+  def self.match(address, domain = nil)
+    if domain
+      condition = Acl.where("address >>= ? OR domain = ?", address, domain)
+    else
+      condition = Acl.where("address >>= ?", address)
+    end
+  end
+
+  def self.no_account_creation(address, domain = nil)
+    self.match(address, domain).where(:k => "no_account_creation").exists?
+  end
+
+  def self.no_note_comment(address, domain = nil)
+    self.match(address, domain).where(:k => "no_note_comment").exists?
+  end
+
+  def self.no_trace_download(address, domain = nil)
+    self.match(address, domain).where(:k => "no_trace_download").exists?
+  end
 end