mirror of
https://github.com/librenms/librenms.git
synced 2024-10-07 16:52:45 +00:00
Poller rewrite (Try 2) (#13525)
* core WIP * try to finish up * trim space too and a couple of cleanups * update test data * put escapes back * another net-snmp difference * correct copy paste error * WIP * Use new code YAY * a tiny bit more * Kind of working * Handle manual modules correctly * convert core to modern module * Only save metrics if modules is not overridden * correct module exists check * database error handling * debug handling * restore bad changes * Introduce Actions RunAlertRulesAction UpdateDeviceGroupsAction * tweaks to output * Fix some issues in outside code * Style fixes * fixes to module status checks * typehints! * Use logger only and DI * OS module not named correctly * Work on quiet output a bit more * generically don't change output when disabling debug if the driver is already stack * Fix missing $device variable for legacy os polling Fix missing dbFacile functions when no legacy modules polled in RunAlertRulesAction * restore legacy os module shim * use the new poller code for tests * PollingDevice event * Fix some issues and enable/disable error reporting around legacy modules * typehints * fully update baseline * Use Process for version commands so we don't leak debug output. * don't detect rrdtool version in ci every time * style fixes * Warning fixes * more fixes * re-update baseline * remove diff noise * fix up alerts * Catch exceptions in device ip lookup * Revert accidental snmp.inc.php poller target change (should have been ?: not ??)
This commit is contained in:
@@ -33,6 +33,7 @@ namespace LibreNMS\Alert;
|
||||
|
||||
use Carbon\Carbon;
|
||||
use LibreNMS\Enum\AlertState;
|
||||
use Log;
|
||||
|
||||
class AlertRules
|
||||
{
|
||||
@@ -57,7 +58,7 @@ class AlertRules
|
||||
}
|
||||
//Checks each rule.
|
||||
foreach (AlertUtil::getRules($device_id) as $rule) {
|
||||
c_echo('Rule %p#' . $rule['id'] . ' (' . $rule['name'] . '):%n ');
|
||||
Log::info('Rule %p#' . $rule['id'] . ' (' . $rule['name'] . '):%n ', ['color' => true]);
|
||||
$extra = json_decode($rule['extra'], true);
|
||||
if (isset($extra['invert'])) {
|
||||
$inv = (bool) $extra['invert'];
|
||||
@@ -90,9 +91,9 @@ class AlertRules
|
||||
$current_state = dbFetchCell('SELECT state FROM alerts WHERE rule_id = ? AND device_id = ? ORDER BY id DESC LIMIT 1', [$rule['id'], $device_id]);
|
||||
if ($doalert) {
|
||||
if ($current_state == AlertState::ACKNOWLEDGED) {
|
||||
c_echo('Status: %ySKIP');
|
||||
Log::info('Status: %ySKIP%n', ['color' => true]);
|
||||
} elseif ($current_state >= AlertState::ACTIVE) {
|
||||
c_echo('Status: %bNOCHG');
|
||||
Log::info('Status: %bNOCHG%n', ['color' => true]);
|
||||
// NOCHG here doesn't mean no change full stop. It means no change to the alert state
|
||||
// So we update the details column with any fresh changes to the alert output we might have.
|
||||
$alert_log = dbFetchRow('SELECT alert_log.id, alert_log.details FROM alert_log,alert_rules WHERE alert_log.rule_id = alert_rules.id && alert_log.device_id = ? && alert_log.rule_id = ? && alert_rules.disabled = 0
|
||||
@@ -113,12 +114,12 @@ class AlertRules
|
||||
} else {
|
||||
dbUpdate(['state' => AlertState::ACTIVE, 'open' => 1, 'timestamp' => Carbon::now()], 'alerts', 'device_id = ? && rule_id = ?', [$device_id, $rule['id']]);
|
||||
}
|
||||
c_echo(PHP_EOL . 'Status: %rALERT');
|
||||
Log::info(PHP_EOL . 'Status: %rALERT%n', ['color' => true]);
|
||||
}
|
||||
}
|
||||
} else {
|
||||
if (! is_null($current_state) && $current_state == AlertState::RECOVERED) {
|
||||
c_echo('Status: %bNOCHG');
|
||||
Log::info('Status: %bNOCHG%n', ['color' => true]);
|
||||
} else {
|
||||
if (dbInsert(['state' => AlertState::RECOVERED, 'device_id' => $device_id, 'rule_id' => $rule['id']], 'alert_log')) {
|
||||
if (is_null($current_state)) {
|
||||
@@ -127,11 +128,10 @@ class AlertRules
|
||||
dbUpdate(['state' => AlertState::RECOVERED, 'open' => 1, 'note' => '', 'timestamp' => Carbon::now()], 'alerts', 'device_id = ? && rule_id = ?', [$device_id, $rule['id']]);
|
||||
}
|
||||
|
||||
c_echo(PHP_EOL . 'Status: %gOK');
|
||||
Log::info(PHP_EOL . 'Status: %gOK%n', ['color' => true]);
|
||||
}
|
||||
}
|
||||
}
|
||||
c_echo('%n' . PHP_EOL);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user