Merge branch '187-proteccion-en-cascada-por-modulo-integria-4112' into 'develop'

Add support for per-module alert cascade protection.

See merge request !479
This commit is contained in:
vgilc 2017-05-17 13:35:44 +02:00
commit a2e728679e
1 changed files with 16 additions and 4 deletions

View File

@ -4069,17 +4069,29 @@ sub pandora_inhibit_alerts {
return 0 if ($agent->{'cascade_protection'} ne '1' || $agent->{'id_parent'} eq '0' || $depth > 1024); return 0 if ($agent->{'cascade_protection'} ne '1' || $agent->{'id_parent'} eq '0' || $depth > 1024);
# Are any of the parent's critical alerts fired? # Are any of the parent's critical alerts fired?
my $count = get_db_value ($dbh, 'SELECT COUNT(*) FROM tagente_modulo, talert_template_modules, talert_templates my $count = 0;
if ($agent->{'cascade_protection_module'} != 0) {
$count = get_db_value ($dbh, 'SELECT COUNT(*) FROM tagente_modulo, talert_template_modules, talert_templates
WHERE tagente_modulo.id_agente = ?
AND tagente_modulo.id_agente_modulo = ?
AND tagente_modulo.id_agente_modulo = talert_template_modules.id_agent_module
AND tagente_modulo.disabled = 0
AND talert_template_modules.id_alert_template = talert_templates.id
AND talert_template_modules.times_fired > 0
AND talert_templates.priority = 4', $agent->{'id_parent'}, $agent->{'cascade_protection_module'});
}
else {
$count = get_db_value ($dbh, 'SELECT COUNT(*) FROM tagente_modulo, talert_template_modules, talert_templates
WHERE tagente_modulo.id_agente = ? WHERE tagente_modulo.id_agente = ?
AND tagente_modulo.id_agente_modulo = talert_template_modules.id_agent_module AND tagente_modulo.id_agente_modulo = talert_template_modules.id_agent_module
AND tagente_modulo.disabled = 0 AND tagente_modulo.disabled = 0
AND talert_template_modules.id_alert_template = talert_templates.id AND talert_template_modules.id_alert_template = talert_templates.id
AND talert_template_modules.times_fired > 0 AND talert_template_modules.times_fired > 0
AND talert_templates.priority = 4', $agent->{'id_parent'}); AND talert_templates.priority = 4', $agent->{'id_parent'});
return 1 if ($count > 0); }
return 1 if (defined($count) && $count > 0);
# Check the parent's parent next # Check the parent's parent next
$agent = get_db_single_row ($dbh, 'SELECT * FROM tagente WHERE id_agente = ?', $agent->{'id_parent'}); $agent = get_db_single_row ($dbh, 'SELECT * FROM tagente WHERE id_agente = ?', $agent->{'id_parent'});
return 0 unless defined ($agent); return 0 unless defined ($agent);