summaryrefslogtreecommitdiff
path: root/lib/gitlab/background_migration/nullify_creator_id_column_of_orphaned_projects.rb
diff options
context:
space:
mode:
Diffstat (limited to 'lib/gitlab/background_migration/nullify_creator_id_column_of_orphaned_projects.rb')
-rw-r--r--lib/gitlab/background_migration/nullify_creator_id_column_of_orphaned_projects.rb24
1 files changed, 24 insertions, 0 deletions
diff --git a/lib/gitlab/background_migration/nullify_creator_id_column_of_orphaned_projects.rb b/lib/gitlab/background_migration/nullify_creator_id_column_of_orphaned_projects.rb
new file mode 100644
index 00000000000..592ef3220ff
--- /dev/null
+++ b/lib/gitlab/background_migration/nullify_creator_id_column_of_orphaned_projects.rb
@@ -0,0 +1,24 @@
+# frozen_string_literal: true
+
+module Gitlab
+ module BackgroundMigration
+ # A job to nullify `projects.creator_id` column of projects who creator
+ # does not exist in `users` table anymore.
+ class NullifyCreatorIdColumnOfOrphanedProjects < BatchedMigrationJob
+ scope_to ->(relation) do
+ relation.where.not(creator_id: nil)
+ .joins('LEFT OUTER JOIN users ON users.id = projects.creator_id')
+ .where(users: { id: nil })
+ end
+
+ operation_name :update_all
+ feature_category :projects
+
+ def perform
+ each_sub_batch do |sub_batch|
+ sub_batch.update_all(creator_id: nil)
+ end
+ end
+ end
+ end
+end