diff options
author | Dmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com> | 2014-10-28 19:20:26 +0200 |
---|---|---|
committer | Dmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com> | 2014-10-28 19:20:26 +0200 |
commit | 3a16acf364aa85e283ef10bbbaf6a5f558e5897e (patch) | |
tree | d1074ae9cc68f9c4cf63f95f8eacd556ae1501bc /lib | |
parent | 8f9c11af3c14c0036e7038c33262367288a09ac8 (diff) | |
parent | 89d8af466ba283b31d7800fe604defa0ce189902 (diff) | |
download | gitlab-shell-3a16acf364aa85e283ef10bbbaf6a5f558e5897e.tar.gz |
Merge pull request #177 from feedhenry/keys_list
Added list-keys command, with associated spec
Diffstat (limited to 'lib')
-rw-r--r-- | lib/gitlab_keys.rb | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/lib/gitlab_keys.rb b/lib/gitlab_keys.rb index 3bdf6c6..100e164 100644 --- a/lib/gitlab_keys.rb +++ b/lib/gitlab_keys.rb @@ -19,6 +19,7 @@ class GitlabKeys when 'add-key'; add_key when 'batch-add-keys'; batch_add_keys when 'rm-key'; rm_key + when 'list-keys'; puts list_keys when 'clear'; clear else $logger.warn "Attempt to execute invalid gitlab-keys command #{@command.inspect}." @@ -38,6 +39,19 @@ class GitlabKeys true 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 lock do open(auth_file, 'a') do |file| |