use new status threshold

This commit is contained in:
tcharles 2019-01-17 15:34:15 +01:00 committed by Colin Gagnaire
parent 156e58966b
commit db14129d93
1 changed files with 6 additions and 40 deletions

View File

@ -25,32 +25,7 @@
use strict; use strict;
use warnings; use warnings;
use DateTime; use DateTime;
use centreon::plugins::templates::catalog_functions qw(catalog_status_threshold);
my $instance_mode;
sub custom_status_threshold {
my ($self, %options) = @_;
my $status = 'ok';
my $message;
eval {
local $SIG{__WARN__} = sub { $message = $_[0]; };
local $SIG{__DIE__} = sub { $message = $_[0]; };
if (defined($instance_mode->{option_results}->{critical_status}) && $instance_mode->{option_results}->{critical_status} ne '' &&
eval "$instance_mode->{option_results}->{critical_status}") {
$status = 'critical';
} elsif (defined($instance_mode->{option_results}->{warning_status}) && $instance_mode->{option_results}->{warning_status} ne '' &&
eval "$instance_mode->{option_results}->{warning_status}") {
$status = 'warning';
}
};
if (defined($message)) {
$self->{output}->output_add(long_msg => 'filter status issue: ' . $message);
}
return $status;
}
sub custom_status_output { sub custom_status_output {
my ($self, %options) = @_; my ($self, %options) = @_;
@ -89,6 +64,7 @@
sub prefix_output { sub prefix_output {
my ($self, %options) = @_; my ($self, %options) = @_;
return "VTL deduplication '" . $options{instance_value}->{name} . "' "; return "VTL deduplication '" . $options{instance_value}->{name} . "' ";
} }
@ -106,7 +82,7 @@
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 => $self->can('custom_status_threshold'), closure_custom_threshold_check => \&catalog_status_threshold,
} }
}, },
{ label => 'original-data-size', set => { { label => 'original-data-size', set => {
@ -164,18 +140,7 @@
$self->{option_results}->{remote} = 1; $self->{option_results}->{remote} = 1;
} }
$instance_mode = $self; $self->change_macros(macros => ['warning_status', 'critical_status']);
$self->change_macros();
}
sub change_macros {
my ($self, %options) = @_;
foreach (('warning_status', 'critical_status')) {
if (defined($self->{option_results}->{$_})) {
$self->{option_results}->{$_} =~ s/%\{(.*?)\}/\$self->{result_values}->{$1}/g;
}
}
} }
sub manage_selection { sub manage_selection {
@ -241,6 +206,7 @@
1; 1;
__END__
=head1 MODE =head1 MODE