mirror of
https://github.com/mastodon/mastodon.git
synced 2024-12-22 18:45:41 +01:00
Always remove setting keys in legacy user settings migrations (#33196)
This commit is contained in:
parent
25387dc423
commit
fbcd14ff7e
2 changed files with 32 additions and 0 deletions
|
@ -8,6 +8,22 @@ class RemoveLegacyUserSettingsData < ActiveRecord::Migration[7.2]
|
|||
thing_type IS NOT NULL
|
||||
AND thing_id IS NOT NULL
|
||||
SQL
|
||||
|
||||
# When running these migrations on mastodon.social, we saw 'notification_emails'
|
||||
# and 'interactions' records that were not associated to a user and caused a
|
||||
# migration issue.
|
||||
# While I have not been able to pinpoint the exact cause of the issue, it is likely
|
||||
# related to the settings system changes made in b11fdc3ae3f90731c01149a5a36dc64e065d4ea2.
|
||||
# So, delete a few user settings that should already have been deleted.
|
||||
connection.execute(<<~SQL.squish)
|
||||
DELETE FROM settings
|
||||
WHERE var IN (
|
||||
'notification_emails', 'interactions', 'boost_modal', 'auto_play_gif',
|
||||
'delete_modal', 'system_font_ui', 'default_sensitive', 'unfollow_modal',
|
||||
'reduce_motion', 'display_sensitive_media', 'hide_network', 'expand_spoilers',
|
||||
'display_media', 'aggregate_reblogs', 'show_application', 'advanced_layout',
|
||||
'use_blurhash', 'use_pending_items')
|
||||
SQL
|
||||
end
|
||||
|
||||
def down
|
||||
|
|
|
@ -15,6 +15,22 @@ class RemoveLegacyUserSettingsColumns < ActiveRecord::Migration[7.2]
|
|||
AND thing_id IS NOT NULL
|
||||
SQL
|
||||
|
||||
# When running these migrations on mastodon.social, we saw 'notification_emails'
|
||||
# and 'interactions' records that were not associated to a user and caused a
|
||||
# migration issue.
|
||||
# While I have not been able to pinpoint the exact cause of the issue, it is likely
|
||||
# related to the settings system changes made in b11fdc3ae3f90731c01149a5a36dc64e065d4ea2.
|
||||
# So, delete a few user settings that should already have been deleted.
|
||||
connection.execute(<<~SQL.squish)
|
||||
DELETE FROM settings
|
||||
WHERE var IN (
|
||||
'notification_emails', 'interactions', 'boost_modal', 'auto_play_gif',
|
||||
'delete_modal', 'system_font_ui', 'default_sensitive', 'unfollow_modal',
|
||||
'reduce_motion', 'display_sensitive_media', 'hide_network', 'expand_spoilers',
|
||||
'display_media', 'aggregate_reblogs', 'show_application', 'advanced_layout',
|
||||
'use_blurhash', 'use_pending_items')
|
||||
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
|
||||
|
||||
|
|
Loading…
Reference in a new issue