diff options
author | Dmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com> | 2014-03-14 12:45:24 +0000 |
---|---|---|
committer | Dmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com> | 2014-03-14 12:45:24 +0000 |
commit | 367a672a35d78c26a79c18ba92bfc14a950e3545 (patch) | |
tree | 398d32db7a41036c088e44bcad387692f294f74f /lib | |
parent | 9e076ab204eb3fec2f59581230a69eacfd39f78c (diff) | |
parent | 3a48eae79eafe1d3641b0aa4271b83b348a95ee6 (diff) | |
download | gitlab-shell-367a672a35d78c26a79c18ba92bfc14a950e3545.tar.gz |
Merge branch 'batch_key_import' into 'master'
Batch Key Import
Diffstat (limited to 'lib')
-rw-r--r-- | lib/gitlab_keys.rb | 24 |
1 files changed, 23 insertions, 1 deletions
diff --git a/lib/gitlab_keys.rb b/lib/gitlab_keys.rb index 0098578..cade09e 100644 --- a/lib/gitlab_keys.rb +++ b/lib/gitlab_keys.rb @@ -16,6 +16,7 @@ class GitlabKeys def exec case @command when 'add-key'; add_key + when 'batch-add-keys'; batch_add_keys when 'rm-key'; rm_key when 'clear'; clear else @@ -29,11 +30,32 @@ class GitlabKeys def add_key $logger.info "Adding key #{@key_id} => #{@key.inspect}" - auth_line = "command=\"#{ROOT_PATH}/bin/gitlab-shell #{@key_id}\",no-port-forwarding,no-X11-forwarding,no-agent-forwarding,no-pty #{@key}" + auth_line = key_line(@key_id, @key) open(auth_file, 'a') { |file| file.puts(auth_line) } true end + def batch_add_keys + open(auth_file, 'a') do |file| + stdin.each_line do |input| + tokens = input.strip.split("\t") + abort("#{$0}: invalid input #{input.inspect}") unless tokens.count == 2 + key_id, public_key = tokens + $logger.info "Adding key #{key_id} => #{public_key.inspect}" + file.puts(key_line(key_id, public_key)) + end + end + true + end + + def stdin + $stdin + end + + def key_line(key_id, public_key) + auth_line = "command=\"#{ROOT_PATH}/bin/gitlab-shell #{key_id}\",no-port-forwarding,no-X11-forwarding,no-agent-forwarding,no-pty #{public_key}" + end + def rm_key $logger.info "Removing key #{@key_id}" Tempfile.open('authorized_keys') do |temp| |