summaryrefslogtreecommitdiff
path: root/db/migrate/20230127151529_add_project_pointer_for_analytics_dashboard.rb
blob: bbfb0c905968e369aaa346de8fd97cb4a5cd27cc (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
29
# frozen_string_literal: true

class AddProjectPointerForAnalyticsDashboard < Gitlab::Database::Migration[2.1]
  disable_ddl_transaction!

  def up
    change_column_null :analytics_dashboards_pointers, :project_id, true
    change_column_null :analytics_dashboards_pointers, :namespace_id, true

    unless column_exists?(:analytics_dashboards_pointers, :target_project_id)
      add_column :analytics_dashboards_pointers, :target_project_id, :bigint
    end

    add_concurrent_foreign_key :analytics_dashboards_pointers, :projects,
                               column: :target_project_id,
                               on_delete: :cascade

    add_concurrent_index :analytics_dashboards_pointers, :target_project_id
  end

  def down
    change_column_null :analytics_dashboards_pointers, :project_id, false
    change_column_null :analytics_dashboards_pointers, :namespace_id, false

    return unless column_exists?(:analytics_dashboards_pointers, :target_project_id)

    remove_column :analytics_dashboards_pointers, :target_project_id
  end
end