HEX
Server: Apache/2.4.41 (Ubuntu)
System: Linux vmi1674223.contaboserver.net 5.4.0-182-generic #202-Ubuntu SMP Fri Apr 26 12:29:36 UTC 2024 x86_64
User: root (0)
PHP: 7.4.3-4ubuntu2.22
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: //opt/openproject/db/migrate/20190502102512_ensure_postgres_index_names.rb
class EnsurePostgresIndexNames < ActiveRecord::Migration[5.2]
  disable_ddl_transaction!

  def up
    sql = <<~SQL
      SELECT
        FORMAT('%s_pkey', table_name) as new_name,
        constraint_name as old_name
      FROM information_schema.table_constraints
      WHERE UPPER(constraint_type) = 'PRIMARY KEY'
      AND constraint_schema IN (select current_schema())
      AND constraint_name != FORMAT('%s_pkey', table_name)
      ORDER BY table_name;
    SQL

    ActiveRecord::Base.connection.execute(sql).each do |entry|
      old_name = entry['old_name']
      new_name = entry['new_name']

      ActiveRecord::Base.transaction do
        execute %(ALTER INDEX "#{old_name}" RENAME TO #{new_name};)
      rescue StandardError => e
        warn "Failed to rename index #{old_name} to #{new_name}: #{e.message}. Skipping"
      end
    end
  end

  def down
    # Nothing to do
  end
end