31 lines
628 B
Ruby
31 lines
628 B
Ruby
# frozen_string_literal: true
|
|
|
|
class AuthorizedKeysWorker
|
|
include ApplicationWorker
|
|
|
|
PERMITTED_ACTIONS = %w[add_key remove_key].freeze
|
|
|
|
feature_category :source_code_management
|
|
urgency :high
|
|
weight 2
|
|
idempotent!
|
|
|
|
def perform(action, *args)
|
|
return unless Gitlab::CurrentSettings.authorized_keys_enabled?
|
|
|
|
case action.to_s
|
|
when 'add_key'
|
|
authorized_keys.add_key(*args)
|
|
when 'remove_key'
|
|
authorized_keys.remove_key(*args)
|
|
else
|
|
raise "Unknown action: #{action.inspect}"
|
|
end
|
|
end
|
|
|
|
private
|
|
|
|
def authorized_keys
|
|
@authorized_keys ||= Gitlab::AuthorizedKeys.new
|
|
end
|
|
end
|