mirror of
https://github.com/tcivie/meshtastic-metrics-exporter.git
synced 2025-01-13 06:48:11 -08:00
Added mqtt connection status for nodes
This commit is contained in:
parent
d2afef76d5
commit
989f762a33
|
@ -25,5 +25,6 @@ CREATE TABLE IF NOT EXISTS client_details
|
||||||
short_name VARCHAR,
|
short_name VARCHAR,
|
||||||
long_name VARCHAR,
|
long_name VARCHAR,
|
||||||
hardware_model VARCHAR,
|
hardware_model VARCHAR,
|
||||||
role VARCHAR
|
role VARCHAR,
|
||||||
|
mqtt_status VARCHAR default 'none'
|
||||||
);
|
);
|
||||||
|
|
|
@ -461,9 +461,9 @@ class TraceRouteAppProcessor(Processor):
|
||||||
traceroute.ParseFromString(payload)
|
traceroute.ParseFromString(payload)
|
||||||
if traceroute.route:
|
if traceroute.route:
|
||||||
route = traceroute.route
|
route = traceroute.route
|
||||||
self.metrics.route_discovery_counter.labels(
|
self.metrics.route_discovery_gauge.labels(
|
||||||
**client_details.to_dict()
|
**client_details.to_dict()
|
||||||
).inc(len(route))
|
).set(len(route))
|
||||||
|
|
||||||
|
|
||||||
@ProcessorRegistry.register_processor(PortNum.NEIGHBORINFO_APP)
|
@ProcessorRegistry.register_processor(PortNum.NEIGHBORINFO_APP)
|
||||||
|
|
|
@ -324,7 +324,7 @@ class _Metrics:
|
||||||
)
|
)
|
||||||
|
|
||||||
def _init_route_discovery_metrics(self):
|
def _init_route_discovery_metrics(self):
|
||||||
self.route_discovery_counter = Counter(
|
self.route_discovery_gauge = Gauge(
|
||||||
'route_length',
|
'route_length',
|
||||||
'Number of nodes in the route',
|
'Number of nodes in the route',
|
||||||
self._get_common_labels(),
|
self._get_common_labels(),
|
||||||
|
|
14
main.py
14
main.py
|
@ -35,11 +35,23 @@ def handle_connect(client, userdata, flags, reason_code, properties):
|
||||||
client.subscribe(os.getenv('MQTT_TOPIC', 'msh/israel/#'))
|
client.subscribe(os.getenv('MQTT_TOPIC', 'msh/israel/#'))
|
||||||
|
|
||||||
|
|
||||||
|
def update_node_status(node_number, status):
|
||||||
|
with connection_pool.connection() as conn:
|
||||||
|
with conn.cursor() as cur:
|
||||||
|
cur.execute("INSERT INTO client_details (node_id, mqtt_status) VALUES (%s, %s)"
|
||||||
|
"ON CONFLICT(node_id)"
|
||||||
|
"DO UPDATE SET mqtt_status = %s", (node_number, status, status))
|
||||||
|
conn.commit()
|
||||||
|
|
||||||
|
|
||||||
def handle_message(client, userdata, message):
|
def handle_message(client, userdata, message):
|
||||||
current_timestamp = datetime.now().strftime('%Y-%m-%d %H:%M:%S')
|
current_timestamp = datetime.now().strftime('%Y-%m-%d %H:%M:%S')
|
||||||
print(f"Received message on topic '{message.topic}' at {current_timestamp}")
|
print(f"Received message on topic '{message.topic}' at {current_timestamp}")
|
||||||
if '/stat/' in message.topic:
|
if '/stat/' in message.topic:
|
||||||
print(f"Filtered out message from topic containing '/stat/': {message.topic}")
|
user_id = message.topic.split('/')[-1] # Hexadecimal user ID
|
||||||
|
if user_id[0] == '!':
|
||||||
|
node_number = str(int(user_id[1:], 16))
|
||||||
|
update_node_status(node_number, message.payload.decode('utf-8'))
|
||||||
return
|
return
|
||||||
|
|
||||||
envelope = ServiceEnvelope()
|
envelope = ServiceEnvelope()
|
||||||
|
|
|
@ -5,4 +5,5 @@ unishox2-py3~=1.0.0
|
||||||
cryptography~=42.0.8
|
cryptography~=42.0.8
|
||||||
psycopg~=3.1.19
|
psycopg~=3.1.19
|
||||||
psycopg_pool~=3.2.2
|
psycopg_pool~=3.2.2
|
||||||
meshtastic~=2.3.13
|
meshtastic~=2.3.13
|
||||||
|
psycopg-binary~=3.1.20
|
Loading…
Reference in a new issue