Commit f980d8f5 authored by Michael Kozono's avatar Michael Kozono

Add list-key-ids command

parent 7e41e378
...@@ -39,6 +39,8 @@ class GitlabKeys ...@@ -39,6 +39,8 @@ class GitlabKeys
rm_key rm_key
when 'list-keys'; when 'list-keys';
list_keys list_keys
when 'list-key-ids';
list_key_ids
when 'clear'; when 'clear';
clear clear
when 'check-permissions'; when 'check-permissions';
...@@ -75,6 +77,17 @@ class GitlabKeys ...@@ -75,6 +77,17 @@ class GitlabKeys
keys keys
end end
def list_key_ids
$logger.info 'Listing all key IDs'
open_auth_file('r') do |f|
f.each_line do |line|
matchd = line.match(/key-(\d+)/)
next unless matchd
puts matchd[1]
end
end
end
def batch_add_keys def batch_add_keys
lock(300) do # Allow 300 seconds (5 minutes) for batch_add_keys lock(300) do # Allow 300 seconds (5 minutes) for batch_add_keys
open_auth_file('a') do |file| open_auth_file('a') do |file|
......
...@@ -80,6 +80,23 @@ describe GitlabKeys do ...@@ -80,6 +80,23 @@ describe GitlabKeys do
end end
end end
describe :list_key_ids do
let(:gitlab_keys) { build_gitlab_keys('list-key-ids') }
before do
create_authorized_keys_fixture(
existing_content:
"key-1\tssh-dsa AAA\nkey-2\tssh-rsa BBB\nkey-3\tssh-rsa CCC\nkey-9000\tssh-rsa DDD\n"
)
end
it 'outputs the key IDs, separated by newlines' do
output = capture_stdout do
gitlab_keys.send(:list_key_ids)
end
output.should match "1\n2\n3\n9000"
end
end
describe :batch_add_keys do describe :batch_add_keys do
let(:gitlab_keys) { build_gitlab_keys('batch-add-keys') } let(:gitlab_keys) { build_gitlab_keys('batch-add-keys') }
let(:fake_stdin) { StringIO.new("key-12\tssh-dsa ASDFASGADG\nkey-123\tssh-rsa GFDGDFSGSDFG\n", 'r') } let(:fake_stdin) { StringIO.new("key-12\tssh-dsa ASDFASGADG\nkey-123\tssh-rsa GFDGDFSGSDFG\n", 'r') }
...@@ -288,9 +305,9 @@ describe GitlabKeys do ...@@ -288,9 +305,9 @@ describe GitlabKeys do
end end
end end
def create_authorized_keys_fixture def create_authorized_keys_fixture(existing_content: 'existing content')
FileUtils.mkdir_p(File.dirname(tmp_authorized_keys_path)) FileUtils.mkdir_p(File.dirname(tmp_authorized_keys_path))
open(tmp_authorized_keys_path, 'w') { |file| file.puts('existing content') } open(tmp_authorized_keys_path, 'w') { |file| file.puts(existing_content) }
gitlab_keys.stub(auth_file: tmp_authorized_keys_path) gitlab_keys.stub(auth_file: tmp_authorized_keys_path)
end end
...@@ -301,4 +318,13 @@ describe GitlabKeys do ...@@ -301,4 +318,13 @@ describe GitlabKeys do
def tmp_lock_file_path def tmp_lock_file_path
tmp_authorized_keys_path + '.lock' tmp_authorized_keys_path + '.lock'
end end
def capture_stdout(&blk)
old = $stdout
$stdout = fake = StringIO.new
blk.call
fake.string
ensure
$stdout = old
end
end end
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment