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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
|
require "saml/kit"
require "saml/kit/cli/version"
require "thor"
module Saml
module Kit
module Cli
class Decode < Thor
desc "redirect uri", "Decodes the uri using the HTTP Redirect binding"
def redirect(uri)
binding = Saml::Kit::Bindings::HttpRedirect.new(location: '')
uri = URI.parse(uri)
query_params = Hash[uri.query.split('&').map { |x| x.split('=', 2) }]
document = binding.deserialize(query_params)
2.times { say "" }
say_status :success, "Decoded #{document.class}"
print_table [
["ID", "Issuer", "Version", "Issue instant"],
[document.id, document.issuer, document.version, document.issue_instant.iso8601 ]
]
say ""
say document.to_xml(pretty: true), :green
end
desc "post saml", "Decodes the SAMLRequest/SAMLResponse using the HTTP Post binding"
def post(saml_request)
binding = Saml::Kit::Bindings::HttpPost.new(location: '')
document = binding.deserialize('SAMLRequest' => saml_request)
2.times { say "" }
say_status :success, "Decoded #{document.class}"
print_table [
["ID", "Issuer", "Version", "Issue instant"],
[document.id, document.issuer, document.version, document.issue_instant.iso8601 ]
]
say ""
say document.to_xml(pretty: true)
end
end
class Generate < Thor
desc "keypair", "Create a key pair using a self signed certificate."
method_option :format, default: "pem", required: false, enum: ["pem", "env"]
method_option :passphrase, default: nil, required: false
def keypair
passphrase = options[:passphrase]
format = options[:format]
generator = ::Xml::Kit::SelfSignedCertificate.new
certificate, private_key = generator.create(passphrase: passphrase)
if "pem" == format
say "** BEGIN PEM Format **", :green
print certificate
say private_key
say "***********************", :green
else
say "** BEGIN ENV Format **", :green
say "X509_CERTIFICATE=" + certificate.inspect
say
say "PRIVATE_KEY=" + private_key.inspect
say "***********************", :green
end
say
say "Private Key Passphrase:", :green
say passphrase.inspect
end
end
class Application < Thor
desc "decode SUBCOMMAND ...ARGS", "decode SAMLRequest/SAMLResponse."
subcommand "decode", Decode
desc "generate SUBCOMMAND ...ARGS", "generate SAML artifacts."
subcommand "generate", Generate
end
end
end
end
|