From d25ee8f128c85a3d08b5fdec86e1f49ffc76c997 Mon Sep 17 00:00:00 2001 From: Matt Visnovsky Date: Fri, 10 May 2024 10:56:38 -0600 Subject: [PATCH] Using JSON Query Expressions Equivalent functionality as before, but we're now building json-query expressions for the user. --- server/monitor-types/snmp.js | 23 +++++++++++++---------- 1 file changed, 13 insertions(+), 10 deletions(-) diff --git a/server/monitor-types/snmp.js b/server/monitor-types/snmp.js index b9dc39e8..60c46187 100644 --- a/server/monitor-types/snmp.js +++ b/server/monitor-types/snmp.js @@ -1,6 +1,7 @@ const { MonitorType } = require("./monitor-type"); const { UP, DOWN, log } = require("../../src/util"); const snmp = require("net-snmp"); +const jsonata = require("jsonata"); class SNMPMonitorType extends MonitorType { name = "snmp"; @@ -52,29 +53,31 @@ class SNMPMonitorType extends MonitorType { let snmpValue = isNaN(value) ? value.toString() : parseFloat(value); let snmpControlValue = isNaN(monitor.snmpControlValue) ? monitor.snmpControlValue.toString() : parseFloat(monitor.snmpControlValue); + let jsonQueryExpression; switch (monitor.snmpCondition) { case ">": - heartbeat.status = snmpValue > snmpControlValue ? UP : DOWN; - break; case ">=": - heartbeat.status = snmpValue >= snmpControlValue ? UP : DOWN; - break; case "<": - heartbeat.status = snmpValue < snmpControlValue ? UP : DOWN; - break; case "<=": - heartbeat.status = snmpValue <= snmpControlValue ? UP : DOWN; + jsonQueryExpression = `$.value ${monitor.snmpCondition} $.control`; break; case "==": - heartbeat.status = snmpValue.toString() === snmpControlValue.toString() ? UP : DOWN; + jsonQueryExpression = "$string($.value) = $string($.control)"; break; case "contains": - heartbeat.status = snmpValue.toString().includes(snmpControlValue.toString()) ? UP : DOWN; + jsonQueryExpression = "$contains($string($.value), $string($.control))"; break; default: throw new Error(`Invalid condition ${monitor.snmpCondition}`); } - heartbeat.msg = "SNMP value " + (heartbeat.status ? "passes" : "does not pass") + ` comparison: ${value.toString()} ${monitor.snmpCondition} ${snmpControlValue}`; + + const expression = jsonata(jsonQueryExpression); + const result = await expression.evaluate({ + value: snmpValue, + control: monitor.snmpControlValue + }); + heartbeat.status = result ? UP : DOWN; + heartbeat.msg = `SNMP value ${result ? "passes" : "does not pass"} comparison: ${snmpValue} ${monitor.snmpCondition} ${snmpControlValue}`; } catch (err) { heartbeat.status = DOWN;