(plugin) network:🇦🇼:standard::snmp - fix license expired error (#4166)
This commit is contained in:
parent
b7f33d699a
commit
70baae18f4
|
@ -24,16 +24,25 @@ use base qw(centreon::plugins::templates::counter);
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::templates::catalog_functions qw(catalog_status_threshold);
|
use centreon::plugins::templates::catalog_functions qw(catalog_status_threshold_ng);
|
||||||
use Time::Local;
|
use Time::Local;
|
||||||
|
|
||||||
sub custom_status_output {
|
sub custom_status_output {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $msg = sprintf("Status is '%s', Expires in '%s' [%s]",
|
my $msg = "status is '" . $self->{result_values}->{flag} . "'";
|
||||||
$self->{result_values}->{flag},
|
if ($self->{result_values}->{expires_date} =~ /never/i) {
|
||||||
|
$msg .= ', never expires';
|
||||||
|
} elsif ($self->{result_values}->{expires_date} =~ /expired/i) {
|
||||||
|
$msg .= ', expired';
|
||||||
|
} else {
|
||||||
|
$msg .= sprintf(
|
||||||
|
"expires in %s [%s]",
|
||||||
$self->{result_values}->{expires_human},
|
$self->{result_values}->{expires_human},
|
||||||
$self->{result_values}->{expires_date});
|
$self->{result_values}->{expires_date}
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
return $msg;
|
return $msg;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -45,65 +54,62 @@ sub custom_status_calc {
|
||||||
$self->{result_values}->{service} = $options{new_datas}->{$self->{instance} . '_sysExtLicenseService'};
|
$self->{result_values}->{service} = $options{new_datas}->{$self->{instance} . '_sysExtLicenseService'};
|
||||||
$self->{result_values}->{expires} = $options{new_datas}->{$self->{instance} . '_sysExtLicenseExpires'};
|
$self->{result_values}->{expires} = $options{new_datas}->{$self->{instance} . '_sysExtLicenseExpires'};
|
||||||
$self->{result_values}->{expires_date} = $options{new_datas}->{$self->{instance} . '_sysExtLicenseExpires'};
|
$self->{result_values}->{expires_date} = $options{new_datas}->{$self->{instance} . '_sysExtLicenseExpires'};
|
||||||
$self->{result_values}->{expires_human} = 'Never';
|
|
||||||
|
|
||||||
if ($self->{result_values}->{expires} !~ /Never/) {
|
$self->{result_values}->{expires_human} = 'never';
|
||||||
|
if ($self->{result_values}->{expires_date} =~ /Expired/) {
|
||||||
|
$self->{result_values}->{expires_human} = 'expired';
|
||||||
|
$self->{result_values}->{expires} = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($self->{result_values}->{expires_date} !~ /Never|Expired/) {
|
||||||
my ($year, $mon, $mday, $hour, $min, $sec) = split(/[\s\-:]+/, $self->{result_values}->{expires});
|
my ($year, $mon, $mday, $hour, $min, $sec) = split(/[\s\-:]+/, $self->{result_values}->{expires});
|
||||||
$self->{result_values}->{expires} = timelocal($sec, $min, $hour, $mday, $mon - 1, $year) - time();
|
$self->{result_values}->{expires} = timelocal($sec, $min, $hour, $mday, $mon - 1, $year) - time();
|
||||||
$self->{result_values}->{expires_human} = centreon::plugins::misc::change_seconds(value => $self->{result_values}->{expires});
|
$self->{result_values}->{expires_human} = centreon::plugins::misc::change_seconds(value => $self->{result_values}->{expires});
|
||||||
$self->{result_values}->{expires_human} = $self->{result_values}->{expires} = 0 if ($self->{result_values}->{expires} < 0);
|
$self->{result_values}->{expires_human} = $self->{result_values}->{expires} = 0 if ($self->{result_values}->{expires} < 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
sub set_counters {
|
|
||||||
my ($self, %options) = @_;
|
|
||||||
|
|
||||||
$self->{maps_counters_type} = [
|
|
||||||
{ name => 'license', type => 1, cb_prefix_output => 'prefix_output',
|
|
||||||
message_multiple => 'All licenses status are ok' },
|
|
||||||
];
|
|
||||||
|
|
||||||
$self->{maps_counters}->{license} = [
|
|
||||||
{ label => 'status', threshold => 0, set => {
|
|
||||||
key_values => [ { name => 'sysExtLicenseKey' }, { name => 'sysExtLicenseFlags' },
|
|
||||||
{ name => 'sysExtLicenseService' }, { name => 'sysExtLicenseExpires' } ],
|
|
||||||
closure_custom_calc => $self->can('custom_status_calc'),
|
|
||||||
closure_custom_output => $self->can('custom_status_output'),
|
|
||||||
closure_custom_perfdata => sub { return 0; },
|
|
||||||
closure_custom_threshold_check => \&catalog_status_threshold,
|
|
||||||
}
|
|
||||||
},
|
|
||||||
];
|
|
||||||
}
|
|
||||||
|
|
||||||
sub prefix_output {
|
sub prefix_output {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
return "License '" . $options{instance_value}->{sysExtLicenseService} . "' ";
|
return "License '" . $options{instance_value}->{sysExtLicenseService} . "' ";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sub set_counters {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
$self->{maps_counters_type} = [
|
||||||
|
{ name => 'license', type => 1, cb_prefix_output => 'prefix_output', message_multiple => 'All licenses status are ok' }
|
||||||
|
];
|
||||||
|
|
||||||
|
$self->{maps_counters}->{license} = [
|
||||||
|
{ label => 'status', type => 2, critical_default => '%{flag} !~ /enabled/i || (%{expires} ne "Never" && %{expires} < 86400)', set => {
|
||||||
|
key_values => [
|
||||||
|
{ name => 'sysExtLicenseKey' }, { name => 'sysExtLicenseFlags' },
|
||||||
|
{ name => 'sysExtLicenseService' }, { name => 'sysExtLicenseExpires' }
|
||||||
|
],
|
||||||
|
closure_custom_calc => $self->can('custom_status_calc'),
|
||||||
|
closure_custom_output => $self->can('custom_status_output'),
|
||||||
|
closure_custom_perfdata => sub { return 0; },
|
||||||
|
closure_custom_threshold_check => \&catalog_status_threshold_ng
|
||||||
|
}
|
||||||
|
}
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
my ($class, %options) = @_;
|
my ($class, %options) = @_;
|
||||||
my $self = $class->SUPER::new(package => __PACKAGE__, %options, force_new_perfdata => 1);
|
my $self = $class->SUPER::new(package => __PACKAGE__, %options, force_new_perfdata => 1);
|
||||||
bless $self, $class;
|
bless $self, $class;
|
||||||
|
|
||||||
$options{options}->add_options(arguments => {
|
$options{options}->add_options(arguments => {
|
||||||
"warning-status:s" => { name => 'warning_status' },
|
|
||||||
"critical-status:s" => { name => 'critical_status',
|
|
||||||
default => '%{flag} !~ /enabled/i || (%{expires} ne "Never" && %{expires} < 86400)' },
|
|
||||||
});
|
});
|
||||||
|
|
||||||
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_flags = (
|
my %map_flags = (
|
||||||
'E' => 'enabled', 'A' => 'auto-generated', 'R' => 'reboot-required'
|
'E' => 'enabled', 'A' => 'auto-generated', 'R' => 'reboot-required'
|
||||||
);
|
);
|
||||||
|
@ -115,7 +121,7 @@ my $mapping = {
|
||||||
sysExtLicenseInstalled => { oid => '.1.3.6.1.4.1.14823.2.2.1.2.1.20.1.3' },
|
sysExtLicenseInstalled => { oid => '.1.3.6.1.4.1.14823.2.2.1.2.1.20.1.3' },
|
||||||
sysExtLicenseExpires => { oid => '.1.3.6.1.4.1.14823.2.2.1.2.1.20.1.4' },
|
sysExtLicenseExpires => { oid => '.1.3.6.1.4.1.14823.2.2.1.2.1.20.1.4' },
|
||||||
sysExtLicenseFlags => { oid => '.1.3.6.1.4.1.14823.2.2.1.2.1.20.1.5', map => \%map_flags },
|
sysExtLicenseFlags => { oid => '.1.3.6.1.4.1.14823.2.2.1.2.1.20.1.5', map => \%map_flags },
|
||||||
sysExtLicenseService => { oid => '.1.3.6.1.4.1.14823.2.2.1.2.1.20.1.6' },
|
sysExtLicenseService => { oid => '.1.3.6.1.4.1.14823.2.2.1.2.1.20.1.6' }
|
||||||
};
|
};
|
||||||
|
|
||||||
sub manage_selection {
|
sub manage_selection {
|
||||||
|
@ -133,7 +139,6 @@ sub manage_selection {
|
||||||
}
|
}
|
||||||
|
|
||||||
$self->{license} = {};
|
$self->{license} = {};
|
||||||
|
|
||||||
foreach my $oid (keys %{$snmp_result}) {
|
foreach my $oid (keys %{$snmp_result}) {
|
||||||
next if ($oid !~ /^$mapping->{sysExtLicenseKey}->{oid}\.(.*)/);
|
next if ($oid !~ /^$mapping->{sysExtLicenseKey}->{oid}\.(.*)/);
|
||||||
my $instance = $1;
|
my $instance = $1;
|
||||||
|
|
Loading…
Reference in New Issue