forked from tkanhe/Fyers-API-Access-Token-Generation-V2
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathfyers_access_token_totp.py
102 lines (77 loc) · 3.74 KB
/
fyers_access_token_totp.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
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
import base64
import hmac
import os
import struct
import time
from urllib.parse import parse_qs, urlparse
import requests
from fyers_api import accessToken, fyersModel
username = "******" # fyers_id
totp_key = "******" # totp_key ("OMKR****CDVDFGECLWXKI6OVB7T4DTKU5")
pin = 1551 # your integer pin
client_id = "******" # "L9NY****W-100" (Client_id here refers to APP_ID of the created app)
secret_key = "******" # app_secret key which you got after creating the app
redirect_uri = "******" # redircet_uri you entered while creating APP.
def totp(key, time_step=30, digits=6, digest="sha1"):
key = base64.b32decode(key.upper() + "=" * ((8 - len(key)) % 8))
counter = struct.pack(">Q", int(time.time() / time_step))
mac = hmac.new(key, counter, digest).digest()
offset = mac[-1] & 0x0F
binary = struct.unpack(">L", mac[offset : offset + 4])[0] & 0x7FFFFFFF
return str(binary)[-digits:].zfill(digits)
def read_file():
with open("fyers_access_token.txt", "r") as f:
token = f.read()
return token
def write_file(token):
with open("fyers_access_token.txt", "w") as f:
f.write(token)
def get_token():
headers = {
"Accept": "application/json",
"Accept-Language": "en-US,en;q=0.9",
"User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/112.0.0.0 Safari/537.36",
}
s = requests.Session()
s.headers.update(headers)
data1 = f'{{"fy_id":"{base64.b64encode(f"{username}".encode()).decode()}","app_id":"2"}}'
r1 = s.post("https://api-t2.fyers.in/vagator/v2/send_login_otp_v2", data=data1)
assert r1.status_code == 200, f"Error in r1:\n {r1.json()}"
request_key = r1.json()["request_key"]
data2 = f'{{"request_key":"{request_key}","otp":{totp(totp_key)}}}'
r2 = s.post("https://api-t2.fyers.in/vagator/v2/verify_otp", data=data2)
assert r2.status_code == 200, f"Error in r2:\n {r2.text}"
request_key = r2.json()["request_key"]
data3 = f'{{"request_key":"{request_key}","identity_type":"pin","identifier":"{base64.b64encode(f"{pin}".encode()).decode()}"}}'
r3 = s.post("https://api-t2.fyers.in/vagator/v2/verify_pin_v2", data=data3)
assert r3.status_code == 200, f"Error in r3:\n {r3.json()}"
headers = {"authorization": f"Bearer {r3.json()['data']['access_token']}", "content-type": "application/json; charset=UTF-8"}
data4 = f'{{"fyers_id":"{username}","app_id":"{client_id[:-4]}","redirect_uri":"{redirect_uri}","appType":"100","code_challenge":"","state":"abcdefg","scope":"","nonce":"","response_type":"code","create_cookie":true}}'
r4 = s.post("https://api.fyers.in/api/v2/token", headers=headers, data=data4)
assert r4.status_code == 308, f"Error in r4:\n {r4.json()}"
parsed = urlparse(r4.json()["Url"])
auth_code = parse_qs(parsed.query)["auth_code"][0]
session = accessToken.SessionModel(client_id=client_id, secret_key=secret_key, redirect_uri=redirect_uri, response_type="code", grant_type="authorization_code")
session.set_token(auth_code)
response = session.generate_token()
return response["access_token"]
def get_profile(token):
fyers = fyersModel.FyersModel(client_id=client_id, token=token, log_path=os.getcwd())
return fyers.get_profile()
def check():
try:
token = read_file()
except FileNotFoundError:
token = get_token()
response = get_profile(token)
if "error" in response["s"] or "error" in response["message"] or "expired" in response["message"]:
print("Getting a new fyers access token!")
token = get_token()
write_file(token)
print(get_profile(token))
else:
print("Got the fyers access token!")
write_file(token)
print(response)
if __name__ == "__main__":
check()