-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathmain.py
128 lines (93 loc) · 3.1 KB
/
main.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
import sys, time, traceback
import socketio
from model_broadcast import ModelBroadcast
# Q_SERVER_URL = "http://localhost:3005"
Q_SERVER_URL = "https://localhost:5000"
# Q_SERVER_URL = "http://176.58.122.57:8000"
# API_TOKEN = "eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJleHAiOjE2ODU4NDg0NTAsImlhdCI6MTY4MzI1NjQ1MCwiaWQiOjF9.rrcb5sdaxcEm-dEApkJ6lEoDN9G1ro8I5CTng3UdXmI"
API_TOKEN="eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJleHAiOjE2ODU5NTg2NzcsImlhdCI6MTY4MzM2NjY3NywiaWQiOjF9.cPWJuH81xv7rBg1fiVa2xqWQF9pLWcN-y_Oz5oJ2p8s"
BUSY = False
CONNECTED = False
ABORT = False
AUTHENTICATED = False
broadcast = ModelBroadcast(api_token = API_TOKEN , test=False)
sio = socketio.Client(logger=True, engineio_logger=True, ssl_verify=False)
@sio.event
def connect():
print('Connection established with queue server.')
CONNECTED = True
@sio.on("broadcast information")
def on_broadcast_formation(data):
global ABORT
if data != "Authenticated":
print(data)
print("Invalid details were shared. Aborting...")
ABORT = True
sio.disconnect()
return
else:
global AUTHENTICATED
AUTHENTICATED = True
print('I recv ', data)
@sio.on("no task")
def no_task():
print('No task')
@sio.on(f"execute task")
def exec_task(_json):
global BUSY
BUSY = True
# print('Executing', _json, "on ", api_id)
model, args, timestamp = _json["model"], _json["args"], _json["timestamp"]
if model in broadcast.broadcast["models"].keys():
try:
_response = broadcast.broadcast["models"][model]["func"](args)
sio.emit("done task", {"_response": _response, "timestamp": timestamp } )
except Exception as e:
print(e)
print(traceback.format_exc())
print("An error occured")
sio.emit("aborted task", {"error": str(e), "timestamp" : timestamp} )
else:
sio.emit("aborted task", {"error": "Model does not exist.", "timestamp" : timestamp} )
BUSY = False
#all relevant procs here
@sio.event
def disconnect():
print('disconnected from server')
CONNECTED = False
def get_work_background_task():
while True:
try:
print("Busy: ", BUSY)
if not BUSY:
print("Sending out that i dont have work")
sio.emit('get work', {"_id": API_TOKEN})
for i in range(10) : sio.sleep(1)
except Exception as e:
print(e)
sys.exit()
def main():
global ABORT
sio.connect(Q_SERVER_URL, wait_timeout=10)
# sio.wait()
sio.emit('broadcast information', {"data": broadcast.get_desc()})
# sio.wait()
time.sleep(10)
if ABORT == True:
print("Aborting...")
sys.exit()
if AUTHENTICATED == True:
sio.start_background_task(get_work_background_task)
# sio.wait()
try:
while True:
time.sleep(1)
except Exception as e:
print(e)
sys.exit()
if __name__ == '__main__':
try:
main()
except KeyboardInterrupt:
sio.disconnect()
sys.exit()