diff options
author | GitLab Bot <gitlab-bot@gitlab.com> | 2020-04-01 15:07:45 +0000 |
---|---|---|
committer | GitLab Bot <gitlab-bot@gitlab.com> | 2020-04-01 15:07:45 +0000 |
commit | 1219a9dce91f4edbc135dfc08299b4122b4825a8 (patch) | |
tree | e7d12a55d75a2d56e60d9527bef3724e3578866d /lib | |
parent | 1a0d6dbdc2ac3047f4953a359ef27ba6e26074ae (diff) | |
download | gitlab-ce-1219a9dce91f4edbc135dfc08299b4122b4825a8.tar.gz |
Add latest changes from gitlab-org/gitlab@master
Diffstat (limited to 'lib')
-rw-r--r-- | lib/gitlab/background_migration/populate_user_highest_roles_table.rb | 56 |
1 files changed, 56 insertions, 0 deletions
diff --git a/lib/gitlab/background_migration/populate_user_highest_roles_table.rb b/lib/gitlab/background_migration/populate_user_highest_roles_table.rb new file mode 100644 index 00000000000..0c9e15b5a80 --- /dev/null +++ b/lib/gitlab/background_migration/populate_user_highest_roles_table.rb @@ -0,0 +1,56 @@ +# frozen_string_literal: true + +module Gitlab + module BackgroundMigration + # This background migration creates records on user_highest_roles according to + # the given user IDs range. IDs will load users with a left outer joins to + # have a record for users without a Group or Project. One INSERT per ID is + # issued. + class PopulateUserHighestRolesTable + BATCH_SIZE = 100 + + # rubocop:disable Style/Documentation + class User < ActiveRecord::Base + self.table_name = 'users' + + scope :active, -> { + where(state: 'active', user_type: nil, bot_type: nil) + .where('ghost IS NOT TRUE') + } + end + + def perform(from_id, to_id) + (from_id..to_id).each_slice(BATCH_SIZE) do |ids| + execute( + <<-EOF + INSERT INTO user_highest_roles (updated_at, user_id, highest_access_level) + #{select_sql(from_id, to_id)} + ON CONFLICT (user_id) DO + UPDATE SET highest_access_level = EXCLUDED.highest_access_level + EOF + ) + end + end + + private + + def select_sql(from_id, to_id) + User + .select('NOW() as updated_at, users.id, MAX(access_level) AS highest_access_level') + .joins('LEFT OUTER JOIN members ON members.user_id = users.id AND members.requested_at IS NULL') + .where(users: { id: active_user_ids(from_id, to_id) }) + .group('users.id') + .to_sql + end + + def active_user_ids(from_id, to_id) + User.active.where(users: { id: from_id..to_id }).pluck(:id) + end + + def execute(sql) + @connection ||= ActiveRecord::Base.connection + @connection.execute(sql) + end + end + end +end |