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
|
#!/bin/python
import getopt
import sys
import pki
import pki.client
import pki.crypto
import pki.key
import pki.kra
def usage():
print "usage: vault-server-retrieve --user-id <user ID> --secret-id <secret ID>"
def main(argv):
try:
opts, _ = getopt.getopt(argv[1:], 'c:d:hv', [
'user-id=', 'secret-id=',
'verbose', 'help'])
except getopt.GetoptError as e:
print 'ERROR: ' + str(e)
usage()
sys.exit(1)
nssdb_directory = "/root/.dogtag/pki-tomcat/ca/alias"
nssdb_password = "Secret123"
transport_cert_nickname = "KRA Transport Certificate"
admin_cert = "/root/.dogtag/pki-tomcat/ca_admin_cert.pem"
scheme = 'https'
host = 'localhost'
port = '8443'
subsystem = 'kra'
user_id = None
secret_id = None
for o, a in opts:
if o == '-d':
nssdb_directory = a
elif o == '-c':
nssdb_password = a
elif o == '--user-id':
user_id = a
elif o == '--secret-id':
secret_id = a
if user_id is None or secret_id is None:
usage()
sys.exit(1)
client_key_id = '%s:%s' % (user_id, secret_id)
crypto = pki.crypto.NSSCryptoProvider(nssdb_directory, nssdb_password)
crypto.initialize()
conn = pki.client.PKIConnection(scheme, host, port, subsystem)
conn.set_authentication_cert(admin_cert)
kra_client = pki.kra.KRAClient(conn, crypto, transport_cert_nickname)
key_client = kra_client.keys
key_info = key_client.get_active_key_info(client_key_id)
key_id = key_info.get_key_id()
response = key_client.retrieve_key(key_id)
print response.data
if __name__ == '__main__':
main(sys.argv)
|