-class Acl < ActiveRecord::Base
- scope :address, lambda { |address| where("#{inet_aton} & netmask = address", address) }
+# == Schema Information
+#
+# Table name: acls
+#
+# id :bigint(8) not null, primary key
+# address :inet
+# k :string not null
+# v :string
+# domain :string
+#
+# Indexes
+#
+# acls_k_idx (k)
+# index_acls_on_address (address) USING gist
+# index_acls_on_domain (domain)
+#
-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