mirror of https://github.com/mastodon/mastodon
31 lines
940 B
Ruby
31 lines
940 B
Ruby
|
# frozen_string_literal: true
|
||
|
|
||
|
class RemoveLegacyUserSettingsColumns < ActiveRecord::Migration[7.2]
|
||
|
disable_ddl_transaction!
|
||
|
|
||
|
def up
|
||
|
# In normal usage this should not find anything to delete
|
||
|
# Deletion here is already done in RemoveLegacyUserSettingsData migration
|
||
|
# and no data like this should be created from app at this point
|
||
|
# Deleting again out of caution
|
||
|
connection.execute(<<~SQL.squish)
|
||
|
DELETE FROM settings
|
||
|
WHERE
|
||
|
thing_type IS NOT NULL
|
||
|
AND thing_id IS NOT NULL
|
||
|
SQL
|
||
|
|
||
|
add_index :settings, :var, unique: true, algorithm: :concurrently
|
||
|
remove_index :settings, [:thing_type, :thing_id, :var], name: :index_settings_on_thing_type_and_thing_id_and_var, unique: true
|
||
|
|
||
|
safety_assured do
|
||
|
remove_column :settings, :thing_type, :string
|
||
|
remove_column :settings, :thing_id, :bigint
|
||
|
end
|
||
|
end
|
||
|
|
||
|
def down
|
||
|
raise ActiveRecord::IrreversibleMigration
|
||
|
end
|
||
|
end
|