use new status threshold
This commit is contained in:
parent
156e58966b
commit
db14129d93
|
@ -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
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue