Cope with MySQL and Postgres.
authorTom Hughes <tom@compton.nu>
Thu, 16 Apr 2009 20:40:32 +0000 (20:40 +0000)
committerTom Hughes <tom@compton.nu>
Thu, 16 Apr 2009 20:40:32 +0000 (20:40 +0000)
app/models/acl.rb

index 5fb99b9e5bfd7bbfeb0f93a3c64da86ee19846f9..3ff19d35f6d8374bba709485641b3080ae62d595 100644 (file)
@@ -1,13 +1,23 @@
 class Acl < ActiveRecord::Base
   def self.find_by_address(address, options)
-    self.with_scope(:find => {:conditions => ["inet_aton(?) & netmask = address", address]}) do
+    self.with_scope(:find => {:conditions => ["#{inet_aton} & netmask = address", address]}) do
       return self.find(:first, options)
     end
   end
 
   def self.find_all_by_address(address, options)
-    self.with_scope(:find => {:conditions => ["inet_aton(?) & netmask = address", address]}) do
+    self.with_scope(:find => {:conditions => ["#{inet_aton} & netmask = address", address]}) do
       return self.find(:all, options)
     end
   end
+
+private
+
+  def self.inet_aton
+    if self.connection.adapter_name == "MySQL"
+      "inet_aton(?)"
+    else
+      "?"
+    end
+  end
 end