]> git.openstreetmap.org Git - rails.git/blobdiff - app/models/acl.rb
Merge remote-tracking branch 'upstream/pull/2014'
[rails.git] / app / models / acl.rb
index 94e37734353ec79dd453a75a72cdd06a6f183185..095bad89b942d07e62ee74b18e999100905c456b 100644 (file)
@@ -1,13 +1,38 @@
-class Acl < ActiveRecord::Base
-  scope :address, lambda { |address| where("#{inet_aton} & netmask = address", address) }
+# == Schema Information
+#
+# Table name: acls
+#
+#  id      :integer          not null, primary key
+#  address :inet
+#  k       :string           not null
+#  v       :string
+#  domain  :string
+#
+# Indexes
+#
+#  acls_k_idx  (k)
+#
 
-private
+class Acl < ActiveRecord::Base
+  validates :k, :presence => true
 
-  def self.inet_aton
-    if self.connection.adapter_name == "MySQL"
-      "inet_aton(?)"
+  def self.match(address, domain = nil)
+    if domain
+      Acl.where("address >>= ? OR domain = ?", address, domain)
     else
-      "?"
+      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