-
Notifications
You must be signed in to change notification settings - Fork 51
/
Copy pathrealtime_poller.py
72 lines (58 loc) · 1.67 KB
/
realtime_poller.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
import json
import logging
from degiro_connector.quotecast.models.ticker import TickerRequest
from degiro_connector.quotecast.tools.ticker_fetcher import TickerFetcher
from degiro_connector.quotecast.tools.ticker_to_df import TickerToDF
logging.basicConfig(level=logging.DEBUG)
with open("config/config.json") as config_file:
config_dict = json.load(config_file)
user_token = config_dict.get("user_token") # HERE GOES YOUR USER_TOKEN
logger = TickerFetcher.build_logger()
session = TickerFetcher.build_session()
ticker_to_df = TickerToDF()
ticker_request = TickerRequest(
request_type="subscription",
request_map={
"61316189": [
"LastDate",
"LastTime",
"LastPrice",
"LastVolume",
],
"AAPL.BATS,E": [
"LastDate",
"LastTime",
"LastPrice",
"LastVolume",
],
},
)
session_id = TickerFetcher.get_session_id(user_token=user_token)
if session_id is None:
raise TypeError("`session_id` is None")
TickerFetcher.subscribe(
ticker_request=ticker_request,
session_id=session_id,
session=session,
logger=logger,
)
while True:
try:
ticker = TickerFetcher.fetch_ticker(
session_id=session_id,
session=session,
logger=logger,
)
if ticker is None:
raise TypeError("`ticker` is None")
df = ticker_to_df.parse(ticker=ticker)
print(df)
# REMOVE THIS LINE TO RUN IT IN LOOP
# USE : CTRL+C TO QUIT
# break
except Exception as e:
print(e)
break
except KeyboardInterrupt:
print("KeyboardInterrupt")
break