forked from device-automation-bus/dab-compliance-suite
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdab_client.py
61 lines (53 loc) · 2.07 KB
/
dab_client.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
from time import sleep
from threading import Lock
from paho.mqtt.properties import Properties
from paho.mqtt.packettypes import PacketTypes
import paho.mqtt.client as mqtt
import json
class DabClient:
def __init__(self):
self.__lock = Lock()
self.__lock.acquire()
self.__client = mqtt.Client("mqtt5_client",protocol=mqtt.MQTTv5)
def __on_message(self, client, userdata, message):
self.__response_dic = json.loads(message.payload)
self.__lock.release()
try:
self.__code = self.__response_dic['status']
except:
self.__code = -1
def disconnect(self):
self.__client.disconnect()
def connect(self,broker_address,broker_port):
self.__client.connect(broker_address, port=broker_port)
self.__client.loop_start()
def request(self,device_id,operation,msg="{}"):
# Send request and block until get the response or timeout
topic = "dab/" + device_id+"/" + operation
response_topic="dab/_response/"+topic
self.__client.subscribe(response_topic)
properties=Properties(PacketTypes.PUBLISH)
properties.ResponseTopic=response_topic
self.__client.on_message = self.__on_message
self.__client.subscribe(response_topic)
self.__client.publish(topic,msg,properties=properties)
if not (self.__lock.acquire(timeout = 90)):
self.__code = 100
def response(self):
if((self.__code != -1) and (self.__code != 100)):
return json.dumps(self.__response_dic, indent=2)
else:
return ""
def last_error_code(self):
return self.__code
def last_error_msg(self):
if(self.__code == -1):
print("Unknown error",end='')
elif(self.__code == 100):
print("Timeout",end='')
elif(self.__code == 400):
print("Request invalid or malformed",end='')
elif(self.__code == 500):
print("Internal error",end='')
elif(self.__code == 501):
print("Not implemented",end='')