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
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
|
#!/usr/bin/env ruby
require 'net/http'
require 'uri'
require 'json'
def get_ticket(un, tgt, sv)
uri = URI.parse("http://localhost:4567/ticket")
header = {'Content-Type': 'text/json'}
login = {
"username": un,
"ticket": tgt,
"service": sv
}
http = Net::HTTP.new(uri.host, uri.port)
request = Net::HTTP::Post.new(uri.request_uri, header)
request.body = login.to_json
response = http.request(request)
response.body
end
print "Username: "; un = gets.strip
print "Mailserver: "; ms = gets.strip
unless File.exist?(".keytab")
puts "No keytab, please kinit"
exit 1
end
Keys = File.readlines(".keytab").map{ |l| l.strip.split(?:) }.to_h
if Keys.keys.include?(ms)
ticket = Keys[ms]
elsif Keys.keys.include?("_TGS")
ticket = get_ticket(un, Keys["_TGS"], ms)
File.open(".keytab", ?a) do |f|
f.puts "#{ms}:#{ticket}"
end
else
puts "No Ticket Granting Ticket, please kinit"
exit 1
end
uri = URI.parse("http://localhost:4568/login")
header = {'Content-Type': 'text/json'}
login = {
"username": un,
"ticket": ticket
}
http = Net::HTTP.new(uri.host, uri.port)
request = Net::HTTP::Post.new(uri.request_uri, header)
request.body = login.to_json
response = http.request(request)
puts response.body
|