2018-09-14 13:21:28 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2018-11-13 02:27:31 -05:00
|
|
|
class EncryptWebHooksColumns < ActiveRecord::Migration[4.2]
|
2018-09-14 13:21:28 -04:00
|
|
|
include Gitlab::Database::MigrationHelpers
|
|
|
|
|
|
|
|
DOWNTIME = false
|
|
|
|
|
|
|
|
BATCH_SIZE = 10000
|
|
|
|
RANGE_SIZE = 100
|
|
|
|
MIGRATION = 'EncryptColumns'
|
|
|
|
COLUMNS = [:token, :url]
|
|
|
|
|
|
|
|
WebHook = ::Gitlab::BackgroundMigration::Models::EncryptColumns::WebHook
|
|
|
|
|
|
|
|
disable_ddl_transaction!
|
|
|
|
|
|
|
|
def up
|
|
|
|
WebHook.each_batch(of: BATCH_SIZE) do |relation, index|
|
|
|
|
delay = index * 2.minutes
|
|
|
|
|
|
|
|
relation.each_batch(of: RANGE_SIZE) do |relation|
|
|
|
|
range = relation.pluck('MIN(id)', 'MAX(id)').first
|
|
|
|
args = [WebHook, COLUMNS, *range]
|
|
|
|
|
|
|
|
BackgroundMigrationWorker.perform_in(delay, MIGRATION, args)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def down
|
|
|
|
# noop
|
|
|
|
end
|
|
|
|
end
|