~cytrogen/masto-fe

8bf9bd5ac8497b26b18434643b72ca2203e732a3 — Eugen Rochko 2 years ago 75e2873
[Glitch] Fix n+1 query in settings migration

Port 0ad2413b35287958f59073a5b63aecc659a64d98 to glitch-soc

Signed-off-by: Claire <claire.github-309c@sitedethib.com>
1 files changed, 17 insertions(+), 14 deletions(-)

M db/migrate/20230215074424_move_glitch_user_settings.rb
M db/migrate/20230215074424_move_glitch_user_settings.rb => db/migrate/20230215074424_move_glitch_user_settings.rb +17 -14
@@ 31,27 31,30 @@ class MoveGlitchUserSettings < ActiveRecord::Migration[6.1]
  end

  def up
    User.find_each do |user|
      previous_settings = LegacySetting.where(thing_type: 'User', thing_id: user.id).index_by(&:var)
    User.find_in_batches do |users|
      previous_settings_for_batch = LegacySetting.where(thing_type: 'User', thing_id: users.map(&:id)).group_by(&:thing_id)

      user_settings = Oj.load(user.settings || '{}')
      user_settings.delete('theme')
      users.each do |user|
        previous_settings = previous_settings_for_batch[user.id]&.index_by(&:var) || {}
        user_settings = Oj.load(user.settings || '{}')
        user_settings.delete('theme')

      MAPPING.each do |legacy_key, new_key|
        value = previous_settings[legacy_key]&.value
        MAPPING.each do |legacy_key, new_key|
          value = previous_settings[legacy_key]&.value

        next if value.blank?
          next if value.blank?

        if value.is_a?(Hash)
          value.each do |nested_key, nested_value|
            user_settings[MAPPING[legacy_key][nested_key.to_sym]] = nested_value
          if value.is_a?(Hash)
            value.each do |nested_key, nested_value|
              user_settings[MAPPING[legacy_key][nested_key.to_sym]] = nested_value
            end
          else
            user_settings[new_key] = value
          end
        else
          user_settings[new_key] = value
        end
      end

      user.update_column('settings', Oj.dump(user_settings)) # rubocop:disable Rails/SkipsModelValidations
        user.update_column('settings', Oj.dump(user_settings)) # rubocop:disable Rails/SkipsModelValidations
      end
    end
  end