blob: b57362b14febcb31cca176834348c5302d437b61 (
plain)
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
|
#!/usr/bin/python
import json
import sys
import Crypto.PublicKey.RSA
import jwt
def catf(f):
return f.read()
def cat(filename):
with open(filename, 'r') as f:
return catf(f)
if len(sys.argv) == 1:
token = catf(sys.stdin).strip()
obj = jwt.decode(token, verify=False)
elif len(sys.argv) == 2:
token = cat(sys.argv[1]).strip()
obj = jwt.decode(token, verify=False)
elif len(sys.argv) == 3:
token = cat(sys.argv[1]).strip()
pubkey_text = cat(sys.argv[2])
opts = {
'verify_aud': False,
'verify_iss': False,
}
obj = jwt.decode(token, verify=True, key=pubkey_text, options=opts)
else:
assert 0
json.dump(obj, sys.stdout, indent=4)
sys.stdout.write('\n')
|