-
Notifications
You must be signed in to change notification settings - Fork 1
/
main.py
executable file
·88 lines (65 loc) · 2.67 KB
/
main.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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
#!/usr/bin/env python3
import time
from datetime import datetime
from nicegui import ui, app
import os
from ping3 import ping, verbose_ping
if 'PINGER_IPS' not in os.environ:
print('define PINGER_IPS > 1.1.1.1,8.8.8.8')
quit()
ips = os.getenv('PINGER_IPS').split(',')
maxTimeSec = 600
pingAlertLimitMs = 100
maxPingResponseTimeS = 0.3
chartRefreshS = 1
chart = []
pingTimer = []
pingIntervalS = 1
for ip in ips:
chart.append(ui.chart({'title': { 'text': ip},
'chart': { 'type': 'area', 'zoomType': 'x' },
'xAxis': { 'type': 'datetime' },
'yAxis': { 'title': {'text':'ms'}},
'time': { 'timezoneOffset': 7200},
'legend': { 'enabled': False },
'series': [{'name' : ip, 'data': [], 'color': '#32a84c'}],
}
).classes('w-full h-64'))
log = ui.log(max_lines=30).classes('w-full h-96 bg-black text-white')
def clear():
i = -1
for ip in ips:
i+= 1
chart[i].options['series'][0]['data'].clear()
log.clear()
log.push("Auto refresh time: " + str(chartRefreshS) + "sec")
ui.button('Clear all', on_click=clear)
def ping_internal(i):
global ips, conn, c, maxTimeSec, maxResponseTimeMs
ip = ips[i]
response_time = ping(ip, timeout=maxPingResponseTimeS, unit='ms')
if response_time is None:
print(datetime.now().strftime('%H:%M:%S') + " no ping reply from " + ip)
log.push(datetime.now().strftime('%H:%M:%S') + " no ping reply from " + ip)
ui.notify(datetime.now().strftime('%H:%M:%S') + " no ping reply from " + ip, type='negative')
chart[i].options['series'][0]['data'].append({'x': int(time.time()*1000), 'y': 0, 'marker': { 'radius': 3, 'fillColor': '#eb0909' }})
else:
chart[i].options['series'][0]['data'].append({'x': int(time.time()*1000), 'y': round(response_time,2), 'marker': { 'radius': 0 }})
if len(chart[i].options['series'][0]['data']) > maxTimeSec:
chart[i].options['series'][0]['data'].pop(0)
if response_time > pingAlertLimitMs:
log.push(datetime.now().strftime('%H:%M:%S') + " high ping reply time from " + ip + " > " + str(response_time) + " ms")
def updateCharts():
global ips, conn, c, maxTimeSec, maxResponseTimeMs
i = -1
for ip in ips:
i+= 1
chart[i].update()
i = -1
for ip in ips:
i += 1
pingTimer.append(ui.timer(pingIntervalS, lambda iter=i: ping_internal(iter)))
# ui.timer(round(len(ips)*maxPingResponseTimeS+1), lambda: ping_internals())
chartTimer = ui.timer(chartRefreshS, lambda: updateCharts())
log.push("Auto refresh time: " + str(chartRefreshS) + "sec")
ui.run(title="pinger", show="False", favicon="📶")