summaryrefslogtreecommitdiff
path: root/bin/ssh-list-authorized-keys
blob: 6a03c8d8f6ff015ac4b0c4bdc3915719403adfad (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
#!/usr/bin/env ruby
# Usage: ssh-list-authorized-keys [username]
cfg_groups = [ "repo", "git" ]

######################################################################
require 'set'
require 'yaml'

all_users = Dir.glob("users/*.yml").map{|f|YAML::load(open(f))}
users = Set.new

groupnames = ARGV & cfg_groups
usernames = ARGV & all_users.map{|u|u["username"]}

unless groupnames.empty?
	groupnames.push("hackers")
end

users = all_users.find_all{|u| usernames.include?(u["username"]) or not ((u["groups"]||[]) & groupnames).empty?}

# Buffer the output to avoid EPIPE when the reader hangs up early
output=""
users.each do |user|
	if user["ssh_keys"]
		user["ssh_keys"].each do |addr,key|
			output+="#{key} #{user["fullname"]} (#{user["username"]}) <#{addr}>\n"
		end
	end
end
print output