Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'db/migrate/20230127151529_add_project_pointer_for_analytics_dashboard.rb')
-rw-r--r--db/migrate/20230127151529_add_project_pointer_for_analytics_dashboard.rb29
1 files changed, 29 insertions, 0 deletions
diff --git a/db/migrate/20230127151529_add_project_pointer_for_analytics_dashboard.rb b/db/migrate/20230127151529_add_project_pointer_for_analytics_dashboard.rb
new file mode 100644
index 00000000000..bbfb0c90596
--- /dev/null
+++ b/db/migrate/20230127151529_add_project_pointer_for_analytics_dashboard.rb
@@ -0,0 +1,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