-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmdparser.py
executable file
·60 lines (41 loc) · 1.17 KB
/
mdparser.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
#!/usr/bin/env python
import sys
import utils
from datetime import timedelta
def parse_saml_metadata(source):
validation = dict()
validation['error'] = None
validation['md_expires'] = None
validation['crt_expires'] = None
try:
t = utils.parse_xml(source)
t = utils.root(t)
# XSD validation
utils.validate_document(t)
# Signature validation
utils.validate_signature(t)
# Expiration check
validation['md_expires'] = utils.metadata_expiration(t)
# Certificate expiration
# Everybody seems to use expired TSC's
# validation['crt_expires'] = utils.certificate_expiration(t)
except Exception as ex:
validation['error'] = ex
return validation
if len(sys.argv) < 2:
sys.exit(sys.argv[0] + " <argument>")
md = open(sys.argv[1], "rb")
v = parse_saml_metadata(md)
error = v['error']
md_expires = v['md_expires']
crt_expires = v['crt_expires']
if (error):
print("Error: %s" % error)
if (md_expires and md_expires < timedelta(days=1)):
print("MD expires: %ss" % md_expires)
sys.exit(1)
if (crt_expires and crt_expires < timedelta(days=7)):
print("CRT expires: %ss" % crt_expires)
sys.exit(1)
exit(0)
md.close()