fix(core): code evaluation tested with values - not permissive (#3237)

This commit is contained in:
qgarnier 2021-11-09 16:23:36 +01:00 committed by GitHub
parent f17c9f9341
commit 5764b0457c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
23 changed files with 230 additions and 419 deletions

View File

@ -27,27 +27,18 @@ use warnings;
sub custom_status_threshold { sub custom_status_threshold {
my ($self, %options) = @_; my ($self, %options) = @_;
my $status = 'ok'; my $status = 'ok';
my $message; # To exclude some OK
if (defined($self->{instance_mode}->{option_results}->{ok_status}) && $self->{instance_mode}->{option_results}->{ok_status} ne '' &&
eval { $self->eval(value => $self->{instance_mode}->{option_results}->{ok_status})) {
local $SIG{__WARN__} = sub { $message = $_[0]; }; $status = 'ok';
local $SIG{__DIE__} = sub { $message = $_[0]; }; } elsif (defined($self->{instance_mode}->{option_results}->{critical_status}) && $self->{instance_mode}->{option_results}->{critical_status} ne '' &&
$self->eval(value => $self->{instance_mode}->{option_results}->{critical_status})) {
# To exclude some OK $status = 'critical';
if (defined($self->{instance_mode}->{option_results}->{ok_status}) && $self->{instance_mode}->{option_results}->{ok_status} ne '' && } elsif (defined($self->{instance_mode}->{option_results}->{warning_status}) && $self->{instance_mode}->{option_results}->{warning_status} ne '' &&
$self->eval(value => $self->{instance_mode}->{option_results}->{ok_status})) { $self->eval(value => $self->{instance_mode}->{option_results}->{warning_status})) {
$status = 'ok'; $status = 'warning';
} elsif (defined($self->{instance_mode}->{option_results}->{critical_status}) && $self->{instance_mode}->{option_results}->{critical_status} ne '' &&
$self->eval(value => $self->{instance_mode}->{option_results}->{critical_status})) {
$status = 'critical';
} elsif (defined($self->{instance_mode}->{option_results}->{warning_status}) && $self->{instance_mode}->{option_results}->{warning_status} ne '' &&
$self->eval(value => $self->{instance_mode}->{option_results}->{warning_status})) {
$status = 'warning';
}
};
if (defined($message)) {
$self->{output}->output_add(long_msg => 'filter status issue: ' . $message);
} }
return $status; return $status;

View File

@ -60,26 +60,16 @@ sub custom_hosts_perfdata {
sub custom_hosts_threshold { sub custom_hosts_threshold {
my ($self, %options) = @_; my ($self, %options) = @_;
my $message;
my $status = 'ok'; my $status = 'ok';
eval { if (defined($self->{instance_mode}->{option_results}->{critical_total}) && $self->{instance_mode}->{option_results}->{critical_total} ne '' &&
local $SIG{__WARN__} = sub { $message = $_[0]; }; $self->eval(value => $self->{instance_mode}->{option_results}->{critical_total})) {
local $SIG{__DIE__} = sub { $message = $_[0]; }; $status = 'critical';
} elsif (defined($self->{instance_mode}->{option_results}->{warning_total}) && $self->{instance_mode}->{option_results}->{warning_total} ne '' &&
if (defined($self->{instance_mode}->{option_results}->{critical_total}) && $self->{instance_mode}->{option_results}->{critical_total} ne '' && $self->eval(value => $self->{instance_mode}->{option_results}->{warning_total})) {
$self->eval(value => $self->{instance_mode}->{option_results}->{critical_total})) { $status = 'warning';
$status = 'critical';
} elsif (defined($self->{instance_mode}->{option_results}->{warning_total}) && $self->{instance_mode}->{option_results}->{warning_total} ne '' &&
$self->eval(value => $self->{instance_mode}->{option_results}->{warning_total})) {
$status = 'warning';
}
};
if (defined($message)) {
$self->{output}->output_add(long_msg => 'filter status issue: ' . $message);
} }
return $status; return $status;
} }
sub custom_services_calc { sub custom_services_calc {
@ -94,8 +84,8 @@ sub custom_services_calc {
sub custom_services_output { sub custom_services_output {
my ($self, %options) = @_; my ($self, %options) = @_;
my $msg = '';
$msg .= "[ok:$self->{result_values}->{ok_total}][warning:$self->{result_values}->{warning_total}][critical:$self->{result_values}->{critical_total}][unknown:$self->{result_values}->{unknown_total}]\n"; my $msg .= "[ok:$self->{result_values}->{ok_total}][warning:$self->{result_values}->{warning_total}][critical:$self->{result_values}->{critical_total}][unknown:$self->{result_values}->{unknown_total}]\n";
return $msg return $msg
} }
@ -114,27 +104,16 @@ sub custom_services_perfdata {
sub custom_services_threshold { sub custom_services_threshold {
my ($self, %options) = @_; my ($self, %options) = @_;
my $message;
my $status = 'ok'; my $status = 'ok';
if (defined($self->{instance_mode}->{option_results}->{critical_total}) && $self->{instance_mode}->{option_results}->{critical_total} ne '' &&
eval { $self->eval(value => $self->{instance_mode}->{option_results}->{critical_total})) {
local $SIG{__WARN__} = sub { $message = $_[0]; }; $status = 'critical';
local $SIG{__DIE__} = sub { $message = $_[0]; }; } elsif (defined($self->{instance_mode}->{option_results}->{warning_total}) && $self->{instance_mode}->{option_results}->{warning_total} ne '' &&
$self->eval(value => $self->{instance_mode}->{option_results}->{warning_total})) {
if (defined($self->{instance_mode}->{option_results}->{critical_total}) && $self->{instance_mode}->{option_results}->{critical_total} ne '' && $status = 'warning';
$self->eval(value => $self->{instance_mode}->{option_results}->{critical_total})) {
$status = 'critical';
} elsif (defined($self->{instance_mode}->{option_results}->{warning_total}) && $self->{instance_mode}->{option_results}->{warning_total} ne '' &&
$self->eval(value => $self->{instance_mode}->{option_results}->{warning_total})) {
$status = 'warning';
}
};
if (defined($message)) {
$self->{output}->output_add(long_msg => 'filter status issue: ' . $message);
} }
return $status; return $status;
} }
sub custom_groups_calc { sub custom_groups_calc {
@ -220,23 +199,14 @@ sub custom_groups_perfdata {
sub custom_groups_threshold { sub custom_groups_threshold {
my ($self, %options) = @_; my ($self, %options) = @_;
my $status = 'ok'; my $status = 'ok';
my $message; if (defined($self->{instance_mode}->{option_results}->{critical_groups}) && $self->{instance_mode}->{option_results}->{critical_groups} ne '' &&
$self->eval(value => $self->{instance_mode}->{option_results}->{critical_groups})) {
eval { $status = 'critical';
local $SIG{__WARN__} = sub { $message = $_[0]; }; } elsif (defined($self->{instance_mode}->{option_results}->{warning_groups}) && $self->{instance_mode}->{option_results}->{warning_groups} ne '' &&
local $SIG{__DIE__} = sub { $message = $_[0]; }; $self->eval(value => $self->{instance_mode}->{option_results}->{warning_groups})) {
$status = 'warning';
if (defined($self->{instance_mode}->{option_results}->{critical_groups}) && $self->{instance_mode}->{option_results}->{critical_groups} ne '' &&
$self->eval(value => $self->{instance_mode}->{option_results}->{critical_groups})) {
$status = 'critical';
} elsif (defined($self->{instance_mode}->{option_results}->{warning_groups}) && $self->{instance_mode}->{option_results}->{warning_groups} ne '' &&
$self->eval(value => $self->{instance_mode}->{option_results}->{warning_groups})) {
$status = 'warning';
}
};
if (defined($message)) {
$self->{output}->output_add(long_msg => 'filter status issue: ' . $message);
} }
return $status; return $status;
@ -245,8 +215,7 @@ sub custom_groups_threshold {
sub set_counters { sub set_counters {
my ($self, %options) = @_; my ($self, %options) = @_;
$self->{maps_counters_type} = [ $self->{maps_counters_type} = [];
];
$self->{maps_counters}->{totalservice} = [ $self->{maps_counters}->{totalservice} = [
{ label => 'total-service', threshold => 0, set => { { label => 'total-service', threshold => 0, set => {

View File

@ -31,31 +31,22 @@ use Digest::MD5 qw(md5_hex);
sub custom_select_threshold { sub custom_select_threshold {
my ($self, %options) = @_; my ($self, %options) = @_;
my $status = 'ok'; my $status = 'ok';
my $message; our $expand = $self->{result_values}->{expand};
if (defined($self->{result_values}->{config}->{critical}) && $self->{result_values}->{config}->{critical} &&
eval { $self->{instance_mode}->{safe}->reval($self->{result_values}->{config}->{critical})) {
local $SIG{__WARN__} = sub { $message = $_[0]; }; $status = 'critical';
local $SIG{__DIE__} = sub { $message = $_[0]; }; } elsif (defined($self->{result_values}->{config}->{warning}) && $self->{result_values}->{config}->{warning} ne '' &&
$self->{instance_mode}->{safe}->reval($self->{result_values}->{config}->{warning})) {
our $expand = $self->{result_values}->{expand}; $status = 'warning';
if (defined($self->{result_values}->{config}->{critical}) && $self->{result_values}->{config}->{critical} && } elsif (defined($self->{result_values}->{config}->{unknown}) && $self->{result_values}->{config}->{unknown} &&
$self->{instance_mode}->{safe}->reval($self->{result_values}->{config}->{critical})) { $self->{instance_mode}->reval($self->{result_values}->{config}->{unknown})) {
$status = 'critical'; $status = 'unknown';
} elsif (defined($self->{result_values}->{config}->{warning}) && $self->{result_values}->{config}->{warning} ne '' && }
$self->{instance_mode}->{safe}->reval($self->{result_values}->{config}->{warning})) { if ($@) {
$status = 'warning'; $self->{output}->add_option_msg(short_msg => 'Unsafe code evaluation: ' . $@);
} elsif (defined($self->{result_values}->{config}->{unknown}) && $self->{result_values}->{config}->{unknown} && $self->{output}->option_exit();
$self->{instance_mode}->reval($self->{result_values}->{config}->{unknown})) {
$status = 'unknown';
}
if ($@) {
$self->{output}->add_option_msg(short_msg => 'Unsafe code evaluation: ' . $@);
$self->{output}->option_exit();
}
};
if (defined($message)) {
$self->{output}->output_add(long_msg => 'filter status issue: ' . $message);
} }
$self->{result_values}->{last_status} = $status; $self->{result_values}->{last_status} = $status;

View File

@ -164,25 +164,15 @@ sub connector_response_status {
# Check response # Check response
my $status = 'ok'; my $status = 'ok';
my $message; if (defined($self->{critical_connector_status}) && $self->{critical_connector_status} ne '' &&
eval { $self->{output}->test_eval(test => $self->{critical_connector_status}, values => $self->{result})) {
local $SIG{__WARN__} = sub { $message = $_[0]; }; $status = 'critical';
local $SIG{__DIE__} = sub { $message = $_[0]; }; } elsif (defined($self->{warning_connector_status}) && $self->{warning_connector_status} ne '' &&
$self->{output}->test_eval(test => $self->{warning_connector_status}, values => $self->{result})) {
if (defined($self->{critical_connector_status}) && $self->{critical_connector_status} ne '' && $status = 'warning';
$self->{output}->test_eval(test => $self->{critical_connector_status}, values => $self->{result})) { } elsif (defined($self->{unknown_connector_status}) && $self->{unknown_connector_status} ne '' &&
$status = 'critical'; $self->{output}->test_eval(test => $self->{unknown_connector_status}, values => $self->{result})) {
} elsif (defined($self->{warning_connector_status}) && $self->{warning_connector_status} ne '' && $status = 'unknown';
$self->{output}->test_eval(test => $self->{warning_connector_status}, values => $self->{result})) {
$status = 'warning';
} elsif (defined($self->{unknown_connector_status}) && $self->{unknown_connector_status} ne '' &&
$self->{output}->test_eval(test => $self->{unknown_connector_status}, values => $self->{result})) {
$status = 'unknown';
}
};
if (defined($message)) {
$self->{output}->add_option_msg(short_msg => 'filter connector status issue: ' . $message);
$self->{output}->option_exit();
} }
if (!$self->{output}->is_status(value => $status, compare => 'ok', litteral => 1)) { if (!$self->{output}->is_status(value => $status, compare => 'ok', litteral => 1)) {

View File

@ -29,25 +29,16 @@ use centreon::plugins::statefile;
sub custom_status_threshold { sub custom_status_threshold {
my ($self, %options) = @_; my ($self, %options) = @_;
my $status = 'ok'; my $status = 'ok';
my $message; if (defined($self->{instance_mode}->{option_results}->{'critical-' . $self->{label}}) && $self->{instance_mode}->{option_results}->{'critical-' . $self->{label}} ne '' &&
$self->eval(value => $self->{instance_mode}->{option_results}->{'critical-' . $self->{label}})) {
eval { $self->{instance_mode}->{dc_critical}++;
local $SIG{__WARN__} = sub { $message = $_[0]; }; $status = 'critical';
local $SIG{__DIE__} = sub { $message = $_[0]; }; } elsif (defined($self->{instance_mode}->{option_results}->{'warning-' . $self->{label}}) && $self->{instance_mode}->{option_results}->{'warning-' . $self->{label}} ne '' &&
$self->eval(value => $self->{instance_mode}->{option_results}->{'warning-' . $self->{label}})) {
if (defined($self->{instance_mode}->{option_results}->{'critical-' . $self->{label}}) && $self->{instance_mode}->{option_results}->{'critical-' . $self->{label}} ne '' && $self->{instance_mode}->{dc_warning}++;
$self->eval(value => $self->{instance_mode}->{option_results}->{'critical-' . $self->{label}})) { $status = 'warning';
$self->{instance_mode}->{dc_critical}++;
$status = 'critical';
} elsif (defined($self->{instance_mode}->{option_results}->{'warning-' . $self->{label}}) && $self->{instance_mode}->{option_results}->{'warning-' . $self->{label}} ne '' &&
$self->eval(value => $self->{instance_mode}->{option_results}->{'warning-' . $self->{label}})) {
$self->{instance_mode}->{dc_warning}++;
$status = 'warning';
}
};
if (defined($message)) {
$self->{output}->output_add(long_msg => 'filter status issue: ' . $message);
} }
return $status; return $status;

View File

@ -29,25 +29,16 @@ use centreon::plugins::statefile;
sub custom_status_threshold { sub custom_status_threshold {
my ($self, %options) = @_; my ($self, %options) = @_;
my $status = 'ok'; my $status = 'ok';
my $message; if (defined($self->{instance_mode}->{option_results}->{'critical-' . $self->{label}}) && $self->{instance_mode}->{option_results}->{'critical-' . $self->{label}} ne '' &&
$self->eval(value => $self->{instance_mode}->{option_results}->{'critical-' . $self->{label}})) {
eval { $self->{instance_mode}->{host_critical}++;
local $SIG{__WARN__} = sub { $message = $_[0]; }; $status = 'critical';
local $SIG{__DIE__} = sub { $message = $_[0]; }; } elsif (defined($self->{instance_mode}->{option_results}->{'warning-' . $self->{label}}) && $self->{instance_mode}->{option_results}->{'warning-' . $self->{label}} ne '' &&
$self->eval(value => $self->{instance_mode}->{option_results}->{'warning-' . $self->{label}})) {
if (defined($self->{instance_mode}->{option_results}->{'critical-' . $self->{label}}) && $self->{instance_mode}->{option_results}->{'critical-' . $self->{label}} ne '' && $self->{instance_mode}->{host_warning}++;
$self->eval(value => $self->{instance_mode}->{option_results}->{'critical-' . $self->{label}})) { $status = 'warning';
$self->{instance_mode}->{host_critical}++;
$status = 'critical';
} elsif (defined($self->{instance_mode}->{option_results}->{'warning-' . $self->{label}}) && $self->{instance_mode}->{option_results}->{'warning-' . $self->{label}} ne '' &&
$self->eval(value => $self->{instance_mode}->{option_results}->{'warning-' . $self->{label}})) {
$self->{instance_mode}->{host_warning}++;
$status = 'warning';
}
};
if (defined($message)) {
$self->{output}->output_add(long_msg => 'filter status issue: ' . $message);
} }
return $status; return $status;

View File

@ -75,22 +75,15 @@ sub check {
centreon::plugins::misc::trim($3), centreon::plugins::misc::trim($4)); centreon::plugins::misc::trim($3), centreon::plugins::misc::trim($4));
$checked++; $checked++;
my ($status, $message) = ('ok'); my $status = 'ok';
eval { if (defined($self->{option_results}->{critical}) && $self->{option_results}->{critical} ne '' &&
local $SIG{__WARN__} = sub { $message = $_[0]; }; $self->{output}->test_eval(test => $self->{option_results}->{critical}, values => $self->{data})) {
local $SIG{__DIE__} = sub { $message = $_[0]; }; $status = 'critical';
} elsif (defined($self->{option_results}->{warning}) && $self->{option_results}->{warning} ne '' &&
if (defined($self->{option_results}->{critical}) && $self->{option_results}->{critical} ne '' && $self->{output}->test_eval(test => $self->{option_results}->{warning}, values => $self->{data})) {
$self->{output}->test_eval(test => $self->{option_results}->{critical}, values => $self->{data})) { $status = 'warning';
$status = 'critical';
} elsif (defined($self->{option_results}->{warning}) && $self->{option_results}->{warning} ne '' &&
$self->{output}->test_eval(test => $self->{option_results}->{warning}, values => $self->{data})) {
$status = 'warning';
}
};
if (defined($message)) {
$self->{output}->output_add(long_msg => 'filter status issue: ' . $message);
} }
if (!$self->{output}->is_status(value => $status, compare => 'ok', litteral => 1)) { if (!$self->{output}->is_status(value => $status, compare => 'ok', litteral => 1)) {
$self->{output}->output_add( $self->{output}->output_add(
severity => $status, severity => $status,

View File

@ -73,22 +73,15 @@ sub check {
$checked++; $checked++;
my ($status, $message) = ('ok'); my $status = 'ok';
eval { if (defined($self->{option_results}->{critical}) && $self->{option_results}->{critical} ne '' &&
local $SIG{__WARN__} = sub { $message = $_[0]; }; $self->{output}->test_eval(test => $self->{option_results}->{critical}, values => $self->{data})) {
local $SIG{__DIE__} = sub { $message = $_[0]; }; $status = 'critical';
} elsif (defined($self->{option_results}->{warning}) && $self->{option_results}->{warning} ne '' &&
if (defined($self->{option_results}->{critical}) && $self->{option_results}->{critical} ne '' && $self->{output}->test_eval(test => $self->{option_results}->{warning}, values => $self->{data})) {
$self->{output}->test_eval(test => $self->{option_results}->{critical}, values => $self->{data})) { $status = 'warning';
$status = 'critical';
} elsif (defined($self->{option_results}->{warning}) && $self->{option_results}->{warning} ne '' &&
$self->{output}->test_eval(test => $self->{option_results}->{warning}, values => $self->{data})) {
$status = 'warning';
}
};
if (defined($message)) {
$self->{output}->output_add(long_msg => 'filter status issue: ' . $message);
} }
if (!$self->{output}->is_status(value => $status, compare => 'ok', litteral => 1)) { if (!$self->{output}->is_status(value => $status, compare => 'ok', litteral => 1)) {
$self->{output}->output_add( $self->{output}->output_add(
severity => $status, severity => $status,

View File

@ -75,22 +75,15 @@ sub check {
) )
); );
my ($status, $message) = ('ok'); my $status = 'ok';
eval { if (defined($self->{option_results}->{critical}) && $self->{option_results}->{critical} ne '' &&
local $SIG{__WARN__} = sub { $message = $_[0]; }; $self->{output}->test_eval(test => $self->{option_results}->{critical}, values => $self->{data})) {
local $SIG{__DIE__} = sub { $message = $_[0]; }; $status = 'critical';
} elsif (defined($self->{option_results}->{warning}) && $self->{option_results}->{warning} ne '' &&
if (defined($self->{option_results}->{critical}) && $self->{option_results}->{critical} ne '' && $self->{output}->test_eval(test => $self->{option_results}->{warning}, values => $self->{data})) {
$self->{output}->test_eval(test => $self->{option_results}->{critical}, values => $self->{data})) { $status = 'warning';
$status = 'critical';
} elsif (defined($self->{option_results}->{warning}) && $self->{option_results}->{warning} ne '' &&
$self->{output}->test_eval(test => $self->{option_results}->{warning}, values => $self->{data})) {
$status = 'warning';
}
};
if (defined($message)) {
$self->{output}->output_add(long_msg => 'filter status issue: ' . $message);
} }
if (!$self->{output}->is_status(value => $status, compare => 'ok', litteral => 1)) { if (!$self->{output}->is_status(value => $status, compare => 'ok', litteral => 1)) {
$self->{output}->output_add( $self->{output}->output_add(
severity => $status, severity => $status,

View File

@ -82,22 +82,15 @@ sub check {
$checked++; $checked++;
my ($status, $message) = ('ok'); my $status = 'ok'
eval { if (defined($self->{option_results}->{critical}) && $self->{option_results}->{critical} ne '' &&
local $SIG{__WARN__} = sub { $message = $_[0]; }; $self->{output}->test_eval(test => $self->{option_results}->{critical}, values => $self->{data})) {
local $SIG{__DIE__} = sub { $message = $_[0]; }; $status = 'critical';
} elsif (defined($self->{option_results}->{warning}) && $self->{option_results}->{warning} ne '' &&
if (defined($self->{option_results}->{critical}) && $self->{option_results}->{critical} ne '' && $self->{output}->test_eval(test => $self->{option_results}->{warning}, values => $self->{data})) {
$self->{output}->test_eval(test => $self->{option_results}->{critical}, values => $self->{data})) { $status = 'warning';
$status = 'critical';
} elsif (defined($self->{option_results}->{warning}) && $self->{option_results}->{warning} ne '' &&
$self->{output}->test_eval(test => $self->{option_results}->{warning}, values => $self->{data})) {
$status = 'warning';
}
};
if (defined($message)) {
$self->{output}->output_add(long_msg => 'filter status issue: ' . $message);
} }
if (!$self->{output}->is_status(value => $status, compare => 'ok', litteral => 1)) { if (!$self->{output}->is_status(value => $status, compare => 'ok', litteral => 1)) {
$self->{output}->output_add( $self->{output}->output_add(
severity => $status, severity => $status,

View File

@ -74,22 +74,15 @@ sub check {
centreon::plugins::misc::trim($4), centreon::plugins::misc::trim($5)); centreon::plugins::misc::trim($4), centreon::plugins::misc::trim($5));
$checked++; $checked++;
my ($status, $message) = ('ok'); my $status = 'ok';
eval { if (defined($self->{option_results}->{critical}) && $self->{option_results}->{critical} ne '' &&
local $SIG{__WARN__} = sub { $message = $_[0]; }; $self->{output}->test_eval(test => $self->{option_results}->{critical}, values => $self->{data})) {
local $SIG{__DIE__} = sub { $message = $_[0]; }; $status = 'critical';
} elsif (defined($self->{option_results}->{warning}) && $self->{option_results}->{warning} ne '' &&
if (defined($self->{option_results}->{critical}) && $self->{option_results}->{critical} ne '' && $self->{output}->test_eval(test => $self->{option_results}->{warning}, values => $self->{data})) {
$self->{output}->test_eval(test => $self->{option_results}->{critical}, values => $self->{data})) { $status = 'warning';
$status = 'critical';
} elsif (defined($self->{option_results}->{warning}) && $self->{option_results}->{warning} ne '' &&
$self->{output}->test_eval(test => $self->{option_results}->{warning}, values => $self->{data})) {
$status = 'warning';
}
};
if (defined($message)) {
$self->{output}->output_add(long_msg => 'filter status issue: ' . $message);
} }
if (!$self->{output}->is_status(value => $status, compare => 'ok', litteral => 1)) { if (!$self->{output}->is_status(value => $status, compare => 'ok', litteral => 1)) {
$self->{output}->output_add( $self->{output}->output_add(
severity => $status, severity => $status,

View File

@ -68,22 +68,15 @@ sub check {
$checked++; $checked++;
my ($status, $message) = ('ok'); my $status = 'ok';
eval { if (defined($self->{option_results}->{critical}) && $self->{option_results}->{critical} ne '' &&
local $SIG{__WARN__} = sub { $message = $_[0]; }; $self->{output}->test_eval(test => $self->{option_results}->{critical}, values => $self->{data})) {
local $SIG{__DIE__} = sub { $message = $_[0]; }; $status = 'critical';
} elsif (defined($self->{option_results}->{warning}) && $self->{option_results}->{warning} ne '' &&
if (defined($self->{option_results}->{critical}) && $self->{option_results}->{critical} ne '' && $self->{output}->test_eval(test => $self->{option_results}->{warning}, values => $self->{data})) {
$self->{output}->test_eval(test => $self->{option_results}->{critical}, values => $self->{data})) { $status = 'warning';
$status = 'critical';
} elsif (defined($self->{option_results}->{warning}) && $self->{option_results}->{warning} ne '' &&
$self->{output}->test_eval(test => $self->{option_results}->{warning}, values => $self->{data})) {
$status = 'warning';
}
};
if (defined($message)) {
$self->{output}->output_add(long_msg => 'filter status issue: ' . $message);
} }
if (!$self->{output}->is_status(value => $status, compare => 'ok', litteral => 1)) { if (!$self->{output}->is_status(value => $status, compare => 'ok', litteral => 1)) {
$self->{output}->output_add( $self->{output}->output_add(
severity => $status, severity => $status,

View File

@ -70,22 +70,15 @@ sub check {
$checked++; $checked++;
my ($status, $message) = ('ok'); my $status = 'ok';
eval { if (defined($self->{option_results}->{critical}) && $self->{option_results}->{critical} ne '' &&
local $SIG{__WARN__} = sub { $message = $_[0]; }; $self->{output}->test_eval(test => $self->{option_results}->{critical}, values => $self->{data})) {
local $SIG{__DIE__} = sub { $message = $_[0]; }; $status = 'critical';
} elsif (defined($self->{option_results}->{warning}) && $self->{option_results}->{warning} ne '' &&
if (defined($self->{option_results}->{critical}) && $self->{option_results}->{critical} ne '' && $self->{output}->test_eval(test => $self->{option_results}->{warning}, values => $self->{data})) {
$self->{output}->test_eval(test => $self->{option_results}->{critical}, values => $self->{data})) { $status = 'warning';
$status = 'critical';
} elsif (defined($self->{option_results}->{warning}) && $self->{option_results}->{warning} ne '' &&
$self->{output}->test_eval(test => $self->{option_results}->{warning}, values => $self->{data})) {
$status = 'warning';
}
};
if (defined($message)) {
$self->{output}->output_add(long_msg => 'filter status issue: ' . $message);
} }
if (!$self->{output}->is_status(value => $status, compare => 'ok', litteral => 1)) { if (!$self->{output}->is_status(value => $status, compare => 'ok', litteral => 1)) {
$self->{output}->output_add( $self->{output}->output_add(
severity => $status, severity => $status,
@ -96,7 +89,7 @@ sub check {
); );
} }
} }
if ($checked == 0) { if ($checked == 0) {
$self->{output}->output_add( $self->{output}->output_add(
severity => 'UNKNOWN', severity => 'UNKNOWN',

View File

@ -33,30 +33,21 @@ use Time::HiRes qw(gettimeofday tv_interval);
sub custom_select_threshold { sub custom_select_threshold {
my ($self, %options) = @_; my ($self, %options) = @_;
my $status = 'ok'; my $status = 'ok';
my $message;
eval { our $expand = $self->{result_values}->{expand};
local $SIG{__WARN__} = sub { $message = $_[0]; }; if (defined($self->{result_values}->{config}->{critical}) && $self->{result_values}->{config}->{critical} &&
local $SIG{__DIE__} = sub { $message = $_[0]; }; $self->{instance_mode}->{safe}->reval($self->{result_values}->{config}->{critical})) {
$status = 'critical';
our $expand = $self->{result_values}->{expand}; } elsif (defined($self->{result_values}->{config}->{warning}) && $self->{result_values}->{config}->{warning} ne '' &&
if (defined($self->{result_values}->{config}->{critical}) && $self->{result_values}->{config}->{critical} && $self->{instance_mode}->{safe}->reval($self->{result_values}->{config}->{warning})) {
$self->{instance_mode}->{safe}->reval($self->{result_values}->{config}->{critical})) { $status = 'warning';
$status = 'critical'; } elsif (defined($self->{result_values}->{config}->{unknown}) && $self->{result_values}->{config}->{unknown} &&
} elsif (defined($self->{result_values}->{config}->{warning}) && $self->{result_values}->{config}->{warning} ne '' && $self->{instance_mode}->reval($self->{result_values}->{config}->{unknown})) {
$self->{instance_mode}->{safe}->reval($self->{result_values}->{config}->{warning})) { $status = 'unknown';
$status = 'warning'; }
} elsif (defined($self->{result_values}->{config}->{unknown}) && $self->{result_values}->{config}->{unknown} && if ($@) {
$self->{instance_mode}->reval($self->{result_values}->{config}->{unknown})) { $self->{output}->add_option_msg(short_msg => 'Unsafe code evaluation: ' . $@);
$status = 'unknown'; $self->{output}->option_exit();
}
if ($@) {
$self->{output}->add_option_msg(short_msg => 'Unsafe code evaluation: ' . $@);
$self->{output}->option_exit();
}
};
if (defined($message)) {
$self->{output}->output_add(long_msg => 'filter status issue: ' . $message);
} }
$self->{result_values}->{last_status} = $status; $self->{result_values}->{last_status} = $status;

View File

@ -383,26 +383,15 @@ sub request {
# Check response # Check response
my $status = 'ok'; my $status = 'ok';
my $message; if (defined($options{request}->{critical_status}) && $options{request}->{critical_status} ne '' &&
$self->{output}->test_eval(test => $options{request}->{critical_status}, values => { code => $self->{response_code} })) {
eval { $status = 'critical';
local $SIG{__WARN__} = sub { $message = $_[0]; }; } elsif (defined($options{request}->{warning_status}) && $options{request}->{warning_status} ne '' &&
local $SIG{__DIE__} = sub { $message = $_[0]; }; $self->{output}->test_eval(test => $options{request}->{warning_status}, values => { code => $self->{response_code} })) {
$status = 'warning';
if (defined($options{request}->{critical_status}) && $options{request}->{critical_status} ne '' && } elsif (defined($options{request}->{unknown_status}) && $options{request}->{unknown_status} ne '' &&
$self->{output}->test_eval(test => $options{request}->{critical_status}, values => { code => $self->{response_code} })) { $self->{output}->test_eval(test => $options{request}->{unknown_status}, values => { code => $self->{response_code} })) {
$status = 'critical'; $status = 'unknown';
} elsif (defined($options{request}->{warning_status}) && $options{request}->{warning_status} ne '' &&
$self->{output}->test_eval(test => $options{request}->{warning_status}, values => { code => $self->{response_code} })) {
$status = 'warning';
} elsif (defined($options{request}->{unknown_status}) && $options{request}->{unknown_status} ne '' &&
$self->{output}->test_eval(test => $options{request}->{unknown_status}, values => { code => $self->{response_code} })) {
$status = 'unknown';
}
};
if (defined($message)) {
$self->{output}->add_option_msg(short_msg => 'filter status issue: ' . $message);
$self->{output}->option_exit();
} }
if (!$self->{output}->is_status(value => $status, compare => 'ok', litteral => 1)) { if (!$self->{output}->is_status(value => $status, compare => 'ok', litteral => 1)) {

View File

@ -251,27 +251,16 @@ sub request {
# Check response # Check response
my $status = 'ok'; my $status = 'ok';
my $message; my $code = $self->{response}->code();
if (defined($request_options->{critical_status}) && $request_options->{critical_status} ne '' &&
eval { $self->{output}->test_eval(test => $request_options->{critical_status}, values => { code => $code })) {
local $SIG{__WARN__} = sub { $message = $_[0]; }; $status = 'critical';
local $SIG{__DIE__} = sub { $message = $_[0]; }; } elsif (defined($request_options->{warning_status}) && $request_options->{warning_status} ne '' &&
$self->{output}->test_eval(test => $request_options->{warning_status}, values => { code => $code })) {
my $code = $self->{response}->code(); $status = 'warning';
if (defined($request_options->{critical_status}) && $request_options->{critical_status} ne '' && } elsif (defined($request_options->{unknown_status}) && $request_options->{unknown_status} ne '' &&
$self->{output}->test_eval(test => $request_options->{critical_status}, values => { code => $code })) { $self->{output}->test_eval(test => $request_options->{unknown_status}, values => { code => $code })) {
$status = 'critical'; $status = 'unknown';
} elsif (defined($request_options->{warning_status}) && $request_options->{warning_status} ne '' &&
$self->{output}->test_eval(test => $request_options->{warning_status}, values => { code => $code })) {
$status = 'warning';
} elsif (defined($request_options->{unknown_status}) && $request_options->{unknown_status} ne '' &&
$self->{output}->test_eval(test => $request_options->{unknown_status}, values => { code => $code })) {
$status = 'unknown';
}
};
if (defined($message)) {
$self->{output}->add_option_msg(short_msg => 'filter status issue: ' . $message);
$self->{output}->option_exit();
} }
if (!$self->{output}->is_status(value => $status, compare => 'ok', litteral => 1)) { if (!$self->{output}->is_status(value => $status, compare => 'ok', litteral => 1)) {

View File

@ -928,9 +928,15 @@ sub test_eval {
die 'Unsafe code evaluation: ' . $@; die 'Unsafe code evaluation: ' . $@;
} }
} elsif (defined($options{values})) { } elsif (defined($options{values})) {
# unsafe code execution. don't need to check if it's safe (with no values)
my $values = $options{values}; my $values = $options{values};
$result = eval "$options{test}"; {
local $SIG{__WARN__} = sub {}; # ignore
$result = eval "$options{test}";
if ($@) {
die 'Code evaluation error: ' . $@;
}
}
} }
return $result; return $result;

View File

@ -30,30 +30,21 @@ our @EXPORT_OK = qw(catalog_status_threshold catalog_status_threshold_ng catalog
sub catalog_status_threshold { sub catalog_status_threshold {
my ($self, %options) = @_; my ($self, %options) = @_;
my $status = 'ok'; my $status = 'ok';
my $message;
eval { my $label = $self->{label};
local $SIG{__WARN__} = sub { $message = $_[0]; }; $label =~ s/-/_/g;
local $SIG{__DIE__} = sub { $message = $_[0]; }; if (defined($self->{instance_mode}->{option_results}->{'ok_' . $label}) && $self->{instance_mode}->{option_results}->{'ok_' . $label} ne '' &&
$self->eval(value => $self->{instance_mode}->{option_results}->{'ok_' . $label})) {
my $label = $self->{label}; $status = 'ok';
$label =~ s/-/_/g; } elsif (defined($self->{instance_mode}->{option_results}->{'critical_' . $label}) && $self->{instance_mode}->{option_results}->{'critical_' . $label} ne '' &&
if (defined($self->{instance_mode}->{option_results}->{'ok_' . $label}) && $self->{instance_mode}->{option_results}->{'ok_' . $label} ne '' && $self->eval(value => $self->{instance_mode}->{option_results}->{'critical_' . $label})) {
$self->eval(value => $self->{instance_mode}->{option_results}->{'ok_' . $label})) { $status = 'critical';
$status = 'ok'; } elsif (defined($self->{instance_mode}->{option_results}->{'warning_' . $label}) && $self->{instance_mode}->{option_results}->{'warning_' . $label} ne '' &&
} elsif (defined($self->{instance_mode}->{option_results}->{'critical_' . $label}) && $self->{instance_mode}->{option_results}->{'critical_' . $label} ne '' && $self->eval(value => $self->{instance_mode}->{option_results}->{'warning_' . $label})) {
$self->eval(value => $self->{instance_mode}->{option_results}->{'critical_' . $label})) { $status = 'warning';
$status = 'critical'; } elsif (defined($self->{instance_mode}->{option_results}->{'unknown_' . $label}) && $self->{instance_mode}->{option_results}->{'unknown_' . $label} ne '' &&
} elsif (defined($self->{instance_mode}->{option_results}->{'warning_' . $label}) && $self->{instance_mode}->{option_results}->{'warning_' . $label} ne '' && $self->eval(value => $self->{instance_mode}->{option_results}->{'unknown_' . $label})) {
$self->eval(value => $self->{instance_mode}->{option_results}->{'warning_' . $label})) { $status = 'unknown';
$status = 'warning';
} elsif (defined($self->{instance_mode}->{option_results}->{'unknown_' . $label}) && $self->{instance_mode}->{option_results}->{'unknown_' . $label} ne '' &&
$self->eval(value => $self->{instance_mode}->{option_results}->{'unknown_' . $label})) {
$status = 'unknown';
}
};
if (defined($message)) {
$self->{output}->output_add(long_msg => 'filter status issue: ' . $message);
} }
return $status; return $status;
@ -64,23 +55,15 @@ sub catalog_status_threshold_ng {
my $status = 'ok'; my $status = 'ok';
my $message; my $message;
eval { if (defined($self->{instance_mode}->{option_results}->{'critical-' . $self->{label}}) && $self->{instance_mode}->{option_results}->{'critical-' . $self->{label}} ne '' &&
local $SIG{__WARN__} = sub { $message = $_[0]; }; $self->eval(value => $self->{instance_mode}->{option_results}->{'critical-' . $self->{label}})) {
local $SIG{__DIE__} = sub { $message = $_[0]; }; $status = 'critical';
} elsif (defined($self->{instance_mode}->{option_results}->{'warning-' . $self->{label}}) && $self->{instance_mode}->{option_results}->{'warning-' . $self->{label}} ne '' &&
if (defined($self->{instance_mode}->{option_results}->{'critical-' . $self->{label}}) && $self->{instance_mode}->{option_results}->{'critical-' . $self->{label}} ne '' && $self->eval(value => $self->{instance_mode}->{option_results}->{'warning-' . $self->{label}})) {
$self->eval(value => $self->{instance_mode}->{option_results}->{'critical-' . $self->{label}})) { $status = 'warning';
$status = 'critical'; } elsif (defined($self->{instance_mode}->{option_results}->{'unknown-' . $self->{label}}) && $self->{instance_mode}->{option_results}->{'unknown-' . $self->{label}} ne '' &&
} elsif (defined($self->{instance_mode}->{option_results}->{'warning-' . $self->{label}}) && $self->{instance_mode}->{option_results}->{'warning-' . $self->{label}} ne '' && $self->eval(value => $self->{instance_mode}->{option_results}->{'unknown-' . $self->{label}})) {
$self->eval(value => $self->{instance_mode}->{option_results}->{'warning-' . $self->{label}})) { $status = 'unknown';
$status = 'warning';
} elsif (defined($self->{instance_mode}->{option_results}->{'unknown-' . $self->{label}}) && $self->{instance_mode}->{option_results}->{'unknown-' . $self->{label}} ne '' &&
$self->eval(value => $self->{instance_mode}->{option_results}->{'unknown-' . $self->{label}})) {
$status = 'unknown';
}
};
if (defined($message)) {
$self->{output}->output_add(long_msg => 'filter status issue: ' . $message);
} }
return $status; return $status;

View File

@ -761,7 +761,6 @@ sub change_macros {
foreach (@{$options{macros}}) { foreach (@{$options{macros}}) {
if (defined($self->{option_results}->{$_}) && $self->{option_results}->{$_} ne '') { if (defined($self->{option_results}->{$_}) && $self->{option_results}->{$_} ne '') {
$self->{option_results}->{$_} =~ s/%\{(.*?)\}/\$values->{$1}/g; $self->{option_results}->{$_} =~ s/%\{(.*?)\}/\$values->{$1}/g;
$self->{output}->test_eval(test => $self->{option_results}->{$_});
} }
} }
} }

View File

@ -257,7 +257,14 @@ sub eval {
} }
} else { } else {
my $values = $self->{result_values}; my $values = $self->{result_values};
$result = eval "$options{value}"; {
local $SIG{__WARN__} = sub {}; # ignore
$result = eval "$options{value}";
if ($@) {
die 'Code evaluation error: ' . $@;
}
}
} }
return $result; return $result;

View File

@ -43,23 +43,14 @@ sub prefix_metric_output {
sub custom_status_threshold { sub custom_status_threshold {
my ($self, %options) = @_; my ($self, %options) = @_;
my $status = 'ok'; my $status = 'ok';
my $message; if (defined($self->{instance_mode}->{option_results}->{critical_status}) && $self->{instance_mode}->{option_results}->{critical_status} ne '' &&
$self->eval(value => $self->{instance_mode}->{option_results}->{critical_status})) {
eval { $status = 'critical';
local $SIG{__WARN__} = sub { $message = $_[0]; }; } elsif (defined($self->{instance_mode}->{option_results}->{warning_status}) && $self->{instance_mode}->{option_results}->{warning_status} ne '' &&
local $SIG{__DIE__} = sub { $message = $_[0]; }; $self->eval(value => $self->{instance_mode}->{option_results}->{warning_status})) {
$status = 'warning';
if (defined($self->{instance_mode}->{option_results}->{critical_status}) && $self->{instance_mode}->{option_results}->{critical_status} ne '' &&
$self->eval(value => $self->{instance_mode}->{option_results}->{critical_status})) {
$status = 'critical';
} elsif (defined($self->{instance_mode}->{option_results}->{warning_status}) && $self->{instance_mode}->{option_results}->{warning_status} ne '' &&
$self->eval(value => $self->{instance_mode}->{option_results}->{warning_status})) {
$status = 'warning';
}
};
if (defined($message)) {
$self->{output}->output_add(long_msg => 'filter status issue: ' . $message);
} }
return $status; return $status;

View File

@ -27,6 +27,7 @@ use warnings;
sub custom_status_output { sub custom_status_output {
my ($self, %options) = @_; my ($self, %options) = @_;
my $msg = 'Status : ' . $self->{result_values}->{linkstatus} . ' (oper: ' . $self->{result_values}->{opstatus} . ', ' . 'admin: ' . $self->{result_values}->{admstatus} . ')'; my $msg = 'Status : ' . $self->{result_values}->{linkstatus} . ' (oper: ' . $self->{result_values}->{opstatus} . ', ' . 'admin: ' . $self->{result_values}->{admstatus} . ')';
if (defined($self->{instance_mode}->{option_results}->{add_duplex_status})) { if (defined($self->{instance_mode}->{option_results}->{add_duplex_status})) {
$msg .= ' (duplex: ' . $self->{result_values}->{duplexstatus} . ')'; $msg .= ' (duplex: ' . $self->{result_values}->{duplexstatus} . ')';
@ -324,15 +325,10 @@ sub add_result_global {
admstatus => $self->{oid_adminstatus_mapping}->{$self->{results}->{$self->{oid_adminstatus} . '.' . $_}} admstatus => $self->{oid_adminstatus_mapping}->{$self->{results}->{$self->{oid_adminstatus} . '.' . $_}}
}; };
foreach (('global_link_up', 'global_link_down', 'global_admin_up', 'global_admin_down', 'global_oper_up', 'global_oper_down')) { foreach (('global_link_up', 'global_link_down', 'global_admin_up', 'global_admin_down', 'global_oper_up', 'global_oper_down')) {
eval { if (defined($self->{option_results}->{$_ . '_rule'}) && $self->{option_results}->{$_ . '_rule'} ne '' &&
local $SIG{__WARN__} = sub { return ; }; $self->{output}->test_eval(test => $self->{option_results}->{$_ . '_rule'}, values => $values)) {
local $SIG{__DIE__} = sub { return ; }; $self->{global}->{$_}++;
}
if (defined($self->{option_results}->{$_ . '_rule'}) && $self->{option_results}->{$_ . '_rule'} ne '' &&
$self->{output}->test_eval(test => $self->{option_results}->{$_ . '_rule'}, values => $values)) {
$self->{global}->{$_}++;
}
};
} }
$self->{global}->{total_port}++; $self->{global}->{total_port}++;
} }

View File

@ -33,27 +33,18 @@ use Digest::MD5 qw(md5_hex);
sub custom_threshold_output { sub custom_threshold_output {
my ($self, %options) = @_; my ($self, %options) = @_;
my $status = 'ok'; my $status = 'ok';
my $message;
eval { if (defined($self->{instance_mode}->{option_results}->{critical_status}) && $self->{instance_mode}->{option_results}->{critical_status} ne '' &&
local $SIG{__WARN__} = sub { $message = $_[0]; }; $self->eval(value => $self->{instance_mode}->{option_results}->{critical_status})) {
local $SIG{__DIE__} = sub { $message = $_[0]; }; $status = 'critical';
} elsif (defined($self->{instance_mode}->{option_results}->{warning_status}) && $self->{instance_mode}->{option_results}->{warning_status} ne '' &&
$self->eval(value => $self->{instance_mode}->{option_results}->{warning_status})) {
$status = 'warning';
}
if (defined($self->{instance_mode}->{option_results}->{critical_status}) && $self->{instance_mode}->{option_results}->{critical_status} ne '' && $self->{instance_mode}->{last_status} = 0;
$self->eval(value => $self->{instance_mode}->{option_results}->{critical_status})) { if (eval "$self->{instance_mode}->{check_status}") {
$status = 'critical'; $self->{instance_mode}->{last_status} = 1;
} elsif (defined($self->{instance_mode}->{option_results}->{warning_status}) && $self->{instance_mode}->{option_results}->{warning_status} ne '' &&
$self->eval(value => $self->{instance_mode}->{option_results}->{warning_status})) {
$status = 'warning';
}
$self->{instance_mode}->{last_status} = 0;
if (eval "$self->{instance_mode}->{check_status}") {
$self->{instance_mode}->{last_status} = 1;
}
};
if (defined($message)) {
$self->{output}->output_add(long_msg => 'filter status issue: ' . $message);
} }
return $status; return $status;
@ -1341,15 +1332,10 @@ sub add_result_global {
admstatus => $self->{oid_adminstatus_mapping}->{ $self->{results}->{$self->{oid_adminstatus} . '.' . $_} } admstatus => $self->{oid_adminstatus_mapping}->{ $self->{results}->{$self->{oid_adminstatus} . '.' . $_} }
}; };
foreach (('global_admin_up', 'global_admin_down', 'global_oper_up', 'global_oper_down')) { foreach (('global_admin_up', 'global_admin_down', 'global_oper_up', 'global_oper_down')) {
eval { if (defined($self->{option_results}->{$_ . '_rule'}) && $self->{option_results}->{$_ . '_rule'} ne '' &&
local $SIG{__WARN__} = sub { return ; }; $self->{output}->test_eval(test => $self->{option_results}->{$_ . '_rule'}, values => $values)) {
local $SIG{__DIE__} = sub { return ; }; $self->{global}->{$_}++;
}
if (defined($self->{option_results}->{$_ . '_rule'}) && $self->{option_results}->{$_ . '_rule'} ne '' &&
$self->{output}->test_eval(test => $self->{option_results}->{$_ . '_rule'}, values => $values)) {
$self->{global}->{$_}++;
}
};
} }
$self->{global}->{total_port}++; $self->{global}->{total_port}++;
} }