-
Notifications
You must be signed in to change notification settings - Fork 4
/
InteractiveSocketClient.py
137 lines (118 loc) · 6.14 KB
/
InteractiveSocketClient.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
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
import json
import socketio
import threading
import time
import configparser
import os
class OrderSocket_io(socketio.Client):
"""A Socket.IO client.
This class implements a fully compliant Socket.IO web client with support
for websocket and long-polling transports.
:param reconnection: 'True'. if the client should automatically attempt to
reconnect to the server after an interruption, or
'False' to not reconnect. The default is 'True'.
:param reconnection_attempts: How many reconnection attempts to issue
before giving up, or 0 for infinity attempts.
The default is 0.
:param reconnection_delay: How long to wait in seconds before the first
reconnection attempt. Each successive attempt
doubles this delay.
:param reconnection_delay_max: The maximum delay between reconnection
attempts.
:param randomization_factor: Randomization amount for each delay between
reconnection attempts. The default is 0.5,
which means that each delay is randomly
adjusted by +/- 50%.
:param logger: To enable logging set to 'True' or pass a logger object to
use. To disable logging set to 'False'. The default is
'False'.
:param binary: 'True' to support binary payloads, 'False' to treat all
payloads as text. On Python 2, if this is set to 'True',
'unicode' values are treated as text, and 'str' and
'bytes' values are treated as binary. This option has no
effect on Python 3, where text and binary payloads are
always automatically discovered.
:param json: An alternative json module to use for encoding and decoding
packets. Custom json modules must have 'dumps' and 'loads'
functions that are compatible with the standard library
versions.
"""
def __init__(self, token, userID, reconnection=True, reconnection_attempts=0, reconnection_delay=1,
reconnection_delay_max=5, randomization_factor=0.5, logger=False, binary=False, json=None, **kwargs):
self.sid = socketio.Client(logger=True, engineio_logger=True)
self.eventlistener = self.sid
self.sid.on('connect', self.on_connect)
self.sid.on('message', self.on_message)
self.sid.on('joined', self.on_joined)
self.sid.on('error', self.on_error)
self.sid.on('order', self.on_order)
self.sid.on('trade', self.on_trade)
self.sid.on('position', self.on_position)
self.sid.on('logout', self.on_messagelogout)
self.sid.on('disconnect', self.on_disconnect)
self.userID = userID
self.token = token
"""Get root url from config file"""
currDirMain = os.getcwd()
configParser = configparser.RawConfigParser()
configFilePath = os.path.join(currDirMain, '..\XTConnect\config.ini')
configParser.read(configFilePath)
self.port = configParser.get('root_url', 'root').strip()
port = f'{self.port}/?token='
self.connection_url = port + self.token + '&userID=' + self.userID
def connect(self, headers={}, transports='websocket', namespaces=None, socketio_path='/interactive/socket.io',
verify=False):
"""Connect to a Socket.IO server.
:param url: The URL of the Socket.IO server. It can include custom
query string parameters if required by the server.
:param headers: A dictionary with custom headers to send with the
connection request.
:param transports: The list of allowed transports. Valid transports
are 'polling' and 'websocket'. If not
given, the polling transport is connected first,
then an upgrade to websocket is attempted.
:param namespaces: The list of custom namespaces to connect, in
addition to the default namespace. If not given,
the namespace list is obtained from the registered
event handlers.
:param socketio_path: The endpoint where the Socket.IO server is
installed. The default value is appropriate for
most cases.
"""
"""Connect to the socket."""
url = self.connection_url
print("URL: " + url)
self.sid.connect(url, headers, transports, namespaces, socketio_path)
self.sid.wait()
"""Disconnect from the socket."""
# self.sid.disconnect()
def on_connect(self):
"""Connect from the socket"""
print('Interactive socket connected successfully!')
def on_message(self):
"""On message from socket"""
print('I received a message!')
def on_joined(self, data):
"""On socket joined"""
print('Interactive socket joined successfully!' + data)
def on_error(self, data):
"""On receiving error from socket"""
print('Interactive socket error!' + data)
def on_order(self, data):
"""On receiving order placed data from socket"""
print("Order placed!" + data)
def on_trade(self, data):
"""On receiving trade data from socket"""
print("Trade Received!" + data)
def on_position(self, data):
"""On receiving position data from socket"""
print("Position Retrieved!" + data)
def on_messagelogout(self, data):
"""On receiving user logout message"""
print("User logged out!" + data)
def on_disconnect(self):
"""On receiving disconnection from socket"""
print('Interactive Socket disconnected!')
def get_emitter(self):
"""For getting event listener"""
return self.eventlistener