forked from ria-ee/X-Road-scripts
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathxrd_subsystems.py
executable file
·87 lines (72 loc) · 2.64 KB
/
xrd_subsystems.py
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
80
81
82
83
84
85
86
87
#!/usr/bin/python3
"""List X-Road Subsystems."""
import argparse
import sys
import xrdinfo
# Default timeout for HTTP requests
DEFAULT_TIMEOUT = 5.0
def print_error(content):
"""Error printer."""
sys.stderr.write(f'ERROR: {content}\n')
def main():
"""Main function"""
parser = argparse.ArgumentParser(
description='List X-Road Subsystems.',
formatter_class=argparse.RawDescriptionHelpFormatter,
epilog='You need to provide either Security Server or Central Server address.\n\n'
'NB! Global configuration signature is not validated when using Central Server.\n'
'Use local Security Server whenever possible.'
)
parser.add_argument(
'-s', metavar='SECURITY_SERVER', help='DNS name/IP/URL of local Security Server')
parser.add_argument(
'-c', metavar='CENTRAL_SERVER',
help='DNS name/IP/URL of Central Server/Configuration Proxy')
parser.add_argument('-t', metavar='TIMEOUT', help='timeout for HTTP query', type=float)
parser.add_argument(
'--verify', metavar='CERT_PATH',
help='validate peer TLS certificate using CA certificate file.')
parser.add_argument(
'--cert', metavar='CERT_PATH', help='use TLS certificate for HTTPS requests.')
parser.add_argument('--key', metavar='KEY_PATH', help='private key for TLS certificate.')
parser.add_argument(
'--instance', metavar='INSTANCE',
help='use this instance instead of local X-Road instance (works only with "-s" argument)')
args = parser.parse_args()
instance = None
if args.instance:
instance = args.instance
timeout = DEFAULT_TIMEOUT
if args.t:
timeout = args.t
verify = False
if args.verify:
verify = args.verify
cert = None
if args.cert and args.key:
cert = (args.cert, args.key)
if args.s:
try:
shared_params = xrdinfo.shared_params_ss(
addr=args.s, instance=instance, timeout=timeout, verify=verify, cert=cert)
except xrdinfo.XrdInfoError as err:
print_error(err)
sys.exit(1)
elif args.c:
try:
shared_params = xrdinfo.shared_params_cs(
addr=args.c, timeout=timeout, verify=verify, cert=cert)
except xrdinfo.XrdInfoError as err:
print_error(err)
sys.exit(1)
else:
parser.print_help()
sys.exit(1)
try:
for subsystem in xrdinfo.subsystems(shared_params):
print(xrdinfo.identifier(subsystem))
except xrdinfo.XrdInfoError as err:
print_error(err)
sys.exit(1)
if __name__ == '__main__':
main()