(plugin) apps::protocols::nrpe - enhance perfdata management in NRPE … (#3703)
This commit is contained in:
parent
52664b4234
commit
dec60f5611
|
@ -24,6 +24,7 @@ use base qw(centreon::plugins::mode);
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
|
use centreon::plugins::misc;
|
||||||
use centreon::plugins::nrpe;
|
use centreon::plugins::nrpe;
|
||||||
|
|
||||||
my %errors_num = (0 => 'OK', 1 => 'WARNING', 2 => 'CRITICAL', 3 => 'UNKNOWN');
|
my %errors_num = (0 => 'OK', 1 => 'WARNING', 2 => 'CRITICAL', 3 => 'UNKNOWN');
|
||||||
|
@ -44,7 +45,8 @@ sub new {
|
||||||
|
|
||||||
if (!defined($options{noptions})) {
|
if (!defined($options{noptions})) {
|
||||||
$options{options}->add_options(arguments => {
|
$options{options}->add_options(arguments => {
|
||||||
'hostname:s' => { name => 'hostname' }
|
'hostname:s' => { name => 'hostname' },
|
||||||
|
'parse' => { name => 'parse' }
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
$options{options}->add_help(package => __PACKAGE__, sections => 'CUSTOM MODE OPTIONS', once => 1);
|
$options{options}->add_help(package => __PACKAGE__, sections => 'CUSTOM MODE OPTIONS', once => 1);
|
||||||
|
@ -68,25 +70,67 @@ sub check_options {
|
||||||
|
|
||||||
$self->{hostname} = (defined($self->{option_results}->{hostname})) ? $self->{option_results}->{hostname} : '';
|
$self->{hostname} = (defined($self->{option_results}->{hostname})) ? $self->{option_results}->{hostname} : '';
|
||||||
|
|
||||||
if (!defined($self->{hostname}) || $self->{hostname} eq '') {
|
if ($self->{hostname} eq '') {
|
||||||
$self->{output}->add_option_msg(short_msg => "Need to specify --hostname option.");
|
$self->{output}->add_option_msg(short_msg => "Need to specify --hostname option.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
$self->{nrpe}->check_options(option_results => $self->{option_results});
|
$self->{nrpe}->check_options(option_results => $self->{option_results});
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sub parse_plugin_output {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
my @lines = split(/\n/, $options{output});
|
||||||
|
my $short = 'no output';
|
||||||
|
my $line = shift(@lines);
|
||||||
|
if (defined($line) && $line =~ /^(.*?)(?:\|(.*)|\Z)/) {
|
||||||
|
$short = $1;
|
||||||
|
if (defined($2)) {
|
||||||
|
my $perf = $2;
|
||||||
|
while ($perf =~ /(.*?)=([0-9\.]+)([^0-9;]+?)?([0-9.@;]+?)?(?:\s+|\Z)/g) {
|
||||||
|
my ($label, $value, $unit, $extra) = ($1, $2, $3, $4);
|
||||||
|
$label = centreon::plugins::misc::trim($label);
|
||||||
|
$label =~ s/^'//;
|
||||||
|
$label =~ s/'$//;
|
||||||
|
my @extras = split(';', $extra);
|
||||||
|
push @{$options{result}->{perf}}, {
|
||||||
|
label => $label,
|
||||||
|
nlabel => $label,
|
||||||
|
unit => $unit,
|
||||||
|
value => $value,
|
||||||
|
warning => $extras[1],
|
||||||
|
critical => $extras[2],
|
||||||
|
min => $extras[3],
|
||||||
|
max => $extras[4]
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$options{result}->{message} = $short;
|
||||||
|
$options{result}->{long_message} = [];
|
||||||
|
foreach (@lines) {
|
||||||
|
push @{$options{result}->{long_message}}, $_;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
sub format_result {
|
sub format_result {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my %result = (
|
my $result = {
|
||||||
code => ($options{content}->{result_code} =~ /^[0-3]$/) ? $errors_num{$options{content}->{result_code}} : $options{content}->{result_code},
|
code => ($options{content}->{result_code} =~ /^[0-3]$/) ? $errors_num{$options{content}->{result_code}} : $options{content}->{result_code},
|
||||||
message => $options{content}->{buffer},
|
message => $options{content}->{buffer},
|
||||||
perf => []
|
perf => []
|
||||||
);
|
};
|
||||||
return \%result;
|
|
||||||
|
if (defined($self->{option_results}->{parse})) {
|
||||||
|
$self->parse_plugin_output(result => $result, output => $options{content}->{buffer});
|
||||||
|
}
|
||||||
|
|
||||||
|
return $result;
|
||||||
}
|
}
|
||||||
|
|
||||||
sub request {
|
sub request {
|
||||||
|
@ -94,9 +138,7 @@ sub request {
|
||||||
|
|
||||||
my ($content) = $self->{nrpe}->request(check => $options{command}, arg => $options{arg});
|
my ($content) = $self->{nrpe}->request(check => $options{command}, arg => $options{arg});
|
||||||
|
|
||||||
my $result = $self->format_result(content => $content);
|
return $self->format_result(content => $content);
|
||||||
|
|
||||||
return $result;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
1;
|
1;
|
||||||
|
@ -117,6 +159,10 @@ NRPE protocol
|
||||||
|
|
||||||
Remote hostname or IP address.
|
Remote hostname or IP address.
|
||||||
|
|
||||||
|
=item B<--parse>
|
||||||
|
|
||||||
|
Parse remote plugin output.
|
||||||
|
|
||||||
=back
|
=back
|
||||||
|
|
||||||
=head1 DESCRIPTION
|
=head1 DESCRIPTION
|
||||||
|
|
|
@ -69,22 +69,28 @@ sub sanitize_message {
|
||||||
|
|
||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $result = $options{custom}->request(
|
my $result = $options{custom}->request(
|
||||||
command => $self->{option_results}->{command},
|
command => $self->{option_results}->{command},
|
||||||
arg => $self->{option_results}->{arg}
|
arg => $self->{option_results}->{arg}
|
||||||
);
|
);
|
||||||
|
|
||||||
$self->{output}->output_add(
|
$self->{output}->output_add(
|
||||||
severity => $result->{code},
|
severity => $result->{code},
|
||||||
short_msg => $self->sanitize_message(message => $result->{message})
|
short_msg => $self->sanitize_message(message => $result->{message})
|
||||||
);
|
);
|
||||||
|
|
||||||
|
if (defined($result->{long_message})) {
|
||||||
|
foreach (@{$result->{long_message}}) {
|
||||||
|
$self->{output}->output_add(long_msg => $_);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
foreach (@{$result->{perf}}) {
|
foreach (@{$result->{perf}}) {
|
||||||
$self->{output}->perfdata_add(%{$_});
|
$self->{output}->perfdata_add(%{$_});
|
||||||
}
|
}
|
||||||
$self->{display_options}->{force_ignore_perfdata} = 1 if (scalar(@{$result->{perf}}) == 0);
|
$self->{display_options}->{force_ignore_perfdata} = 1 if (scalar(@{$result->{perf}}) == 0);
|
||||||
|
|
||||||
$self->{output}->display(%{$self->{display_options}});
|
$self->{output}->display(%{$self->{display_options}});
|
||||||
$self->{output}->exit();
|
$self->{output}->exit();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue