-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathjwt_generator.py
53 lines (43 loc) · 1.21 KB
/
jwt_generator.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
import jwt, sys
from cryptography.hazmat.primitives import serialization
import time
private_key = open('.ssh/id_rsa', 'r').read()
key = serialization.load_ssh_private_key(private_key.encode(), password=None)
payload_data = { "payload1" :
{"auth-provider": "sso",
"email": "[email protected]"},
"payload2" :
{"auth-provider": "user-pass",
"email": "[email protected]"},
"payload3" :
{"auth-provider": "sso",
"email": "[email protected]"},
"payload4" : {"auth-provider": "sso",
"email": "[email protected]"}
}
def timeStamp():
ts = int(time.time())
timeStamp = {"expiry": ts}
return timeStamp
def tokenGen(i):
payload = ''
if i > 0 and i < 5:
pKey = "payload" + str(i)
payload=payload_data[pKey]
payload.update(timeStamp())
elif i == 5:
payload=payload_data['payload1']
ts = (int(time.time())-5000)
payload.update({"expiry": ts})
else:
print(str(i) + " is not a valid index")
return -1
new_token = jwt.encode(
payload=payload,
key=key,
algorithm='RS256'
)
return new_token
if __name__ == "__main__":
i = sys.argv[1]
print(tokenGen(i))