enh(core): add filter-perfdata-adv option (#2800)

This commit is contained in:
qgarnier 2021-05-17 10:15:53 +02:00 committed by GitHub
parent 1e5ca98a62
commit 9125d889e4
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 39 additions and 10 deletions

View File

@ -38,6 +38,7 @@ sub new {
'explode-perfdata-max:s@' => { name => 'explode_perfdata_max' }, 'explode-perfdata-max:s@' => { name => 'explode_perfdata_max' },
'range-perfdata:s' => { name => 'range_perfdata' }, 'range-perfdata:s' => { name => 'range_perfdata' },
'filter-perfdata:s' => { name => 'filter_perfdata' }, 'filter-perfdata:s' => { name => 'filter_perfdata' },
'filter-perfdata-adv:s' => { name => 'filter_perfdata_adv' },
'change-perfdata:s@' => { name => 'change_perfdata' }, 'change-perfdata:s@' => { name => 'change_perfdata' },
'extend-perfdata:s@' => { name => 'extend_perfdata' }, 'extend-perfdata:s@' => { name => 'extend_perfdata' },
'extend-perfdata-group:s@'=> { name => 'extend_perfdata_group' }, 'extend-perfdata-group:s@'=> { name => 'extend_perfdata_group' },
@ -137,6 +138,11 @@ sub check_options {
} }
} }
if (defined($self->{option_results}->{filter_perfdata_adv}) && $self->{option_results}->{filter_perfdata_adv} ne '') {
$self->{option_results}->{filter_perfdata_adv} =~ s/%\{(.*?)\}/\$values->{$1}/g;
$self->{option_results}->{filter_perfdata_adv} =~ s/%\((.*?)\)/\$values->{$1}/g;
}
$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}));
@ -201,6 +207,7 @@ sub output_add {
sub perfdata_add { sub perfdata_add {
my ($self, %options) = @_; my ($self, %options) = @_;
my $perfdata = { my $perfdata = {
label => '', value => '', unit => '', warning => '', critical => '', min => '', max => '', mode => $self->{mode} label => '', value => '', unit => '', warning => '', critical => '', min => '', max => '', mode => $self->{mode}
}; };
@ -227,6 +234,23 @@ sub perfdata_add {
push @{$self->{perfdatas}}, $perfdata; push @{$self->{perfdatas}}, $perfdata;
} }
sub filter_perfdata {
my ($self, %options) = @_;
return 1 if (
defined($self->{option_results}->{filter_perfdata}) &&
$options{perf}->{label} !~ /$self->{option_results}->{filter_perfdata}/
);
return 1 if (
defined($self->{option_results}->{filter_perfdata_adv}) &&
$self->{option_results}->{filter_perfdata_adv} ne '' &&
!$self->test_eval(test => $self->{option_results}->{filter_perfdata_adv}, values => $options{perf})
);
return 0;
}
sub range_perfdata { sub range_perfdata {
my ($self, %options) = @_; my ($self, %options) = @_;
@ -281,8 +305,7 @@ sub output_json {
if ($options{force_ignore_perfdata} == 0) { if ($options{force_ignore_perfdata} == 0) {
$self->change_perfdata(); $self->change_perfdata();
foreach my $perf (@{$self->{perfdatas}}) { foreach my $perf (@{$self->{perfdatas}}) {
next if (defined($self->{option_results}->{filter_perfdata}) && next if ($self->filter_perfdata(perf => $perf));
$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 = ();
@ -371,8 +394,7 @@ sub output_xml {
if ($options{force_ignore_perfdata} == 0) { if ($options{force_ignore_perfdata} == 0) {
$self->change_perfdata(); $self->change_perfdata();
foreach my $perf (@{$self->{perfdatas}}) { foreach my $perf (@{$self->{perfdatas}}) {
next if (defined($self->{option_results}->{filter_perfdata}) && next if ($self->filter_perfdata(perf => $perf));
$perf->{label} !~ /$self->{option_results}->{filter_perfdata}/);
$self->range_perfdata(ranges => [\$perf->{warning}, \$perf->{critical}]); $self->range_perfdata(ranges => [\$perf->{warning}, \$perf->{critical}]);
my ($child_perfdata); my ($child_perfdata);
@ -403,10 +425,12 @@ sub output_openmetrics {
$self->change_perfdata(); $self->change_perfdata();
foreach my $perf (@{$self->{perfdatas}}) { foreach my $perf (@{$self->{perfdatas}}) {
next if (defined($self->{option_results}->{filter_perfdata}) && next if ($self->filter_perfdata(perf => $perf));
$perf->{label} !~ /$self->{option_results}->{filter_perfdata}/);
$perf->{unit} = '' if (defined($self->{option_results}->{filter_uom}) && $perf->{unit} = '' if (
$perf->{unit} !~ /$self->{option_results}->{filter_uom}/); defined($self->{option_results}->{filter_uom}) &&
$perf->{unit} !~ /$self->{option_results}->{filter_uom}/
);
$self->range_perfdata(ranges => [\$perf->{warning}, \$perf->{critical}]); $self->range_perfdata(ranges => [\$perf->{warning}, \$perf->{critical}]);
my $label = $perf->{label}; my $label = $perf->{label};
my $instance; my $instance;
@ -486,8 +510,7 @@ sub output_txt {
print '|'; print '|';
$self->change_perfdata(); $self->change_perfdata();
foreach my $perf (@{$self->{perfdatas}}) { foreach my $perf (@{$self->{perfdatas}}) {
next if (defined($self->{option_results}->{filter_perfdata}) && next if ($self->filter_perfdata(perf => $perf));
$perf->{label} !~ /$self->{option_results}->{filter_perfdata}/);
$perf->{unit} = '' if (defined($self->{option_results}->{filter_uom}) && $perf->{unit} = '' if (defined($self->{option_results}->{filter_uom}) &&
$perf->{unit} !~ /$self->{option_results}->{filter_uom}/); $perf->{unit} !~ /$self->{option_results}->{filter_uom}/);
$self->range_perfdata(ranges => [\$perf->{warning}, \$perf->{critical}]); $self->range_perfdata(ranges => [\$perf->{warning}, \$perf->{critical}]);
@ -1418,6 +1441,12 @@ Display also debug messages.
Filter perfdata that match the regexp. Filter perfdata that match the regexp.
=item B<--filter-perfdata-adv>
Advanced perfdata filter.
Eg: --filter-perfdata-adv='not (%(value) == 0 and %(max) eq "")'
=item B<--explode-perfdata-max> =item B<--explode-perfdata-max>
Put max perfdata (if it exist) in a specific perfdata Put max perfdata (if it exist) in a specific perfdata