remote empty lines

This commit is contained in:
garnier-quentin 2019-11-25 15:05:42 +01:00
parent c03971376e
commit 9cbc3133fa
1 changed files with 72 additions and 72 deletions

View File

@ -54,14 +54,14 @@ sub new {
'disco-show' => { name => 'disco_show' }, 'disco-show' => { name => 'disco_show' },
'float-precision:s' => { name => 'float_precision', default => 8 }, 'float-precision:s' => { name => 'float_precision', default => 8 },
}); });
%{$self->{option_results}} = (); %{$self->{option_results}} = ();
$self->{option_msg} = []; $self->{option_msg} = [];
$self->{nodisplay} = 0; $self->{nodisplay} = 0;
$self->{noexit_die} = 0; $self->{noexit_die} = 0;
$self->{is_output_xml} = 0; $self->{is_output_xml} = 0;
$self->{is_output_json} = 0; $self->{is_output_json} = 0;
$self->{errors} = {OK => 0, WARNING => 1, CRITICAL => 2, UNKNOWN => 3, PENDING => 4}; $self->{errors} = {OK => 0, WARNING => 1, CRITICAL => 2, UNKNOWN => 3, PENDING => 4};
@ -106,7 +106,7 @@ sub check_options {
$self->{option_results}->{output_xml} = 1; $self->{option_results}->{output_xml} = 1;
} }
} }
if (defined($self->{option_results}->{range_perfdata})) { if (defined($self->{option_results}->{range_perfdata})) {
$self->{range_perfdata} = $self->{option_results}->{range_perfdata}; $self->{range_perfdata} = $self->{option_results}->{range_perfdata};
$self->{range_perfdata} = 1 if ($self->{range_perfdata} eq ''); $self->{range_perfdata} = 1 if ($self->{range_perfdata} eq '');
@ -115,7 +115,7 @@ sub check_options {
$self->option_exit(); $self->option_exit();
} }
} }
if (defined($self->{option_results}->{explode_perfdata_max})) { if (defined($self->{option_results}->{explode_perfdata_max})) {
if (${$self->{option_results}->{explode_perfdata_max}}[0] eq '') { if (${$self->{option_results}->{explode_perfdata_max}}[0] eq '') {
$self->{explode_perfdata_total} = 2; $self->{explode_perfdata_total} = 2;
@ -131,7 +131,7 @@ sub check_options {
} }
} }
} }
$self->load_perfdata_extend_args(); $self->load_perfdata_extend_args();
$self->{option_results}->{use_new_perfdata} = 1 if (defined($self->{option_results}->{output_openmetrics})); $self->{option_results}->{use_new_perfdata} = 1 if (defined($self->{option_results}->{output_openmetrics}));
} }
@ -141,7 +141,7 @@ sub add_option_msg {
# $options{short_msg} = string msg # $options{short_msg} = string msg
# $options{long_msg} = string msg # $options{long_msg} = string msg
$options{severity} = 'UNQUALIFIED_YET'; $options{severity} = 'UNQUALIFIED_YET';
$self->output_add(%options); $self->output_add(%options);
} }
@ -166,7 +166,7 @@ sub output_add {
long_msg => undef, long_msg => undef,
); );
my $options = {%args, %params}; my $options = {%args, %params};
if (defined($options->{short_msg})) { if (defined($options->{short_msg})) {
chomp $options->{short_msg}; chomp $options->{short_msg};
if (defined($self->{global_short_concat_outputs}->{uc($options->{severity})})) { if (defined($self->{global_short_concat_outputs}->{uc($options->{severity})})) {
@ -194,7 +194,7 @@ sub perfdata_add {
next if (!defined($options{$_})); next if (!defined($options{$_}));
$perfdata->{$_} = $options{$_}; $perfdata->{$_} = $options{$_};
} }
if (defined($self->{option_results}->{use_new_perfdata}) && defined($options{nlabel})) { if (defined($self->{option_results}->{use_new_perfdata}) && defined($options{nlabel})) {
$perfdata->{label} = $options{nlabel}; $perfdata->{label} = $options{nlabel};
} }
@ -207,14 +207,14 @@ sub perfdata_add {
$perfdata->{label} .= '_' . join('_', @{$options{instances}}); $perfdata->{label} .= '_' . join('_', @{$options{instances}});
} }
} }
$perfdata->{label} =~ s/'/''/g; $perfdata->{label} =~ s/'/''/g;
push @{$self->{perfdatas}}, $perfdata; push @{$self->{perfdatas}}, $perfdata;
} }
sub range_perfdata { sub range_perfdata {
my ($self, %options) = @_; my ($self, %options) = @_;
return if ($self->{range_perfdata} == 0); return if ($self->{range_perfdata} == 0);
if ($self->{range_perfdata} == 1) { if ($self->{range_perfdata} == 1) {
for (my $i = 0; $i < scalar(@{$options{ranges}}); $i++) { for (my $i = 0; $i < scalar(@{$options{ranges}}); $i++) {
@ -269,14 +269,14 @@ sub output_json {
next if (defined($self->{option_results}->{filter_perfdata}) && next if (defined($self->{option_results}->{filter_perfdata}) &&
$perf->{label} !~ /$self->{option_results}->{filter_perfdata}/); $perf->{label} !~ /$self->{option_results}->{filter_perfdata}/);
$self->range_perfdata(ranges => [\$perf->{warning}, \$perf->{critical}]); $self->range_perfdata(ranges => [\$perf->{warning}, \$perf->{critical}]);
my %values = (); my %values = ();
foreach my $key (keys %$perf) { foreach my $key (keys %$perf) {
$perf->{$key} = '' if (defined($self->{option_results}->{filter_uom}) && $key eq 'unit' && $perf->{$key} = '' if (defined($self->{option_results}->{filter_uom}) && $key eq 'unit' &&
$perf->{$key} !~ /$self->{option_results}->{filter_uom}/); $perf->{$key} !~ /$self->{option_results}->{filter_uom}/);
$values{$key} = $perf->{$key}; $values{$key} = $perf->{$key};
} }
push @{$json_content->{plugin}->{perfdatas}}, { push @{$json_content->{plugin}->{perfdatas}}, {
%values %values
}; };
@ -338,7 +338,7 @@ sub output_xml {
if (defined($self->{option_results}->{verbose}) || $force_long_output == 1) { if (defined($self->{option_results}->{verbose}) || $force_long_output == 1) {
foreach (@{$self->{global_long_output}}) { foreach (@{$self->{global_long_output}}) {
my ($child_output, $child_type, $child_msg); my ($child_output, $child_type, $child_msg);
$child_output = $self->{xml_output}->createElement('output'); $child_output = $self->{xml_output}->createElement('output');
$child_plugin_output->addChild($child_output); $child_plugin_output->addChild($child_output);
@ -405,14 +405,14 @@ sub output_openmetrics {
} }
} }
$bucket .= '}'; $bucket .= '}';
print $label . $bucket . ' ' . $perf->{value} . ' ' . $time_ms . "\n"; print $label . $bucket . ' ' . $perf->{value} . ' ' . $time_ms . "\n";
} }
} }
sub output_txt_short_display { sub output_txt_short_display {
my ($self, %options) = @_; my ($self, %options) = @_;
if (defined($self->{global_short_concat_outputs}->{CRITICAL})) { if (defined($self->{global_short_concat_outputs}->{CRITICAL})) {
print (($options{nolabel} == 0 ? 'CRITICAL: ' : '') . $self->{global_short_concat_outputs}->{CRITICAL} . " "); print (($options{nolabel} == 0 ? 'CRITICAL: ' : '') . $self->{global_short_concat_outputs}->{CRITICAL} . " ");
} }
@ -429,19 +429,19 @@ sub output_txt_short_display {
sub output_txt_short { sub output_txt_short {
my ($self, %options) = @_; my ($self, %options) = @_;
if (!defined($self->{option_results}->{change_short_output})) { if (!defined($self->{option_results}->{change_short_output})) {
$self->output_txt_short_display(%options); $self->output_txt_short_display(%options);
return ; return ;
} }
my $stdout = ''; my $stdout = '';
{ {
local *STDOUT; local *STDOUT;
open STDOUT, '>', \$stdout; open STDOUT, '>', \$stdout;
$self->output_txt_short_display(%options); $self->output_txt_short_display(%options);
} }
foreach (@{$self->{option_results}->{change_short_output}}) { foreach (@{$self->{option_results}->{change_short_output}}) {
my ($pattern, $replace, $modifier) = split /~/; my ($pattern, $replace, $modifier) = split /~/;
next if (!defined($pattern)); next if (!defined($pattern));
@ -449,7 +449,7 @@ sub output_txt_short {
$modifier = '' if (!defined($modifier)); $modifier = '' if (!defined($modifier));
eval "\$stdout =~ s{$pattern}{$replace}$modifier"; eval "\$stdout =~ s{$pattern}{$replace}$modifier";
} }
print $stdout; print $stdout;
} }
@ -480,7 +480,7 @@ sub output_txt {
} }
print "\n"; print "\n";
} }
if (defined($self->{option_results}->{verbose}) || $force_long_output == 1) { if (defined($self->{option_results}->{verbose}) || $force_long_output == 1) {
if (scalar(@{$self->{global_long_output}})) { if (scalar(@{$self->{global_long_output}})) {
print join("\n", @{$self->{global_long_output}}); print join("\n", @{$self->{global_long_output}});
@ -528,7 +528,7 @@ sub display {
$self->output_openmetrics(); $self->output_openmetrics();
return ; return ;
} }
$self->output_txt( $self->output_txt(
exit_litteral => $self->get_litteral_status(), exit_litteral => $self->get_litteral_status(),
nolabel => $nolabel, nolabel => $nolabel,
@ -594,7 +594,7 @@ sub option_exit {
sub exit { sub exit {
my ($self, %options) = @_; my ($self, %options) = @_;
if ($self->{noexit_die} == 1) { if ($self->{noexit_die} == 1) {
die 'exit'; die 'exit';
} }
@ -618,7 +618,7 @@ sub get_most_critical {
sub get_litteral_status { sub get_litteral_status {
my ($self, %options) = @_; my ($self, %options) = @_;
if (defined($options{status})) { if (defined($options{status})) {
if (defined($self->{errors_num}->{$options{status}})) { if (defined($self->{errors_num}->{$options{status}})) {
return $self->{errors_num}->{$options{status}}; return $self->{errors_num}->{$options{status}};
@ -692,7 +692,7 @@ sub create_xml_document {
sub plugin { sub plugin {
my ($self, %options) = @_; my ($self, %options) = @_;
# $options{name} = string name # $options{name} = string name
if (defined($options{name})) { if (defined($options{name})) {
$self->{plugin} = $options{name}; $self->{plugin} = $options{name};
} }
@ -717,10 +717,10 @@ sub add_disco_format {
sub display_disco_format { sub display_disco_format {
my ($self, %options) = @_; my ($self, %options) = @_;
if (defined($self->{option_results}->{output_xml})) { if (defined($self->{option_results}->{output_xml})) {
$self->create_xml_document(); $self->create_xml_document();
my $root = $self->{xml_output}->createElement('data'); my $root = $self->{xml_output}->createElement('data');
$self->{xml_output}->setDocumentElement($root); $self->{xml_output}->setDocumentElement($root);
@ -737,17 +737,17 @@ sub display_disco_format {
foreach (@{$self->{disco_elements}}) { foreach (@{$self->{disco_elements}}) {
push @{$json_content->{data}}, $_; push @{$json_content->{data}}, $_;
} }
print $self->{json_output}->encode($json_content); print $self->{json_output}->encode($json_content);
} }
} }
sub display_disco_show { sub display_disco_show {
my ($self, %options) = @_; my ($self, %options) = @_;
if (defined($self->{option_results}->{output_xml})) { if (defined($self->{option_results}->{output_xml})) {
$self->create_xml_document(); $self->create_xml_document();
my $root = $self->{xml_output}->createElement('data'); my $root = $self->{xml_output}->createElement('data');
$self->{xml_output}->setDocumentElement($root); $self->{xml_output}->setDocumentElement($root);
@ -770,14 +770,14 @@ sub display_disco_show {
} }
push @{$json_content->{data}}, {%values}; push @{$json_content->{data}}, {%values};
} }
print $self->{json_output}->encode($json_content); print $self->{json_output}->encode($json_content);
} }
} }
sub to_utf8 { sub to_utf8 {
my ($self, $value) = @_; my ($self, $value) = @_;
if ($self->{encode_utf8_import} == 0) { if ($self->{encode_utf8_import} == 0) {
# Some Perl version dont have the following module (like Perl 5.6.x) # Some Perl version dont have the following module (like Perl 5.6.x)
if (centreon::plugins::misc::mymodule_load(no_quit => 1, module => 'Encode', if (centreon::plugins::misc::mymodule_load(no_quit => 1, module => 'Encode',
@ -785,11 +785,11 @@ sub to_utf8 {
print "Cannot load module 'Encode'\n"; print "Cannot load module 'Encode'\n";
$self->exit(exit_litteral => 'unknown'); $self->exit(exit_litteral => 'unknown');
} }
$self->{encode_utf8_import} = 1; $self->{encode_utf8_import} = 1;
eval '$self->{perlqq} = Encode::PERLQQ'; eval '$self->{perlqq} = Encode::PERLQQ';
} }
return centreon::plugins::misc::trim(Encode::decode('UTF-8', $value, $self->{perlqq})); return centreon::plugins::misc::trim(Encode::decode('UTF-8', $value, $self->{perlqq}));
} }
@ -866,7 +866,7 @@ sub get_instance_perfdata_separator {
sub parse_pfdata_scale { sub parse_pfdata_scale {
my ($self, %options) = @_; my ($self, %options) = @_;
# --extend-perfdata=traffic_in,,scale(Mbps),mbps # --extend-perfdata=traffic_in,,scale(Mbps),mbps
my $args = { unit => 'auto' }; my $args = { unit => 'auto' };
if ($options{args} =~ /^([KMGTPEkmgtpe])?(B|b|bps|Bps|b\/s|auto)$/) { if ($options{args} =~ /^([KMGTPEkmgtpe])?(B|b|bps|Bps|b\/s|auto)$/) {
@ -875,7 +875,7 @@ sub parse_pfdata_scale {
} elsif ($options{args} ne '') { } elsif ($options{args} ne '') {
return 1; return 1;
} }
return (0, $args); return (0, $args);
} }
@ -890,17 +890,17 @@ sub parse_pfdata_math {
} elsif ($options{args} ne '') { } elsif ($options{args} ne '') {
return 1; return 1;
} }
if (defined($apply_threshold) && $apply_threshold =~ /^\s*(0|1)\s*$/ ) { if (defined($apply_threshold) && $apply_threshold =~ /^\s*(0|1)\s*$/ ) {
$args->{apply_threshold} = $1; $args->{apply_threshold} = $1;
} }
return (0, $args); return (0, $args);
} }
sub parse_group_pfdata { sub parse_group_pfdata {
my ($self, %options) = @_; my ($self, %options) = @_;
$options{args} =~ s/^\s+//; $options{args} =~ s/^\s+//;
$options{args} =~ s/\s+$//; $options{args} =~ s/\s+$//;
my $args = { pattern_pf => $options{args} }; my $args = { pattern_pf => $options{args} };
@ -909,37 +909,37 @@ sub parse_group_pfdata {
sub parse_pfdata_min { sub parse_pfdata_min {
my ($self, %options) = @_; my ($self, %options) = @_;
my $args = $self->parse_group_pfdata(%options); my $args = $self->parse_group_pfdata(%options);
return (0, $args); return (0, $args);
} }
sub parse_pfdata_max { sub parse_pfdata_max {
my ($self, %options) = @_; my ($self, %options) = @_;
my $args = $self->parse_group_pfdata(%options); my $args = $self->parse_group_pfdata(%options);
return (0, $args); return (0, $args);
} }
sub parse_pfdata_average { sub parse_pfdata_average {
my ($self, %options) = @_; my ($self, %options) = @_;
my $args = $self->parse_group_pfdata(%options); my $args = $self->parse_group_pfdata(%options);
return (0, $args); return (0, $args);
} }
sub parse_pfdata_sum { sub parse_pfdata_sum {
my ($self, %options) = @_; my ($self, %options) = @_;
my $args = $self->parse_group_pfdata(%options); my $args = $self->parse_group_pfdata(%options);
return (0, $args); return (0, $args);
} }
sub apply_pfdata_scale { sub apply_pfdata_scale {
my ($self, %options) = @_; my ($self, %options) = @_;
return if (${$options{perf}}->{unit} !~ /^([KMGTPEkmgtpe])?(B|b|bps|Bps|b\/s)$/); return if (${$options{perf}}->{unit} !~ /^([KMGTPEkmgtpe])?(B|b|bps|Bps|b\/s)$/);
my ($src_quantity, $src_unit) = ($1, $2); my ($src_quantity, $src_unit) = ($1, $2);
my ($value, $dst_quantity, $dst_unit) = centreon::plugins::misc::scale_bytesbit(value => ${$options{perf}}->{value}, my ($value, $dst_quantity, $dst_unit) = centreon::plugins::misc::scale_bytesbit(value => ${$options{perf}}->{value},
src_quantity => $src_quantity, src_unit => $src_unit, dst_quantity => $options{args}->{quantity}, dst_unit => $options{args}->{unit}); src_quantity => $src_quantity, src_unit => $src_unit, dst_quantity => $options{args}->{quantity}, dst_unit => $options{args}->{unit});
@ -949,7 +949,7 @@ sub apply_pfdata_scale {
} else { } else {
${$options{perf}}->{unit} = $options{args}->{quantity} . $options{args}->{unit}; ${$options{perf}}->{unit} = $options{args}->{quantity} . $options{args}->{unit};
} }
if (defined(${$options{perf}}->{max}) && ${$options{perf}}->{max} ne '') { if (defined(${$options{perf}}->{max}) && ${$options{perf}}->{max} ne '') {
($value) = centreon::plugins::misc::scale_bytesbit(value => ${$options{perf}}->{max}, ($value) = centreon::plugins::misc::scale_bytesbit(value => ${$options{perf}}->{max},
src_quantity => $src_quantity, src_unit => $src_unit, src_quantity => $src_quantity, src_unit => $src_unit,
@ -957,7 +957,7 @@ sub apply_pfdata_scale {
dst_unit => defined($dst_unit) ? $dst_unit : $options{args}->{unit}); dst_unit => defined($dst_unit) ? $dst_unit : $options{args}->{unit});
${$options{perf}}->{max} = sprintf('%.2f', $value); ${$options{perf}}->{max} = sprintf('%.2f', $value);
} }
foreach my $threshold ('warning', 'critical') { foreach my $threshold ('warning', 'critical') {
next if (${$options{perf}}->{$threshold} eq ''); next if (${$options{perf}}->{$threshold} eq '');
my ($status, $result) = centreon::plugins::misc::parse_threshold(threshold => ${$options{perf}}->{$threshold}); my ($status, $result) = centreon::plugins::misc::parse_threshold(threshold => ${$options{perf}}->{$threshold});
@ -975,22 +975,22 @@ sub apply_pfdata_scale {
dst_quantity => defined($dst_unit) ? $dst_quantity : $options{args}->{quantity}, dst_quantity => defined($dst_unit) ? $dst_quantity : $options{args}->{quantity},
dst_unit => defined($dst_unit) ? $dst_unit : $options{args}->{unit}); dst_unit => defined($dst_unit) ? $dst_unit : $options{args}->{unit});
} }
${$options{perf}}->{$threshold} = centreon::plugins::misc::get_threshold_litteral(%$result); ${$options{perf}}->{$threshold} = centreon::plugins::misc::get_threshold_litteral(%$result);
} }
} }
sub apply_pfdata_invert { sub apply_pfdata_invert {
my ($self, %options) = @_; my ($self, %options) = @_;
return if (!defined(${$options{perf}}->{max}) || ${$options{perf}}->{max} eq ''); return if (!defined(${$options{perf}}->{max}) || ${$options{perf}}->{max} eq '');
${$options{perf}}->{value} = ${$options{perf}}->{max} - ${$options{perf}}->{value}; ${$options{perf}}->{value} = ${$options{perf}}->{max} - ${$options{perf}}->{value};
foreach my $threshold ('warning', 'critical') { foreach my $threshold ('warning', 'critical') {
next if (${$options{perf}}->{$threshold} eq ''); next if (${$options{perf}}->{$threshold} eq '');
my ($status, $result) = centreon::plugins::misc::parse_threshold(threshold => ${$options{perf}}->{$threshold}); my ($status, $result) = centreon::plugins::misc::parse_threshold(threshold => ${$options{perf}}->{$threshold});
next if ($status == 0); next if ($status == 0);
my $tmp = { arobase => $result->{arobase}, infinite_pos => 0, infinite_neg => 0, start => $result->{start}, end => $result->{end} }; my $tmp = { arobase => $result->{arobase}, infinite_pos => 0, infinite_neg => 0, start => $result->{start}, end => $result->{end} };
$tmp->{infinite_neg} = 1 if ($result->{infinite_pos} == 1); $tmp->{infinite_neg} = 1 if ($result->{infinite_pos} == 1);
$tmp->{infinite_pos} = 1 if ($result->{infinite_neg} == 1); $tmp->{infinite_pos} = 1 if ($result->{infinite_neg} == 1);
@ -1001,7 +1001,7 @@ sub apply_pfdata_invert {
if ($result->{end} ne '' && $result->{infinite_pos} == 0) { if ($result->{end} ne '' && $result->{infinite_pos} == 0) {
$tmp->{start} = ${$options{perf}}->{max} - $result->{end}; $tmp->{start} = ${$options{perf}}->{max} - $result->{end};
} }
${$options{perf}}->{$threshold} = centreon::plugins::misc::get_threshold_litteral(%$tmp); ${$options{perf}}->{$threshold} = centreon::plugins::misc::get_threshold_litteral(%$tmp);
} }
} }
@ -1010,7 +1010,7 @@ sub apply_pfdata_percent {
my ($self, %options) = @_; my ($self, %options) = @_;
return if (!defined(${$options{perf}}->{max}) || ${$options{perf}}->{max} eq ''); return if (!defined(${$options{perf}}->{max}) || ${$options{perf}}->{max} eq '');
${$options{perf}}->{value} = sprintf('%.2f', ${$options{perf}}->{value} * 100 / ${$options{perf}}->{max}); ${$options{perf}}->{value} = sprintf('%.2f', ${$options{perf}}->{value} * 100 / ${$options{perf}}->{max});
${$options{perf}}->{unit} = '%'; ${$options{perf}}->{unit} = '%';
foreach my $threshold ('warning', 'critical') { foreach my $threshold ('warning', 'critical') {
@ -1024,24 +1024,24 @@ sub apply_pfdata_percent {
if ($result->{end} ne '' && $result->{infinite_pos} == 0) { if ($result->{end} ne '' && $result->{infinite_pos} == 0) {
$result->{end} = sprintf('%.2f', $result->{end} * 100 / ${$options{perf}}->{max}); $result->{end} = sprintf('%.2f', $result->{end} * 100 / ${$options{perf}}->{max});
} }
${$options{perf}}->{$threshold} = centreon::plugins::misc::get_threshold_litteral(%$result); ${$options{perf}}->{$threshold} = centreon::plugins::misc::get_threshold_litteral(%$result);
} }
${$options{perf}}->{max} = 100; ${$options{perf}}->{max} = 100;
} }
sub apply_pfdata_math { sub apply_pfdata_math {
my ($self, %options) = @_; my ($self, %options) = @_;
my $math = $options{args}->{math}; my $math = $options{args}->{math};
$math =~ s/current/\$value/g; $math =~ s/current/\$value/g;
my $value = ${$options{perf}}->{value}; my $value = ${$options{perf}}->{value};
eval "\${\$options{perf}}->{value} = $math"; eval "\${\$options{perf}}->{value} = $math";
return if ($options{args}->{apply_threshold} == 0); return if ($options{args}->{apply_threshold} == 0);
foreach my $threshold ('warning', 'critical') { foreach my $threshold ('warning', 'critical') {
next if (${$options{perf}}->{$threshold} eq ''); next if (${$options{perf}}->{$threshold} eq '');
my ($status, $result) = centreon::plugins::misc::parse_threshold(threshold => ${$options{perf}}->{$threshold}); my ($status, $result) = centreon::plugins::misc::parse_threshold(threshold => ${$options{perf}}->{$threshold});
@ -1055,10 +1055,10 @@ sub apply_pfdata_math {
$value = $result->{end}; $value = $result->{end};
eval "\$result->{end} = $math"; eval "\$result->{end} = $math";
} }
${$options{perf}}->{$threshold} = centreon::plugins::misc::get_threshold_litteral(%$result); ${$options{perf}}->{$threshold} = centreon::plugins::misc::get_threshold_litteral(%$result);
} }
${$options{perf}}->{max} = 100; ${$options{perf}}->{max} = 100;
} }
@ -1147,12 +1147,12 @@ sub load_perfdata_extend_args {
sub parse_perfdata_extend_args { sub parse_perfdata_extend_args {
my ($self, %options) = @_; my ($self, %options) = @_;
# --extend-perfdata=searchlabel,newlabel,method[,[newuom],[min],[max]] # --extend-perfdata=searchlabel,newlabel,method[,[newuom],[min],[max]]
my ($pfdata_match, $pfdata_substitute, $method, $uom_sub, $min_sub, $max_sub) = my ($pfdata_match, $pfdata_substitute, $method, $uom_sub, $min_sub, $max_sub) =
split /,/, $options{arg}; split /,/, $options{arg};
return if ((!defined($pfdata_match) || $pfdata_match eq '') && $options{type} != 3); return if ((!defined($pfdata_match) || $pfdata_match eq '') && $options{type} != 3);
$self->{pfdata_extends} = [] if (!defined($self->{pfdata_extends})); $self->{pfdata_extends} = [] if (!defined($self->{pfdata_extends}));
my $pfdata_extends = { my $pfdata_extends = {
pfdata_match => defined($pfdata_match) && $pfdata_match ne '' ? $pfdata_match : undef, pfdata_match => defined($pfdata_match) && $pfdata_match ne '' ? $pfdata_match : undef,
@ -1168,7 +1168,7 @@ sub parse_perfdata_extend_args {
$self->output_add(long_msg => "method in argument '$options{arg}' is unknown", debug => 1); $self->output_add(long_msg => "method in argument '$options{arg}' is unknown", debug => 1);
return ; return ;
} }
$pfdata_extends->{method_name} = $1; $pfdata_extends->{method_name} = $1;
my $args = $2; my $args = $2;
if (my $func = $self->can('parse_pfdata_' . $pfdata_extends->{method_name})) { if (my $func = $self->can('parse_pfdata_' . $pfdata_extends->{method_name})) {
@ -1185,7 +1185,7 @@ sub parse_perfdata_extend_args {
sub apply_perfdata_explode { sub apply_perfdata_explode {
my ($self, %options) = @_; my ($self, %options) = @_;
return if ($self->{explode_perfdata_total} == 0); return if ($self->{explode_perfdata_total} == 0);
foreach (@{$self->{perfdatas}}) { foreach (@{$self->{perfdatas}}) {
next if ($_->{max} eq ''); next if ($_->{max} eq '');
@ -1207,7 +1207,7 @@ sub apply_perfdata_extend {
foreach my $extend (@{$self->{pfdata_extends}}) { foreach my $extend (@{$self->{pfdata_extends}}) {
my $new_pfdata = []; my $new_pfdata = [];
# Manage special case when type group and pfdata_match empty # Manage special case when type group and pfdata_match empty
if ($extend->{type} == 3 && (!defined($extend->{pfdata_match}) || $extend->{pfdata_match} eq '')) { if ($extend->{type} == 3 && (!defined($extend->{pfdata_match}) || $extend->{pfdata_match} eq '')) {
next if (!defined($extend->{pfdata_substitute}) || $extend->{pfdata_substitute} eq ''); next if (!defined($extend->{pfdata_substitute}) || $extend->{pfdata_substitute} eq '');
@ -1229,15 +1229,15 @@ sub apply_perfdata_extend {
} }
next; next;
} }
for (my $i = 0; $i < scalar(@{$self->{perfdatas}}); $i++) { for (my $i = 0; $i < scalar(@{$self->{perfdatas}}); $i++) {
next if ($self->{perfdatas}->[$i]->{label} !~ /$extend->{pfdata_match}/); next if ($self->{perfdatas}->[$i]->{label} !~ /$extend->{pfdata_match}/);
my $new_perf = { %{$self->{perfdatas}->[$i]} }; my $new_perf = { %{$self->{perfdatas}->[$i]} };
if ($extend->{type} == 3) { if ($extend->{type} == 3) {
$new_perf = { label => $self->{perfdatas}->[$i]->{label}, value => '', unit => '', warning => '', critical => '', min => '', max => '' }; $new_perf = { label => $self->{perfdatas}->[$i]->{label}, value => '', unit => '', warning => '', critical => '', min => '', max => '' };
} }
if (defined($extend->{pfdata_substitute})) { if (defined($extend->{pfdata_substitute})) {
eval "\$new_perf->{label} =~ s{$extend->{pfdata_match}}{$extend->{pfdata_substitute}}"; eval "\$new_perf->{label} =~ s{$extend->{pfdata_match}}{$extend->{pfdata_substitute}}";
} }
@ -1246,7 +1246,7 @@ sub apply_perfdata_extend {
my $func = $self->can('apply_pfdata_' . $extend->{method_name}); my $func = $self->can('apply_pfdata_' . $extend->{method_name});
$func->($self, perf => \$new_perf, args => $extend->{method_args}); $func->($self, perf => \$new_perf, args => $extend->{method_args});
} }
$new_perf->{unit} = $extend->{uom_sub} if (defined($extend->{uom_sub})); $new_perf->{unit} = $extend->{uom_sub} if (defined($extend->{uom_sub}));
$new_perf->{min} = $extend->{min_sub} if (defined($extend->{min_sub})); $new_perf->{min} = $extend->{min_sub} if (defined($extend->{min_sub}));
$new_perf->{max} = $extend->{max_sub} if (defined($extend->{max_sub})); $new_perf->{max} = $extend->{max_sub} if (defined($extend->{max_sub}));
@ -1264,7 +1264,7 @@ sub apply_perfdata_extend {
sub change_perfdata { sub change_perfdata {
my ($self, %options) = @_; my ($self, %options) = @_;
$self->apply_perfdata_extend(); $self->apply_perfdata_extend();
$self->apply_perfdata_explode(); $self->apply_perfdata_explode();
} }
@ -1326,7 +1326,7 @@ Change traffic values in percent: --change-perfdata=traffic_in,,percent()
=item B<--extend-perfdata-group> =item B<--extend-perfdata-group>
Extend perfdata from multiple perfdatas (methods in target are: min, max, average, sum) Extend perfdata from multiple perfdatas (methods in target are: min, max, average, sum)
Syntax: --extend-perfdata-group=searchlabel,newlabel,target[,newuom] Syntax: --extend-perfdata-group=searchlabel,newlabel,target[,[newuom],[min],[max]]
Common examples: Common examples: