some fix on kaspersky

This commit is contained in:
garnier-quentin 2021-01-11 15:47:59 +01:00
parent ea414df3e3
commit 7ba1bd547a
6 changed files with 103 additions and 86 deletions

View File

@ -42,9 +42,12 @@ sub custom_status_calc {
sub custom_progress_perfdata { sub custom_progress_perfdata {
my ($self, %options) = @_; my ($self, %options) = @_;
$self->{output}->perfdata_add(label => 'progress', $self->{output}->perfdata_add(
value => $self->{result_values}->{installed}, label => 'progress',
min => 0, max => $self->{result_values}->{total}); nlabel => $self->{nlabel},
value => $self->{result_values}->{installed},
min => 0, max => $self->{result_values}->{total}
);
} }
sub custom_progress_threshold { sub custom_progress_threshold {
@ -52,9 +55,13 @@ sub custom_progress_threshold {
my ($exit, $threshold_value); my ($exit, $threshold_value);
$threshold_value = defined($self->{instance_mode}->{option_results}->{percent}) ? $self->{result_values}->{prct_installed} : $self->{result_values}->{installed} ; $threshold_value = defined($self->{instance_mode}->{option_results}->{percent}) ? $self->{result_values}->{prct_installed} : $self->{result_values}->{installed} ;
$exit = $self->{perfdata}->threshold_check(value => $threshold_value, $exit = $self->{perfdata}->threshold_check(
threshold => [ { label => 'critical-' . $self->{label}, exit_litteral => 'critical' }, value => $threshold_value,
{ label => 'warning-' . $self->{label}, exit_litteral => 'warning' } ]); threshold => [
{ label => 'critical-' . $self->{thlabel}, exit_litteral => 'critical' },
{ label => 'warning-' . $self->{thlabel}, exit_litteral => 'warning' }
]
);
return $exit; return $exit;
} }
@ -82,19 +89,26 @@ sub custom_progress_calc {
sub custom_expiring_perfdata { sub custom_expiring_perfdata {
my ($self, %options) = @_; my ($self, %options) = @_;
$self->{output}->perfdata_add(label => 'expiring', $self->{output}->perfdata_add(
value => $self->{result_values}->{expiring}, label => 'expiring',
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning-' . $self->{label}), nlabel => $self->{nlabel},
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical-' . $self->{label}), value => $self->{result_values}->{expiring},
min => 0); warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning-' . $self->{thlabel}),
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical-' . $self->{thlabel}),
min => 0
);
} }
sub custom_expiring_threshold { sub custom_expiring_threshold {
my ($self, %options) = @_; my ($self, %options) = @_;
my $exit = $self->{perfdata}->threshold_check(value => $self->{result_values}->{expiring}, my $exit = $self->{perfdata}->threshold_check(
threshold => [ { label => 'critical-' . $self->{label}, exit_litteral => 'critical' }, value => $self->{result_values}->{expiring},
{ label => 'warning-' . $self->{label}, exit_litteral => 'warning' } ]); threshold => [
{ label => 'critical-' . $self->{thlabel}, exit_litteral => 'critical' },
{ label => 'warning-' . $self->{thlabel}, exit_litteral => 'warning' }
]
);
return $exit; return $exit;
} }
@ -119,19 +133,26 @@ sub custom_expiring_calc {
sub custom_expired_perfdata { sub custom_expired_perfdata {
my ($self, %options) = @_; my ($self, %options) = @_;
$self->{output}->perfdata_add(label => 'expired', $self->{output}->perfdata_add(
value => $self->{result_values}->{expired}, label => 'expired',
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning-' . $self->{label}), nlabel => $self->{nlabel},
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical-' . $self->{label}), value => $self->{result_values}->{expired},
min => 0); warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning-' . $self->{thlabel}),
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical-' . $self->{thlabel}),
min => 0
);
} }
sub custom_expired_threshold { sub custom_expired_threshold {
my ($self, %options) = @_; my ($self, %options) = @_;
my $exit = $self->{perfdata}->threshold_check(value => $self->{result_values}->{expired}, my $exit = $self->{perfdata}->threshold_check(
threshold => [ { label => 'critical-' . $self->{label}, exit_litteral => 'critical' }, value => $self->{result_values}->{expired},
{ label => 'warning-' . $self->{label}, exit_litteral => 'warning' } ]); threshold => [
{ label => 'critical-' . $self->{thlabel}, exit_litteral => 'critical' },
{ label => 'warning-' . $self->{thlabel}, exit_litteral => 'warning' }
]
);
return $exit; return $exit;
} }
@ -224,7 +245,7 @@ my %map_status = (
0 => 'OK', 0 => 'OK',
1 => 'Info', 1 => 'Info',
2 => 'Warning', 2 => 'Warning',
3 => 'Critical', 3 => 'Critical'
); );
my $oid_deploymentStatus = '.1.3.6.1.4.1.23668.1093.1.1.1'; my $oid_deploymentStatus = '.1.3.6.1.4.1.23668.1093.1.1.1';
@ -240,14 +261,16 @@ my $oid_hostsLicenceExpired = '.1.3.6.1.4.1.23668.1093.1.1.10';
sub manage_selection { sub manage_selection {
my ($self, %options) = @_; my ($self, %options) = @_;
my $snmp_result = $options{snmp}->get_leef(oids => [ $oid_deploymentStatus, $oid_hostsInGroups, my $snmp_result = $options{snmp}->get_leef(
$oid_hostsWithAntivirus, $oid_hostsRemoteInstallFailed, oids => [
$oid_licenceExpiringSerial, $oid_licenceExpiredSerial, $oid_deploymentStatus, $oid_hostsInGroups,
$oid_licenceExpiringDays, $oid_hostsLicenceExpiring, $oid_hostsWithAntivirus, $oid_hostsRemoteInstallFailed,
$oid_hostsLicenceExpired ], $oid_licenceExpiringSerial, $oid_licenceExpiredSerial,
nothing_quit => 1); $oid_licenceExpiringDays, $oid_hostsLicenceExpiring,
$oid_hostsLicenceExpired
$self->{global} = {}; ],
nothing_quit => 1
);
$self->{global} = { $self->{global} = {
deploymentStatus => $map_status{$snmp_result->{$oid_deploymentStatus}}, deploymentStatus => $map_status{$snmp_result->{$oid_deploymentStatus}},

View File

@ -49,14 +49,15 @@ sub set_counters {
$self->{maps_counters}->{global} = [ $self->{maps_counters}->{global} = [
{ {
label => 'status', label => 'status',
type => 2, warning_default => '%{status} =~ /Warning/i', type => 2,
warning_default => '%{status} =~ /Warning/i',
critical_default => '%{status} =~ /Critical/i', critical_default => '%{status} =~ /Critical/i',
set => { set => {
key_values => [ { name => 'eventsStatus' } ], key_values => [ { name => 'eventsStatus' } ],
closure_custom_calc => $self->can('custom_status_calc'), closure_custom_calc => $self->can('custom_status_calc'),
closure_custom_output => $self->can('custom_status_output'), closure_custom_output => $self->can('custom_status_output'),
closure_custom_perfdata => sub { return 0; }, closure_custom_perfdata => sub { return 0; },
closure_custom_threshold_check => \&catalog_status_threshold_ng, closure_custom_threshold_check => \&catalog_status_threshold_ng
} }
}, },
{ label => 'events', nlabel => 'events.critical.count', set => { { label => 'events', nlabel => 'events.critical.count', set => {
@ -81,18 +82,11 @@ sub new {
return $self; return $self;
} }
sub check_options {
my ($self, %options) = @_;
$self->SUPER::check_options(%options);
$self->change_macros(macros => ['warning_status', 'critical_status']);
}
my %map_status = ( my %map_status = (
0 => 'OK', 0 => 'OK',
1 => 'Info', 1 => 'Info',
2 => 'Warning', 2 => 'Warning',
3 => 'Critical', 3 => 'Critical'
); );
my $oid_eventsStatus = '.1.3.6.1.4.1.23668.1093.1.6.1'; my $oid_eventsStatus = '.1.3.6.1.4.1.23668.1093.1.6.1';
@ -101,14 +95,16 @@ my $oid_criticalEventsCount = '.1.3.6.1.4.1.23668.1093.1.6.3';
sub manage_selection { sub manage_selection {
my ($self, %options) = @_; my ($self, %options) = @_;
my $snmp_result = $options{snmp}->get_leef(oids => [ $oid_eventsStatus, $oid_criticalEventsCount ], my $snmp_result = $options{snmp}->get_leef(
nothing_quit => 1); oids => [
$oid_eventsStatus, $oid_criticalEventsCount
$self->{global} = {}; ],
nothing_quit => 1
);
$self->{global} = { $self->{global} = {
eventsStatus => $map_status{$snmp_result->{$oid_eventsStatus}}, eventsStatus => $map_status{$snmp_result->{$oid_eventsStatus}},
criticalEventsCount => $snmp_result->{$oid_criticalEventsCount}, criticalEventsCount => $snmp_result->{$oid_criticalEventsCount}
}; };
} }

View File

@ -49,14 +49,15 @@ sub set_counters {
$self->{maps_counters}->{global} = [ $self->{maps_counters}->{global} = [
{ {
label => 'status', label => 'status',
type => 2, warning_default => '%{status} =~ /Warning/i', type => 2,
warning_default => '%{status} =~ /Warning/i',
critical_default => '%{status} =~ /Critical/i', critical_default => '%{status} =~ /Critical/i',
set => { set => {
key_values => [ { name => 'fullscanStatus' } ], key_values => [ { name => 'fullscanStatus' } ],
closure_custom_calc => $self->can('custom_status_calc'), closure_custom_calc => $self->can('custom_status_calc'),
closure_custom_output => $self->can('custom_status_output'), closure_custom_output => $self->can('custom_status_output'),
closure_custom_perfdata => sub { return 0; }, closure_custom_perfdata => sub { return 0; },
closure_custom_threshold_check => \&catalog_status_threshold, closure_custom_threshold_check => \&catalog_status_threshold_ng
} }
}, },
{ label => 'not-scanned', nlabel => 'hosts.unscanned.count', set => { { label => 'not-scanned', nlabel => 'hosts.unscanned.count', set => {
@ -85,7 +86,7 @@ my %map_status = (
0 => 'OK', 0 => 'OK',
1 => 'Info', 1 => 'Info',
2 => 'Warning', 2 => 'Warning',
3 => 'Critical', 3 => 'Critical'
); );
my $oid_fullscanStatus = '.1.3.6.1.4.1.23668.1093.1.4.1'; my $oid_fullscanStatus = '.1.3.6.1.4.1.23668.1093.1.4.1';
@ -94,14 +95,14 @@ my $oid_hostsNotScannedLately = '.1.3.6.1.4.1.23668.1093.1.4.3';
sub manage_selection { sub manage_selection {
my ($self, %options) = @_; my ($self, %options) = @_;
my $snmp_result = $options{snmp}->get_leef(oids => [ $oid_fullscanStatus, $oid_hostsNotScannedLately ], my $snmp_result = $options{snmp}->get_leef(
nothing_quit => 1); oids => [ $oid_fullscanStatus, $oid_hostsNotScannedLately ],
nothing_quit => 1
$self->{global} = {}; );
$self->{global} = { $self->{global} = {
fullscanStatus => $map_status{$snmp_result->{$oid_fullscanStatus}}, fullscanStatus => $map_status{$snmp_result->{$oid_fullscanStatus}},
hostsNotScannedLately => $snmp_result->{$oid_hostsNotScannedLately}, hostsNotScannedLately => $snmp_result->{$oid_hostsNotScannedLately}
}; };
} }

View File

@ -57,7 +57,7 @@ sub set_counters {
closure_custom_calc => $self->can('custom_status_calc'), closure_custom_calc => $self->can('custom_status_calc'),
closure_custom_output => $self->can('custom_status_output'), closure_custom_output => $self->can('custom_status_output'),
closure_custom_perfdata => sub { return 0; }, closure_custom_perfdata => sub { return 0; },
closure_custom_threshold_check => \&catalog_status_threshold_ng, closure_custom_threshold_check => \&catalog_status_threshold_ng
} }
}, },
{ label => 'new-hosts', nlabel => 'hosts.new.count', set => { { label => 'new-hosts', nlabel => 'hosts.new.count', set => {
@ -106,18 +106,11 @@ sub new {
return $self; return $self;
} }
sub check_options {
my ($self, %options) = @_;
$self->SUPER::check_options(%options);
$self->change_macros(macros => ['warning_status', 'critical_status']);
}
my %map_status = ( my %map_status = (
0 => 'OK', 0 => 'OK',
1 => 'Info', 1 => 'Info',
2 => 'Warning', 2 => 'Warning',
3 => 'Critical', 3 => 'Critical'
); );
my $oid_logicalNetworkStatus = '.1.3.6.1.4.1.23668.1093.1.5.1'; my $oid_logicalNetworkStatus = '.1.3.6.1.4.1.23668.1093.1.5.1';
@ -129,19 +122,21 @@ my $oid_hostsControlLost = '.1.3.6.1.4.1.23668.1093.1.5.6';
sub manage_selection { sub manage_selection {
my ($self, %options) = @_; my ($self, %options) = @_;
my $snmp_result = $options{snmp}->get_leef(oids => [ $oid_logicalNetworkStatus, $oid_hostsFound, my $snmp_result = $options{snmp}->get_leef(
$oid_groupsCount, $oid_hostsNotConnectedLongTime, oids => [
$oid_hostsControlLost ], $oid_logicalNetworkStatus, $oid_hostsFound,
nothing_quit => 1); $oid_groupsCount, $oid_hostsNotConnectedLongTime,
$oid_hostsControlLost
$self->{global} = {}; ],
nothing_quit => 1
);
$self->{global} = { $self->{global} = {
logicalNetworkStatus => $map_status{$snmp_result->{$oid_logicalNetworkStatus}}, logicalNetworkStatus => $map_status{$snmp_result->{$oid_logicalNetworkStatus}},
hostsFound => $snmp_result->{$oid_hostsFound}, hostsFound => $snmp_result->{$oid_hostsFound},
groupsCount => $snmp_result->{$oid_groupsCount}, groupsCount => $snmp_result->{$oid_groupsCount},
hostsNotConnectedLongTime => $snmp_result->{$oid_hostsNotConnectedLongTime}, hostsNotConnectedLongTime => $snmp_result->{$oid_hostsNotConnectedLongTime},
hostsControlLost => $snmp_result->{$oid_hostsControlLost}, hostsControlLost => $snmp_result->{$oid_hostsControlLost}
}; };
} }

View File

@ -29,8 +29,7 @@ use centreon::plugins::templates::catalog_functions qw(catalog_status_threshold_
sub custom_status_output { sub custom_status_output {
my ($self, %options) = @_; my ($self, %options) = @_;
my $msg = sprintf("Protection status is '%s'", $self->{result_values}->{status}); return sprintf("Protection status is '%s'", $self->{result_values}->{status});
return $msg;
} }
sub custom_status_calc { sub custom_status_calc {
@ -58,7 +57,7 @@ sub set_counters {
closure_custom_calc => $self->can('custom_status_calc'), closure_custom_calc => $self->can('custom_status_calc'),
closure_custom_output => $self->can('custom_status_output'), closure_custom_output => $self->can('custom_status_output'),
closure_custom_perfdata => sub { return 0; }, closure_custom_perfdata => sub { return 0; },
closure_custom_threshold_check => \&catalog_status_threshold_ng, closure_custom_threshold_check => \&catalog_status_threshold_ng
} }
}, },
{ label => 'no-antivirus', nlabel => 'protection.hosts.antivirus.notrunning.count', set => { { label => 'no-antivirus', nlabel => 'protection.hosts.antivirus.notrunning.count', set => {
@ -89,8 +88,8 @@ sub set_counters {
key_values => [ { name => 'hostsNotCuredObject' } ], key_values => [ { name => 'hostsNotCuredObject' } ],
output_template => '%d host(s) with not cured objects', output_template => '%d host(s) with not cured objects',
perfdatas => [ perfdatas => [
{ label => 'not_cured_objects', value => 'hostsNotCuredObject', template => '%d', min => 0 }, { label => 'not_cured_objects', value => 'hostsNotCuredObject', template => '%d', min => 0 }
], ]
} }
}, },
{ label => 'too-many-threats', nlabel => 'protection.hosts.2manythreats.count', set => { { label => 'too-many-threats', nlabel => 'protection.hosts.2manythreats.count', set => {
@ -100,7 +99,7 @@ sub set_counters {
{ label => 'too_many_threats', template => '%d', min => 0 } { label => 'too_many_threats', template => '%d', min => 0 }
] ]
} }
}, }
]; ];
} }
@ -119,7 +118,7 @@ my %map_status = (
0 => 'OK', 0 => 'OK',
1 => 'Info', 1 => 'Info',
2 => 'Warning', 2 => 'Warning',
3 => 'Critical', 3 => 'Critical'
); );
my $oid_protectionStatus = '.1.3.6.1.4.1.23668.1093.1.3.1'; my $oid_protectionStatus = '.1.3.6.1.4.1.23668.1093.1.3.1';
@ -132,12 +131,14 @@ my $oid_hostsTooManyThreats = '.1.3.6.1.4.1.23668.1093.1.3.7';
sub manage_selection { sub manage_selection {
my ($self, %options) = @_; my ($self, %options) = @_;
my $snmp_result = $options{snmp}->get_leef(oids => [ $oid_protectionStatus, $oid_hostsAntivirusNotRunning, my $snmp_result = $options{snmp}->get_leef(
$oid_hostsRealtimeNotRunning, $oid_hostsRealtimeLevelChanged, oids => [
$oid_hostsNotCuredObject, $oid_hostsTooManyThreats ], $oid_protectionStatus, $oid_hostsAntivirusNotRunning,
nothing_quit => 1); $oid_hostsRealtimeNotRunning, $oid_hostsRealtimeLevelChanged,
$oid_hostsNotCuredObject, $oid_hostsTooManyThreats
$self->{global} = {}; ],
nothing_quit => 1
);
$self->{global} = { $self->{global} = {
protectionStatus => $map_status{$snmp_result->{$oid_protectionStatus}}, protectionStatus => $map_status{$snmp_result->{$oid_protectionStatus}},
@ -145,7 +146,7 @@ sub manage_selection {
hostsRealtimeNotRunning => $snmp_result->{$oid_hostsRealtimeNotRunning}, hostsRealtimeNotRunning => $snmp_result->{$oid_hostsRealtimeNotRunning},
hostsRealtimeLevelChanged => $snmp_result->{$oid_hostsRealtimeLevelChanged}, hostsRealtimeLevelChanged => $snmp_result->{$oid_hostsRealtimeLevelChanged},
hostsNotCuredObject => $snmp_result->{$oid_hostsNotCuredObject}, hostsNotCuredObject => $snmp_result->{$oid_hostsNotCuredObject},
hostsTooManyThreats => $snmp_result->{$oid_hostsTooManyThreats}, hostsTooManyThreats => $snmp_result->{$oid_hostsTooManyThreats}
}; };
} }

View File

@ -46,6 +46,7 @@ sub custom_last_perfdata {
$self->{output}->perfdata_add( $self->{output}->perfdata_add(
label => 'last_server_update', label => 'last_server_update',
nlabel => $self->{nlabel},
value => $self->{result_values}->{diff}, value => $self->{result_values}->{diff},
unit => 's', unit => 's',
min => 0 min => 0
@ -58,8 +59,8 @@ sub custom_last_threshold {
my $exit = $self->{perfdata}->threshold_check( my $exit = $self->{perfdata}->threshold_check(
value => $self->{result_values}->{diff}, value => $self->{result_values}->{diff},
threshold => [ threshold => [
{ label => 'critical-' . $self->{label}, exit_litteral => 'critical' }, { label => 'critical-' . $self->{thlabel}, exit_litteral => 'critical' },
{ label => 'warning-' . $self->{label}, exit_litteral => 'warning' } { label => 'warning-' . $self->{thlabel}, exit_litteral => 'warning' }
] ]
); );
return $exit; return $exit;