23 lines
489 B
Ruby
23 lines
489 B
Ruby
|
require 'ipaddr'
|
||
|
|
||
|
class ChangeIpToInetInViews < ActiveRecord::Migration
|
||
|
def up
|
||
|
table = :views
|
||
|
add_column table, :ip_address, :inet
|
||
|
|
||
|
execute "UPDATE views SET ip_address = inet(
|
||
|
(ip >> 24 & 255) || '.' ||
|
||
|
(ip >> 16 & 255) || '.' ||
|
||
|
(ip >> 8 & 255) || '.' ||
|
||
|
(ip >> 0 & 255)
|
||
|
);"
|
||
|
|
||
|
change_column table, :ip_address, :inet, { :null => false }
|
||
|
remove_column table, :ip
|
||
|
end
|
||
|
|
||
|
def down
|
||
|
raise ActiveRecord::IrreversibleMigration
|
||
|
end
|
||
|
end
|