Commit 3a16acf3 authored by Dmitriy Zaporozhets's avatar Dmitriy Zaporozhets

Merge pull request #177 from feedhenry/keys_list

Added list-keys command, with associated spec
parents 8f9c11af 89d8af46
...@@ -78,6 +78,11 @@ Remove key: ...@@ -78,6 +78,11 @@ Remove key:
./bin/gitlab-keys rm-key key-23 "ssh-rsa AAAAx321..." ./bin/gitlab-keys rm-key key-23 "ssh-rsa AAAAx321..."
List all keys:
./bin/gitlab-keys list-keys
Remove all keys from authorized_keys file: Remove all keys from authorized_keys file:
./bin/gitlab-keys clear ./bin/gitlab-keys clear
...@@ -12,6 +12,8 @@ require_relative '../lib/gitlab_init' ...@@ -12,6 +12,8 @@ require_relative '../lib/gitlab_init'
# #
# /bin/gitlab-keys rm-key key-23 "ssh-rsa AAAAx321..." # /bin/gitlab-keys rm-key key-23 "ssh-rsa AAAAx321..."
# #
# /bin/gitlab-keys list-keys
#
# /bin/gitlab-keys clear # /bin/gitlab-keys clear
# #
......
...@@ -19,6 +19,7 @@ class GitlabKeys ...@@ -19,6 +19,7 @@ class GitlabKeys
when 'add-key'; add_key when 'add-key'; add_key
when 'batch-add-keys'; batch_add_keys when 'batch-add-keys'; batch_add_keys
when 'rm-key'; rm_key when 'rm-key'; rm_key
when 'list-keys'; puts list_keys
when 'clear'; clear when 'clear'; clear
else else
$logger.warn "Attempt to execute invalid gitlab-keys command #{@command.inspect}." $logger.warn "Attempt to execute invalid gitlab-keys command #{@command.inspect}."
...@@ -38,6 +39,19 @@ class GitlabKeys ...@@ -38,6 +39,19 @@ class GitlabKeys
true true
end end
def list_keys
$logger.info 'Listing all keys'
keys = ''
File.readlines(auth_file).each do |line|
# key_id & public_key
# command=".../bin/gitlab-shell key-741" ... ssh-rsa AAAAB3NzaDAxx2E\n
# ^^^^^^^ ^^^^^^^^^^^^^^^
matches = /^command=\".+?\s+(.+?)\".+?ssh-rsa\s(.+)\s*.*\n*$/.match(line)
keys << "#{matches[1]} #{matches[2]}\n" unless matches.nil?
end
keys
end
def batch_add_keys def batch_add_keys
lock do lock do
open(auth_file, 'a') do |file| open(auth_file, 'a') do |file|
......
...@@ -41,6 +41,19 @@ describe GitlabKeys do ...@@ -41,6 +41,19 @@ describe GitlabKeys do
end end
end end
describe :list_keys do
let(:gitlab_keys) do
build_gitlab_keys('add-key', 'key-741', 'ssh-rsa AAAAB3NzaDAxx2E')
end
it 'adds a key and lists it' do
create_authorized_keys_fixture
gitlab_keys.send :add_key
auth_line1 = 'key-741 AAAAB3NzaDAxx2E'
gitlab_keys.send(:list_keys).should == "#{auth_line1}\n"
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') }
......
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