summaryrefslogtreecommitdiff
path: root/db/post_migrate/20220318111040_add_indexes_for_primary_email_second_cleanup_migration.rb
blob: 5dcb99b36b69f12cf0bb52678c335a67a3e998f7 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
# frozen_string_literal: true

class AddIndexesForPrimaryEmailSecondCleanupMigration < Gitlab::Database::Migration[1.0]
  USERS_INDEX = :index_users_on_id_for_primary_email_migration
  EMAIL_INDEX = :index_emails_on_email_user_id

  disable_ddl_transaction!

  def up
    unless index_exists_by_name?(:users, USERS_INDEX)

      disable_statement_timeout do
        execute <<~SQL
        CREATE INDEX CONCURRENTLY #{USERS_INDEX}
        ON users (id) INCLUDE (email, confirmed_at)
        WHERE confirmed_at IS NOT NULL
        SQL
      end
    end

    add_concurrent_index :emails, [:email, :user_id], name: EMAIL_INDEX
  end

  def down
    remove_concurrent_index_by_name :users, USERS_INDEX
    remove_concurrent_index_by_name :emails, EMAIL_INDEX
  end
end