mirror of
https://github.com/librenms/librenms.git
synced 2024-10-07 16:52:45 +00:00
Configurable Alert Rule default settings (#11152)
* configurable Alert Rule default settings * codeclimate fix#
This commit is contained in:
@@ -24,6 +24,7 @@
|
||||
*/
|
||||
|
||||
use LibreNMS\Alerting\QueryBuilderParser;
|
||||
use LibreNMS\Config;
|
||||
|
||||
header('Content-type: application/json');
|
||||
|
||||
@@ -40,19 +41,20 @@ if (is_numeric($template_id)) {
|
||||
$rules = get_rules_from_json();
|
||||
$rule = $rules[$template_id];
|
||||
$default_extra = [
|
||||
'mute' => false,
|
||||
'count' => '-1',
|
||||
'delay' => 60,
|
||||
'invert' => false,
|
||||
'interval' => 300,
|
||||
'recovery' => true,
|
||||
'mute' => Config::get('alert_rule.mute_alerts'),
|
||||
'count' => Config::get('alert_rule.max_alerts'),
|
||||
'delay' => 60 * Config::get('alert_rule.delay'),
|
||||
'invert' => Config::get('alert_rule.invert_rule_match'),
|
||||
'interval' => 60 * Config::get('alert_rule.interval'),
|
||||
'recovery' => Config::get('alert_rule.recovery_alerts'),
|
||||
];
|
||||
$output = [
|
||||
'status' => 'ok',
|
||||
'name' => $rule['name'],
|
||||
'builder' => $rule['builder'] ?: QueryBuilderParser::fromOld($rule['rule'])->toArray(),
|
||||
'extra' => array_replace($default_extra, (array)$rule['extra']),
|
||||
'severity' => $rule['severity'] ?: 'critical'
|
||||
'severity' => $rule['severity'] ?: Config::get('alert_rule.severity'),
|
||||
'invert_map' => Config::get('alert_rule.invert_map')
|
||||
];
|
||||
} else {
|
||||
$output = [
|
||||
|
@@ -13,6 +13,16 @@
|
||||
*/
|
||||
|
||||
use LibreNMS\Alerting\QueryBuilderFilter;
|
||||
use LibreNMS\Config;
|
||||
|
||||
$default_severity = Config::get('alert_rule.severity');
|
||||
$default_max_alerts = Config::get('alert_rule.max_alerts');
|
||||
$default_delay = Config::get('alert_rule.delay') . 'm';
|
||||
$default_interval = Config::get('alert_rule.interval') . 'm';
|
||||
$default_mute_alerts = Config::get('alert_rule.mute_alerts');
|
||||
$default_invert_rule_match = Config::get('alert_rule.invert_rule_match');
|
||||
$default_recovery_alerts = Config::get('alert_rule.recovery_alerts');
|
||||
$default_invert_map = Config::get('alert_rule.invert_map');
|
||||
|
||||
if (Auth::user()->hasGlobalAdmin()) {
|
||||
$filters = json_encode(new QueryBuilderFilter('alert'));
|
||||
@@ -292,17 +302,17 @@ if (Auth::user()->hasGlobalAdmin()) {
|
||||
$("#builder").queryBuilder("reset");
|
||||
var $severity = $('#severity');
|
||||
$severity.val($severity.find("option[selected]").val());
|
||||
$("#mute").bootstrapSwitch('state', false);
|
||||
$("#invert").bootstrapSwitch('state', false);
|
||||
$("#recovery").bootstrapSwitch('state', true);
|
||||
$("#mute").bootstrapSwitch('state', <?=$default_mute_alerts?>);
|
||||
$("#invert").bootstrapSwitch('state', <?=$default_invert_rule_match?>);
|
||||
$("#recovery").bootstrapSwitch('state', <?=$default_recovery_alerts?>);
|
||||
$("#override_query").bootstrapSwitch('state', false);
|
||||
$("#invert_map").bootstrapSwitch('state', false);
|
||||
$("#invert_map").bootstrapSwitch('state', <?=$default_invert_map?>);
|
||||
$(this).find("input[type=text]").val("");
|
||||
$('#count').val('1');
|
||||
$('#delay').val('1m');
|
||||
$('#interval').val('5m');
|
||||
$('#count').val('<?=$default_max_alerts?>');
|
||||
$('#delay').val('<?=$default_delay?>');
|
||||
$('#interval').val('<?=$default_interval?>');
|
||||
$('#adv_query').val('');
|
||||
$('#severity').val('warning');
|
||||
$('#severity').val('<?=$default_severity?>');
|
||||
|
||||
var $maps = $('#maps');
|
||||
$maps.empty();
|
||||
@@ -374,7 +384,7 @@ if (Auth::user()->hasGlobalAdmin()) {
|
||||
$("[name='mute']").bootstrapSwitch('state', extra.mute);
|
||||
$("[name='invert']").bootstrapSwitch('state', extra.invert);
|
||||
if (typeof extra.recovery == 'undefined') {
|
||||
extra.recovery = true;
|
||||
extra.recovery = '<?=$default_recovery_alerts?>';
|
||||
}
|
||||
|
||||
if (typeof extra.options == 'undefined') {
|
||||
@@ -393,7 +403,7 @@ if (Auth::user()->hasGlobalAdmin()) {
|
||||
|
||||
$("[name='override_query']").bootstrapSwitch('state', extra.options.override_query);
|
||||
} else {
|
||||
$('#count').val('1');
|
||||
$('#count').val('<?=$default_max_alerts?>');
|
||||
}
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user