Browse Source

Exception handling for MQTT

master
Dirk Alders 2 years ago
parent
commit
5425af984b
1 changed files with 13 additions and 7 deletions
  1. 13
    7
      powerplug.py

+ 13
- 7
powerplug.py View File

77
     def send_state(self, output):
77
     def send_state(self, output):
78
         topic = config.MQTT_TOPIC + "/status/" + str(output)
78
         topic = config.MQTT_TOPIC + "/status/" + str(output)
79
         logger.info("Sending Powerplug status information of plug %s to mqtt %s = %s", str(output), topic, str(self.__state__[output - 1]))
79
         logger.info("Sending Powerplug status information of plug %s to mqtt %s = %s", str(output), topic, str(self.__state__[output - 1]))
80
-        self.__mqtt_client__.publish(topic, "true" if self.__state__[output - 1] else "false")
80
+        try:
81
+            self.__mqtt_client__.publish(topic, "true" if self.__state__[output - 1] else "false")
82
+        except (socket.timeout, OSError) as e:
83
+            logger.warning("Erro while sending state information information")
81
 
84
 
82
 
85
 
83
 class mqtt_powerplug(object):
86
 class mqtt_powerplug(object):
98
         self.__client__ = mqtt.Client("mqtt_powerplug")                         # create client object
101
         self.__client__ = mqtt.Client("mqtt_powerplug")                         # create client object
99
         self.__client__.on_message = self.__receive__                           # attach function to callback
102
         self.__client__.on_message = self.__receive__                           # attach function to callback
100
         self.__client__.username_pw_set(config.MQTT_USER, config.MQTT_PASS)     # login with credentials
103
         self.__client__.username_pw_set(config.MQTT_USER, config.MQTT_PASS)     # login with credentials
101
-        self.__client__.connect(config.MQTT_SERVER, 1883)                       # establish connection
102
-        self.__client__.loop_start()                                            # start the loop
103
-        self.__topics__ = []
104
-        for subtopic in self.SUBTOPICS:
105
-            self.__topics__.append(config.MQTT_TOPIC + "/" + subtopic)
106
-            self.__client__.subscribe(self.__topics__[-1])                      # subscibe a topic
104
+        try:
105
+            self.__client__.connect(config.MQTT_SERVER, 1883)                       # establish connection
106
+            self.__client__.loop_start()                                            # start the loop
107
+            self.__topics__ = []
108
+            for subtopic in self.SUBTOPICS:
109
+                self.__topics__.append(config.MQTT_TOPIC + "/" + subtopic)
110
+                self.__client__.subscribe(self.__topics__[-1])                      # subscibe a topic
111
+        except (socket.timeout, OSError) as e:
112
+            logger.warning("Erro while setting up mqtt instance and listener")
107
         self.__sc__ = sispmctl(self.__client__)
113
         self.__sc__ = sispmctl(self.__client__)
108
 
114
 
109
     def __receive__(self, client, userdata, message):
115
     def __receive__(self, client, userdata, message):

Loading…
Cancel
Save