summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorDmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com>2014-03-14 12:45:24 +0000
committerDmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com>2014-03-14 12:45:24 +0000
commit367a672a35d78c26a79c18ba92bfc14a950e3545 (patch)
tree398d32db7a41036c088e44bcad387692f294f74f /lib
parent9e076ab204eb3fec2f59581230a69eacfd39f78c (diff)
parent3a48eae79eafe1d3641b0aa4271b83b348a95ee6 (diff)
downloadgitlab-shell-367a672a35d78c26a79c18ba92bfc14a950e3545.tar.gz
Merge branch 'batch_key_import' into 'master'
Batch Key Import
Diffstat (limited to 'lib')
-rw-r--r--lib/gitlab_keys.rb24
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|