Fix #1952
This commit is contained in:
parent
7b50b89261
commit
9098a5adef
|
@ -26,46 +26,44 @@ use Net::DNS;
|
||||||
|
|
||||||
my $handle;
|
my $handle;
|
||||||
|
|
||||||
my %map_search_field = (
|
sub search {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
my $map_search_field = {
|
||||||
MX => 'exchange',
|
MX => 'exchange',
|
||||||
SOA => 'mname',
|
SOA => 'mname',
|
||||||
NS => 'nsdname',
|
NS => 'nsdname',
|
||||||
A => 'address',
|
A => 'address',
|
||||||
PTR => 'name',
|
PTR => 'name',
|
||||||
CNAME => 'cname',
|
CNAME => 'cname',
|
||||||
TXT => 'txtdata',
|
TXT => 'txtdata'
|
||||||
);
|
};
|
||||||
|
|
||||||
sub search {
|
|
||||||
my ($self, %options) = @_;
|
|
||||||
|
|
||||||
my @results = ();
|
my @results = ();
|
||||||
my $search_type = $self->{option_results}->{search_type};
|
my $search_type = $self->{option_results}->{search_type};
|
||||||
if (defined($search_type) && !defined($map_search_field{$search_type})) {
|
if (defined($search_type) && !defined($map_search_field->{$search_type})) {
|
||||||
$self->{output}->add_option_msg(short_msg => "search-type '$search_type' is unknown or unsupported");
|
$self->{output}->add_option_msg(short_msg => "search-type '$search_type' is unknown or unsupported");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$map_search_field->{PTR} = 'ptrdname' if (defined($self->{option_results}->{use_ptr_fqdn}));
|
||||||
|
|
||||||
my $error_quit = defined($options{error_quit}) ? $options{error_quit} : undef;
|
my $error_quit = defined($options{error_quit}) ? $options{error_quit} : undef;
|
||||||
|
|
||||||
my $reply = $handle->search($self->{option_results}->{search}, $search_type);
|
my $reply = $handle->search($self->{option_results}->{search}, $search_type);
|
||||||
if ($reply) {
|
if ($reply) {
|
||||||
foreach my $rr ($reply->answer) {
|
foreach my $rr ($reply->answer) {
|
||||||
if (!defined($search_type)) {
|
my $type = defined($search_type) ? $search_type : $rr->type;
|
||||||
push @results, $rr->address if ($rr->type eq 'A');
|
next if ($type ne $rr->type);
|
||||||
push @results, $rr->name if ($rr->type eq 'PTR');
|
my $attr = $map_search_field->{$type};
|
||||||
push @results, $rr->txtdata if ($rr->type eq 'TXT');
|
push @results, $rr->$attr;
|
||||||
next;
|
|
||||||
}
|
|
||||||
|
|
||||||
next if ($rr->type ne $search_type);
|
|
||||||
my $search_field = $map_search_field{$search_type};
|
|
||||||
push @results, $rr->$search_field;
|
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (defined($error_quit)) {
|
if (defined($error_quit)) {
|
||||||
$self->{output}->output_add(severity => $error_quit,
|
$self->{output}->output_add(
|
||||||
short_msg => sprintf("DNS Query Failed: %s", $handle->errorstring));
|
severity => $error_quit,
|
||||||
|
short_msg => sprintf('DNS query failed: %s', $handle->errorstring)
|
||||||
|
);
|
||||||
$self->{output}->display();
|
$self->{output}->display();
|
||||||
$self->{output}->exit();
|
$self->{output}->exit();
|
||||||
}
|
}
|
||||||
|
|
|
@ -34,17 +34,17 @@ sub new {
|
||||||
my $self = $class->SUPER::new(package => __PACKAGE__, %options);
|
my $self = $class->SUPER::new(package => __PACKAGE__, %options);
|
||||||
bless $self, $class;
|
bless $self, $class;
|
||||||
|
|
||||||
$options{options}->add_options(arguments =>
|
$options{options}->add_options(arguments => {
|
||||||
{
|
'nameservers:s@' => { name => 'nameservers' },
|
||||||
"nameservers:s@" => { name => 'nameservers' },
|
'searchlist:s@' => { name => 'searchlist' },
|
||||||
"searchlist:s@" => { name => 'searchlist' },
|
'dns-options:s@' => { name => 'dns_options' },
|
||||||
"dns-options:s@" => { name => 'dns_options' },
|
'search:s' => { name => 'search' },
|
||||||
"search:s" => { name => 'search' },
|
'search-type:s' => { name => 'search_type' },
|
||||||
"search-type:s" => { name => 'search_type' },
|
'use-ptr-fqdn' => { name => 'use_ptr_fqdn' },
|
||||||
"expected-answer:s" => { name => 'expected_answer' },
|
'expected-answer:s' => { name => 'expected_answer' },
|
||||||
"warning:s" => { name => 'warning' },
|
'warning:s' => { name => 'warning' },
|
||||||
"critical:s" => { name => 'critical' },
|
'critical:s' => { name => 'critical' },
|
||||||
"memory" => { name => 'memory' },
|
'memory' => { name => 'memory' }
|
||||||
});
|
});
|
||||||
|
|
||||||
$self->{statefile_cache} = centreon::plugins::statefile->new(%options);
|
$self->{statefile_cache} = centreon::plugins::statefile->new(%options);
|
||||||
|
@ -96,14 +96,20 @@ sub run {
|
||||||
my $timeelapsed = tv_interval ($timing0, [gettimeofday]);
|
my $timeelapsed = tv_interval ($timing0, [gettimeofday]);
|
||||||
my $result_str = join(', ', @results);
|
my $result_str = join(', ', @results);
|
||||||
|
|
||||||
my $exit = $self->{perfdata}->threshold_check(value => $timeelapsed,
|
my $exit = $self->{perfdata}->threshold_check(
|
||||||
threshold => [ { label => 'critical', exit_litteral => 'critical' }, { label => 'warning', exit_litteral => 'warning' } ]);
|
value => $timeelapsed,
|
||||||
$self->{output}->output_add(severity => $exit,
|
threshold => [ { label => 'critical', exit_litteral => 'critical' }, { label => 'warning', exit_litteral => 'warning' } ]
|
||||||
short_msg => sprintf("Response time %.3f second(s) (answer: %s)", $timeelapsed, $result_str));
|
);
|
||||||
$self->{output}->perfdata_add(label => "time", unit => 's',
|
$self->{output}->output_add(
|
||||||
|
severity => $exit,
|
||||||
|
short_msg => sprintf("Response time %.3f second(s) (answer: %s)", $timeelapsed, $result_str)
|
||||||
|
);
|
||||||
|
$self->{output}->perfdata_add(
|
||||||
|
label => "time", unit => 's',
|
||||||
value => sprintf('%.3f', $timeelapsed),
|
value => sprintf('%.3f', $timeelapsed),
|
||||||
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning'),
|
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning'),
|
||||||
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical'));
|
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical')
|
||||||
|
);
|
||||||
|
|
||||||
if (defined($self->{option_results}->{expected_answer}) && $self->{option_results}->{expected_answer} ne '') {
|
if (defined($self->{option_results}->{expected_answer}) && $self->{option_results}->{expected_answer} ne '') {
|
||||||
my $match = 0;
|
my $match = 0;
|
||||||
|
@ -114,8 +120,11 @@ sub run {
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($match == 0) {
|
if ($match == 0) {
|
||||||
$self->{output}->output_add(severity => 'CRITICAL',
|
$self->{output}->output_add(
|
||||||
short_msg => sprintf("No result values match expected answer (answer: %s)", $result_str));
|
severity => 'CRITICAL',
|
||||||
|
short_msg => sprintf("No result values match expected answer (answer: %s)", $result_str
|
||||||
|
)
|
||||||
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -125,8 +134,10 @@ sub run {
|
||||||
my $old_result = $self->{statefile_cache}->get(name => "result");
|
my $old_result = $self->{statefile_cache}->get(name => "result");
|
||||||
if (defined($old_result)) {
|
if (defined($old_result)) {
|
||||||
if ($old_result ne $result_str) {
|
if ($old_result ne $result_str) {
|
||||||
$self->{output}->output_add(severity => 'CRITICAL',
|
$self->{output}->output_add(
|
||||||
short_msg => sprintf("Result has changed [answer: %s] [old answer: %s]", $result_str, $old_result));
|
severity => 'CRITICAL',
|
||||||
|
short_msg => sprintf("Result has changed [answer: %s] [old answer: %s]", $result_str, $old_result)
|
||||||
|
);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
$self->{output}->output_add(long_msg => 'cache file created.');
|
$self->{output}->output_add(long_msg => 'cache file created.');
|
||||||
|
@ -169,6 +180,10 @@ Set the search value (required).
|
||||||
Set the search type. Can be: 'MX', 'SOA', 'NS', 'A', 'CNAME' or 'PTR'.
|
Set the search type. Can be: 'MX', 'SOA', 'NS', 'A', 'CNAME' or 'PTR'.
|
||||||
'A' or 'PTR' is used by default (depends if an IP or not).
|
'A' or 'PTR' is used by default (depends if an IP or not).
|
||||||
|
|
||||||
|
=item B<--use-ptr-fqdn>
|
||||||
|
|
||||||
|
Search is done on conical names for PTR type.
|
||||||
|
|
||||||
=item B<--expected-answer>
|
=item B<--expected-answer>
|
||||||
|
|
||||||
What the server must answer (can be a regexp).
|
What the server must answer (can be a regexp).
|
||||||
|
|
Loading…
Reference in New Issue