enh(core): add filter-perfdata-adv option (#2800)
This commit is contained in:
parent
1e5ca98a62
commit
9125d889e4
|
@ -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
|
||||||
|
|
Loading…
Reference in New Issue