32 lines
628 B
Ruby
32 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
|