-
Notifications
You must be signed in to change notification settings - Fork 0
/
main_server.py
74 lines (54 loc) · 1.95 KB
/
main_server.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
# Vocal interface
import socket
import json
from core.utils.logs import *
from core.utils.cleanOrder import *
from core import core
from core.communication import *
sockRobot=socket.socket()
sockRobot.connect(("127.0.0.1", 56987))
sockRobot.send(str.encode("motordaemon"))
socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
socket.bind(('', 15555))
logHeader("######################")
logHeader("# VOCAL SERVER #")
logHeader("######################")
while(42):
logUnderline("--- Attente de requete ---")
socket.listen(5)
client, address = socket.accept()
logGreen("Client connecte...\n")
try :
orderJson = recvFromClient(client)
if (orderJson["type"] == "question" or orderJson["type"] == "confirmation"):
#print("Reçu ordre de type " + orderJson["type"])
#print("Request : ")
#logBlue(orderJson["msg"])
orderJson["client"] = client
orderJson = cleanOrder(orderJson)
ret = core.executeSkill(orderJson) # TODO tout transformer en JSON !!!
if (ret != ""):
#logBold("Response : " + ret)
sendAnswer(ret, client)
print("Close")
client.close()
else:
print("ORDRE DE TYPE NON RECONNU : " + str(orderJson))
ret = "ERREUR : Le message envoye au serveur n'est pas un bon Json"
logFail("Response : " + ret)
sendError(ret, client)
print("Close")
client.close()
except KeyError:
ret = "ERREUR : Le message envoye au serveur n'est pas un bon Json"
logFail("Response : " + ret)
sendError(ret, client)
print("Close")
client.close()
#except ValueError :
# ret = "ERREUR : Le message envoye au serveur n'est pas un Json"
# logFail("Response : " + ret)
# sendError(ret, client)
# print("Close")
# client.close()
print("\n--------------\n")