Browse Source

videv loopback prevention ignore rx after tx

tags/v1.0.0
Dirk Alders 1 year ago
parent
commit
f70ba22ce2
1 changed files with 20 additions and 10 deletions
  1. 20
    10
      function/videv.py

+ 20
- 10
function/videv.py View File

13
 from base import mqtt_base
13
 from base import mqtt_base
14
 import devices
14
 import devices
15
 import json
15
 import json
16
+import time
16
 
17
 
17
 try:
18
 try:
18
     from config import APP_NAME as ROOT_LOGGER_NAME
19
     from config import APP_NAME as ROOT_LOGGER_NAME
28
         self.__display_dict__ = {}
29
         self.__display_dict__ = {}
29
         self.__control_dict__ = {}
30
         self.__control_dict__ = {}
30
         self.__capabilities__ = None
31
         self.__capabilities__ = None
32
+        self.__active_tx__ = {}
31
 
33
 
32
     def add_display(self, my_key, ext_device, ext_key, on_change_only=True):
34
     def add_display(self, my_key, ext_device, ext_key, on_change_only=True):
33
         """
35
         """
49
         self.__tx__(self.__display_dict__[(id(ext_device), ext_key)], data)
51
         self.__tx__(self.__display_dict__[(id(ext_device), ext_key)], data)
50
 
52
 
51
     def __tx__(self, key, data):
53
     def __tx__(self, key, data):
54
+        if key in self.__control_dict__:
55
+            self.__active_tx__[key] = (time.time(), data)
52
         if type(data) not in (str, ):
56
         if type(data) not in (str, ):
53
             data = json.dumps(data)
57
             data = json.dumps(data)
54
         self.mqtt_client.send(self.topic + '/' + key, data)
58
         self.mqtt_client.send(self.topic + '/' + key, data)
69
 
73
 
70
     def __rx_videv_data__(self, client, userdata, message):
74
     def __rx_videv_data__(self, client, userdata, message):
71
         my_key = message.topic.split('/')[-1]
75
         my_key = message.topic.split('/')[-1]
72
-        ext_device, ext_key, on_change_only = self.__control_dict__[my_key]
73
-        if my_key in self.keys():
74
-            try:
75
-                data = json.loads(message.payload)
76
-            except json.decoder.JSONDecodeError:
77
-                data = message.payload
78
-            if data != self[my_key] or not on_change_only:
79
-                ext_device.set(ext_key, data)
80
-            self.set(my_key, data)
76
+        try:
77
+            data = json.loads(message.payload)
78
+        except json.decoder.JSONDecodeError:
79
+            data = message.payload
80
+        if my_key in self.__active_tx__:
81
+            tm, tx_data = self.__active_tx__.pop(my_key)
82
+            do_ex = data != tx_data and time.time() - tm < 2
81
         else:
83
         else:
82
-            self.logger.info("Ignoring rx message with topic %s", message.topic)
84
+            do_ex = True
85
+        if do_ex:
86
+            ext_device, ext_key, on_change_only = self.__control_dict__[my_key]
87
+            if my_key in self.keys():
88
+                if data != self[my_key] or not on_change_only:
89
+                    ext_device.set(ext_key, data)
90
+                self.set(my_key, data)
91
+            else:
92
+                self.logger.info("Ignoring rx message with topic %s", message.topic)
83
 
93
 
84
     def add_routing(self, my_key, ext_device, ext_key, on_change_only_disp=True, on_change_only_videv=True):
94
     def add_routing(self, my_key, ext_device, ext_key, on_change_only_disp=True, on_change_only_videv=True):
85
         """
95
         """

Loading…
Cancel
Save