]> git.openstreetmap.org Git - rails.git/blobdiff - app/models/acl.rb
Bump eslint from 8.52.0 to 8.53.0
[rails.git] / app / models / acl.rb
index 3ff19d35f6d8374bba709485641b3080ae62d595..a65c3a35ad68977fe1a1da5f6296c280006145a0 100644 (file)
@@ -1,23 +1,51 @@
-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.no_note_comment(address, domain = nil)
+    match(address, :domain => domain).exists?(:k => "no_note_comment")
+  end
 
-  def self.inet_aton
-    if self.connection.adapter_name == "MySQL"
-      "inet_aton(?)"
-    else
-      "?"
-    end
+  def self.no_trace_download(address, domain = nil)
+    match(address, :domain => domain).exists?(:k => "no_trace_download")
   end
 end