Enhance berry example with full list of active devices
This commit is contained in:
parent
ed35bbff84
commit
4490284fb4
@ -1,15 +1,30 @@
|
|||||||
# Show hostname and IP address from MQTT STATE messages in GUI
|
#-
|
||||||
|
Show topic/hostname and IP address with uptime from MQTT STATE messages in GUI
|
||||||
|
|
||||||
|
Enable either
|
||||||
|
self.line_option = 1 : Scroll 'line_cnt' lines
|
||||||
|
or
|
||||||
|
self.line_option = 2 : Show devices updating within 'line_teleperiod'
|
||||||
|
-#
|
||||||
|
|
||||||
import mqtt
|
import mqtt
|
||||||
import string
|
import string
|
||||||
|
|
||||||
class mqttdata_cls
|
class mqttdata_cls
|
||||||
var list_buffer # Buffer storing lines
|
var line_option # Line option
|
||||||
var line_cnt # Number of lines
|
var line_cnt # Number of lines
|
||||||
|
var line_teleperiod # Skip any device taking longer to respond (probably offline)
|
||||||
|
var line_duration # Duration option
|
||||||
|
var list_buffer # Buffer storing lines
|
||||||
|
|
||||||
def init()
|
def init()
|
||||||
|
# self.line_option = 1 # Scroll line_cnt lines
|
||||||
|
self.line_option = 2 # Show devices updating within line_teleperiod
|
||||||
|
self.line_cnt = 10 # Option 1 number of lines to show
|
||||||
|
self.line_teleperiod = 1200 # Option 2 number of teleperiod for devices to be shown
|
||||||
|
self.line_duration = 0 # Show duration of last state message (1)
|
||||||
|
|
||||||
self.list_buffer = [] # Init line buffer list
|
self.list_buffer = [] # Init line buffer list
|
||||||
self.line_cnt = 10 # Number of lines to show
|
|
||||||
|
|
||||||
if global.mqttdata_driver
|
if global.mqttdata_driver
|
||||||
global.mqttdata_driver.stop() # Let previous instance bail out cleanly
|
global.mqttdata_driver.stop() # Let previous instance bail out cleanly
|
||||||
@ -27,39 +42,129 @@ class mqttdata_cls
|
|||||||
var subtopic = string.split(full_topic, "/") # Assume default Fulltopic (%prefix%/%topic%/)
|
var subtopic = string.split(full_topic, "/") # Assume default Fulltopic (%prefix%/%topic%/)
|
||||||
var topic = subtopic[1] # wemos7
|
var topic = subtopic[1] # wemos7
|
||||||
|
|
||||||
var line
|
|
||||||
var state = json.load(data)
|
var state = json.load(data)
|
||||||
if state
|
if state # Valid JSON state message
|
||||||
var uptime = state['Uptime']
|
var sub_option = 1
|
||||||
|
var ipaddress = "" # Not used
|
||||||
|
var uptime = state['Uptime'] # 129T10:52:41
|
||||||
if state.find('Hostname')
|
if state.find('Hostname')
|
||||||
var hostname = state['Hostname']
|
sub_option = 2
|
||||||
var ipaddress = state['IPAddress']
|
topic = state['Hostname'] # wemos7
|
||||||
line = format("<tr><td><a target=_blank href='http://%s.'>%s</a></td><td><a target=_blank href='http://%s'>%s</a></td><td align='right'>%s</td></tr>",
|
ipaddress = state['IPAddress'] # 192.168.2.123
|
||||||
hostname, hostname, ipaddress, ipaddress, uptime)
|
|
||||||
else
|
|
||||||
line = format("<tr><td>%s</td><td> </td><td align='right'>%s</td></tr>",
|
|
||||||
topic, uptime)
|
|
||||||
end
|
end
|
||||||
end
|
var last_seen = tasmota.rtc('local')
|
||||||
self.list_buffer.push(line) # Add as last entry
|
var line = format("%s,%s,%s,%d,%d", topic, ipaddress, uptime, last_seen, sub_option)
|
||||||
|
|
||||||
|
if 1 == self.line_option
|
||||||
|
self.list_buffer.push(line) # Add state as last entry
|
||||||
if self.list_buffer.size() > self.line_cnt # Max number of lines in buffer
|
if self.list_buffer.size() > self.line_cnt # Max number of lines in buffer
|
||||||
self.list_buffer.remove(0) # Remove first entry
|
self.list_buffer.remove(0) # Remove first entry
|
||||||
end
|
end
|
||||||
|
elif 2 == self.line_option
|
||||||
|
if self.list_buffer.size()
|
||||||
|
var i = 0
|
||||||
|
var list_size = size(self.list_buffer)
|
||||||
|
while i < list_size # Use while loop as counter is decremented
|
||||||
|
if 0 == string.find(self.list_buffer[i], topic)
|
||||||
|
self.list_buffer.remove(i) # Remove current state
|
||||||
|
list_size -= 1 # Continue for duplicates
|
||||||
|
end
|
||||||
|
i += 1
|
||||||
|
end
|
||||||
|
end
|
||||||
|
self.list_buffer.push(line) # Add state as last entry
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
||||||
end
|
end
|
||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def sort(l, cmp) # Sort list
|
||||||
|
for i:1..size(l)-1
|
||||||
|
var k = l[i]
|
||||||
|
var j = i
|
||||||
|
while (j > 0) && !cmp(l[j-1], k)
|
||||||
|
l[j] = l[j-1]
|
||||||
|
j -= 1
|
||||||
|
end
|
||||||
|
l[j] = k
|
||||||
|
end
|
||||||
|
return l
|
||||||
|
end
|
||||||
|
|
||||||
|
def dhm(last_time) # Duration
|
||||||
|
var since = tasmota.rtc('local') - last_time
|
||||||
|
var unit = "d"
|
||||||
|
if since > (24 * 3600)
|
||||||
|
since /= (24 * 3600)
|
||||||
|
if since > 99 since = 99 end
|
||||||
|
elif since > 3600
|
||||||
|
since /= 3600
|
||||||
|
unit = "h"
|
||||||
|
else
|
||||||
|
since /= 60
|
||||||
|
unit = "m"
|
||||||
|
end
|
||||||
|
return format("%02d%s", since, unit)
|
||||||
|
end
|
||||||
|
|
||||||
def web_sensor()
|
def web_sensor()
|
||||||
if self.list_buffer.size()
|
if self.list_buffer.size()
|
||||||
var msg = format("</table>{t}") # Terminate two column table and open new table
|
var msg = ""
|
||||||
for i: self.list_buffer.keys()
|
|
||||||
msg += self.list_buffer[i]
|
if 2 == self.line_option
|
||||||
|
# Sort list
|
||||||
|
var less = /a,b -> a < b
|
||||||
|
self.sort(self.list_buffer, less)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
var stx = false # If list_buffer is empty due to removes show nothing
|
||||||
|
var time_window = tasmota.rtc('local') - self.line_teleperiod
|
||||||
|
var i = 0
|
||||||
|
var j = size(self.list_buffer)
|
||||||
|
while i < j
|
||||||
|
var splits = string.split(self.list_buffer[i], ",")
|
||||||
|
var last_seen = int(splits[3])
|
||||||
|
|
||||||
|
if time_window > last_seen # Remove offline devices
|
||||||
|
self.list_buffer.remove(i)
|
||||||
|
j -= 1
|
||||||
|
continue
|
||||||
|
end
|
||||||
|
|
||||||
|
var topic = splits[0] # topic or hostname
|
||||||
|
var ipaddress = splits[1]
|
||||||
|
var uptime = splits[2]
|
||||||
|
var sub_option = int(splits[4])
|
||||||
|
|
||||||
|
if !stx
|
||||||
|
stx = true
|
||||||
|
msg = format("</table>{t}") # Terminate two column table and open new table
|
||||||
|
end
|
||||||
|
# msg += format("<tr style='font-size:%d%%'>", 90 - (self.line_duration * 10))
|
||||||
|
msg += "<tr style='font-size:80%'>"
|
||||||
|
if 1 == sub_option
|
||||||
|
msg += format("<td>%s</td><td> </td><td align='right'>%s</td>",
|
||||||
|
topic, uptime)
|
||||||
|
elif 2 == sub_option
|
||||||
|
msg += format("<td><a target=_blank href='http://%s.'>%s</a></td><td><a target=_blank href='http://%s'>%s</a></td><td align='right'>%s</td>",
|
||||||
|
topic, topic, ipaddress, ipaddress, uptime)
|
||||||
|
end
|
||||||
|
if self.line_duration
|
||||||
|
msg += format("<td style='font-size:90%%'>🕗%s</td>", # Clock
|
||||||
|
self.dhm(last_seen))
|
||||||
|
end
|
||||||
|
msg += "</tr>"
|
||||||
|
i += 1
|
||||||
|
end
|
||||||
|
if stx
|
||||||
msg += "</table>{t}" # Terminate three column table and open new table
|
msg += "</table>{t}" # Terminate three column table and open new table
|
||||||
tasmota.web_send(msg) # Do not use tasmota.web_send_decimal() which will replace IPAddress dots
|
tasmota.web_send(msg) # Do not use tasmota.web_send_decimal() which will replace IPAddress dots
|
||||||
tasmota.web_send_decimal("") # Force horizontal line
|
tasmota.web_send_decimal("") # Force horizontal line
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
mqttdata = mqttdata_cls()
|
mqttdata = mqttdata_cls()
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user