Merge branch 'master' of http://git.centreon.com/centreon-plugins
This commit is contained in:
commit
bd4753554d
|
@ -42,6 +42,7 @@ use centreon::plugins::httplib;
|
||||||
use centreon::plugins::statefile;
|
use centreon::plugins::statefile;
|
||||||
use Digest::MD5 qw(md5_hex);
|
use Digest::MD5 qw(md5_hex);
|
||||||
use XML::XPath;
|
use XML::XPath;
|
||||||
|
use URI::Escape;
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
my ($class, %options) = @_;
|
my ($class, %options) = @_;
|
||||||
|
@ -203,6 +204,7 @@ sub manage_selection {
|
||||||
my $connector_name = $node->getParentNode()->getParentNode()->getAttribute("name");
|
my $connector_name = $node->getParentNode()->getParentNode()->getAttribute("name");
|
||||||
$connector_name =~ s/^["'\s]+//;
|
$connector_name =~ s/^["'\s]+//;
|
||||||
$connector_name =~ s/["'\s]+$//;
|
$connector_name =~ s/["'\s]+$//;
|
||||||
|
$connector_name = uri_unescape($connector_name);
|
||||||
|
|
||||||
next if (defined($self->{option_results}->{name}) && defined($self->{option_results}->{use_regexp}) && defined($self->{option_results}->{use_regexpi})
|
next if (defined($self->{option_results}->{name}) && defined($self->{option_results}->{use_regexp}) && defined($self->{option_results}->{use_regexpi})
|
||||||
&& $connector_name !~ /$self->{option_results}->{name}/i);
|
&& $connector_name !~ /$self->{option_results}->{name}/i);
|
||||||
|
@ -236,7 +238,7 @@ sub run {
|
||||||
$self->manage_selection();
|
$self->manage_selection();
|
||||||
|
|
||||||
my $new_datas = {};
|
my $new_datas = {};
|
||||||
$self->{statefile_value}->read(statefile => "cache_apps_tomcat_web_" . $self->{hostname} . '_' . $self->{mode} . '_' . (defined($self->{option_results}->{name}) ? md5_hex($self->{option_results}->{name}) : md5_hex('all')));
|
$self->{statefile_value}->read(statefile => 'cache_apps_tomcat_web_' . $self->{option_results}->{hostname} . '_' . $self->{option_results}->{port} . '_' . $self->{mode} . '_' . (defined($self->{option_results}->{name}) ? md5_hex($self->{option_results}->{name}) : md5_hex('all')));
|
||||||
$new_datas->{last_timestamp} = time();
|
$new_datas->{last_timestamp} = time();
|
||||||
my $old_timestamp = $self->{statefile_value}->get(name => 'last_timestamp');
|
my $old_timestamp = $self->{statefile_value}->get(name => 'last_timestamp');
|
||||||
|
|
||||||
|
|
|
@ -40,6 +40,7 @@ use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::httplib;
|
||||||
use XML::XPath;
|
use XML::XPath;
|
||||||
|
use URI::Escape;
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
my ($class, %options) = @_;
|
my ($class, %options) = @_;
|
||||||
|
@ -160,6 +161,7 @@ sub manage_selection {
|
||||||
my $connector_name = $node->getParentNode()->getParentNode()->getAttribute("name");
|
my $connector_name = $node->getParentNode()->getParentNode()->getAttribute("name");
|
||||||
$connector_name =~ s/^["'\s]+//;
|
$connector_name =~ s/^["'\s]+//;
|
||||||
$connector_name =~ s/["'\s]+$//;
|
$connector_name =~ s/["'\s]+$//;
|
||||||
|
$connector_name = uri_unescape($connector_name);
|
||||||
|
|
||||||
next if (defined($self->{option_results}->{name}) && defined($self->{option_results}->{use_regexp}) && defined($self->{option_results}->{use_regexpi})
|
next if (defined($self->{option_results}->{name}) && defined($self->{option_results}->{use_regexp}) && defined($self->{option_results}->{use_regexpi})
|
||||||
&& $connector_name !~ /$self->{option_results}->{name}/i);
|
&& $connector_name !~ /$self->{option_results}->{name}/i);
|
||||||
|
|
|
@ -43,6 +43,7 @@ use centreon::plugins::misc;
|
||||||
use centreon::plugins::statefile;
|
use centreon::plugins::statefile;
|
||||||
use Digest::MD5 qw(md5_hex);
|
use Digest::MD5 qw(md5_hex);
|
||||||
use XML::XPath;
|
use XML::XPath;
|
||||||
|
use URI::Escape;
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
my ($class, %options) = @_;
|
my ($class, %options) = @_;
|
||||||
|
@ -188,6 +189,7 @@ sub manage_selection {
|
||||||
my $connector_name = $node->getParentNode()->getParentNode()->getAttribute("name");
|
my $connector_name = $node->getParentNode()->getParentNode()->getAttribute("name");
|
||||||
$connector_name =~ s/^["'\s]+//;
|
$connector_name =~ s/^["'\s]+//;
|
||||||
$connector_name =~ s/["'\s]+$//;
|
$connector_name =~ s/["'\s]+$//;
|
||||||
|
$connector_name = uri_unescape($connector_name);
|
||||||
|
|
||||||
next if (defined($self->{option_results}->{name}) && defined($self->{option_results}->{use_regexp}) && defined($self->{option_results}->{use_regexpi})
|
next if (defined($self->{option_results}->{name}) && defined($self->{option_results}->{use_regexp}) && defined($self->{option_results}->{use_regexpi})
|
||||||
&& $connector_name !~ /$self->{option_results}->{name}/i);
|
&& $connector_name !~ /$self->{option_results}->{name}/i);
|
||||||
|
@ -221,7 +223,7 @@ sub run {
|
||||||
$self->manage_selection();
|
$self->manage_selection();
|
||||||
|
|
||||||
my $new_datas = {};
|
my $new_datas = {};
|
||||||
$self->{statefile_value}->read(statefile => "cache_apps_tomcat_web_" . $self->{hostname} . '_' . $self->{mode} . '_' . (defined($self->{option_results}->{name}) ? md5_hex($self->{option_results}->{name}) : md5_hex('all')));
|
$self->{statefile_value}->read(statefile => 'cache_apps_tomcat_web_' . $self->{option_results}->{hostname} . '_' . $self->{option_results}->{port} . '_' . $self->{mode} . '_' . (defined($self->{option_results}->{name}) ? md5_hex($self->{option_results}->{name}) : md5_hex('all')));
|
||||||
$new_datas->{last_timestamp} = time();
|
$new_datas->{last_timestamp} = time();
|
||||||
my $old_timestamp = $self->{statefile_value}->get(name => 'last_timestamp');
|
my $old_timestamp = $self->{statefile_value}->get(name => 'last_timestamp');
|
||||||
|
|
||||||
|
|
|
@ -58,9 +58,12 @@ sub new {
|
||||||
"sudo" => { name => 'sudo' },
|
"sudo" => { name => 'sudo' },
|
||||||
"command:s" => { name => 'command', default => 'errpt' },
|
"command:s" => { name => 'command', default => 'errpt' },
|
||||||
"command-path:s" => { name => 'command_path' },
|
"command-path:s" => { name => 'command_path' },
|
||||||
|
"command-options:s" => { name => 'command_options', default => '' },
|
||||||
"error-type:s" => { name => 'error_type' },
|
"error-type:s" => { name => 'error_type' },
|
||||||
"error-class:s" => { name => 'error_class' },
|
"error-class:s" => { name => 'error_class' },
|
||||||
"retention:s" => { name => 'retention' },
|
"retention:s" => { name => 'retention' },
|
||||||
|
"timezone:s" => { name => 'timezone' },
|
||||||
|
"description" => { name => 'description' },
|
||||||
});
|
});
|
||||||
$self->{result} = {};
|
$self->{result} = {};
|
||||||
return $self;
|
return $self;
|
||||||
|
@ -76,13 +79,16 @@ sub manage_selection {
|
||||||
my $extra_options = '';
|
my $extra_options = '';
|
||||||
|
|
||||||
if (defined($self->{option_results}->{error_type})){
|
if (defined($self->{option_results}->{error_type})){
|
||||||
$extra_options = $extra_options.' -T '.$self->{option_results}->{error_type};
|
$extra_options .= ' -T '.$self->{option_results}->{error_type};
|
||||||
}
|
}
|
||||||
if (defined($self->{option_results}->{error_class})){
|
if (defined($self->{option_results}->{error_class})){
|
||||||
$extra_options = $extra_options.' -d '.$self->{option_results}->{error_class};
|
$extra_options .= ' -d '.$self->{option_results}->{error_class};
|
||||||
}
|
}
|
||||||
if (defined($self->{option_results}->{retention})){
|
if (defined($self->{option_results}->{retention})){
|
||||||
my $retention = time() - $self->{option_results}->{retention};
|
my $retention = time() - $self->{option_results}->{retention};
|
||||||
|
if (defined($self->{option_results}->{timezone})){
|
||||||
|
$ENV{TZ} = $self->{option_results}->{timezone};
|
||||||
|
}
|
||||||
my ($sec,$min,$hour,$mday,$mon,$year,$wday,$yday,$isdst) = localtime($retention);
|
my ($sec,$min,$hour,$mday,$mon,$year,$wday,$yday,$isdst) = localtime($retention);
|
||||||
$year = $year - 100;
|
$year = $year - 100;
|
||||||
if (length($sec)==1){
|
if (length($sec)==1){
|
||||||
|
@ -94,14 +100,19 @@ sub manage_selection {
|
||||||
if (length($hour)==1){
|
if (length($hour)==1){
|
||||||
$hour = '0'.$hour;
|
$hour = '0'.$hour;
|
||||||
}
|
}
|
||||||
|
if (length($mday)==1){
|
||||||
|
$mday = '0'.$mday;
|
||||||
|
}
|
||||||
$mon = $mon + 1;
|
$mon = $mon + 1;
|
||||||
if (length($mon)==1){
|
if (length($mon)==1){
|
||||||
$mon = '0'.$mon;
|
$mon = '0'.$mon;
|
||||||
}
|
}
|
||||||
$retention = $mon.$mday.$hour.$min.$year;
|
$retention = $mon.$mday.$hour.$min.$year;
|
||||||
$extra_options = $extra_options.' -s '.$retention;
|
$extra_options .= ' -s '.$retention;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$extra_options .= $self->{option_results}->{command_options};
|
||||||
|
|
||||||
my $stdout = centreon::plugins::misc::execute(output => $self->{output},
|
my $stdout = centreon::plugins::misc::execute(output => $self->{output},
|
||||||
options => $self->{option_results},
|
options => $self->{option_results},
|
||||||
sudo => $self->{option_results}->{sudo},
|
sudo => $self->{option_results}->{sudo},
|
||||||
|
@ -114,14 +125,16 @@ sub manage_selection {
|
||||||
foreach my $line (@lines) {
|
foreach my $line (@lines) {
|
||||||
next if ($line !~ /^(\S+)\s+(\S+)\s+(\S+)\s+(\S+)\s+(\S+)\s+(.*)/);
|
next if ($line !~ /^(\S+)\s+(\S+)\s+(\S+)\s+(\S+)\s+(\S+)\s+(.*)/);
|
||||||
|
|
||||||
my ($identifier, $timestamp, $resource_name) = ($1, $2, $5);
|
my ($identifier, $timestamp, $resource_name, $description) = ($1, $2, $5, $6);
|
||||||
$self->{result}->{$identifier} = {timestamp => $timestamp, resource_name => $resource_name};
|
$self->{result}->{$timestamp.'~'.$identifier.'~'.$resource_name} = {description => $description};
|
||||||
}
|
}
|
||||||
|
|
||||||
if (scalar(keys %{$self->{result}}) <= 0) {
|
if (scalar(keys %{$self->{result}}) <= 0) {
|
||||||
if (defined($self->{option_results}->{name})) {
|
if (defined($self->{option_results}->{retention})) {
|
||||||
$self->{output}->output_add(long_msg => "No error found with these options.");
|
$self->{output}->output_add(long_msg => sprintf("No error found with these options since %s seconds.", $self->{option_results}->{retention}));
|
||||||
|
$self->{output}->output_add(short_msg => sprintf("No error found since %s seconds.", $self->{option_results}->{retention}));
|
||||||
} else {
|
} else {
|
||||||
|
$self->{output}->output_add(long_msg => "No error found with these options.");
|
||||||
$self->{output}->output_add(short_msg => "No error found.");
|
$self->{output}->output_add(short_msg => "No error found.");
|
||||||
}
|
}
|
||||||
$self->{output}->display();
|
$self->{output}->display();
|
||||||
|
@ -136,17 +149,27 @@ sub run {
|
||||||
$self->{output}->output_add(severity => 'OK',
|
$self->{output}->output_add(severity => 'OK',
|
||||||
short_msg => 'No error found.');
|
short_msg => 'No error found.');
|
||||||
|
|
||||||
foreach my $identifier (sort(keys %{$self->{result}})) {
|
foreach my $errpt_error (sort(keys %{$self->{result}})) {
|
||||||
my $timestamp = $self->{result}->{$identifier}->{timestamp};
|
my @split_error = split ('~',$errpt_error);
|
||||||
my $resource_name = $self->{result}->{$identifier}->{resource_name};
|
my $timestamp = $split_error[0];
|
||||||
|
my $identifier = $split_error[1];
|
||||||
|
my $resource_name = $split_error[2];
|
||||||
|
my $description = $self->{result}->{$errpt_error}->{description};
|
||||||
my $exit;
|
my $exit;
|
||||||
|
if (defined($self->{option_results}->{description})) {
|
||||||
|
$self->{output}->output_add(long_msg => sprintf("Error '%s' Date: %s ResourceName: %s Description: %s", $identifier,
|
||||||
|
$timestamp, $resource_name, $description));
|
||||||
|
$self->{output}->output_add(severity => 'critical',
|
||||||
|
short_msg => sprintf("Error '%s' Date: %s ResourceName: %s Description: %s", $identifier,
|
||||||
|
$timestamp, $resource_name, $description));
|
||||||
|
} else {
|
||||||
$self->{output}->output_add(long_msg => sprintf("Error '%s' Date: %s ResourceName: %s", $identifier,
|
$self->{output}->output_add(long_msg => sprintf("Error '%s' Date: %s ResourceName: %s", $identifier,
|
||||||
$timestamp, $resource_name));
|
$timestamp, $resource_name));
|
||||||
$self->{output}->output_add(severity => 'critical',
|
$self->{output}->output_add(severity => 'critical',
|
||||||
short_msg => sprintf("Error '%s' Date: %s ResourceName: %s", $identifier,
|
short_msg => sprintf("Error '%s' Date: %s ResourceName: %s", $identifier,
|
||||||
$timestamp, $resource_name));
|
$timestamp, $resource_name));
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
$self->{output}->display();
|
$self->{output}->display();
|
||||||
$self->{output}->exit();
|
$self->{output}->exit();
|
||||||
|
@ -209,7 +232,11 @@ Filter error class ('H' for hardware, 'S' for software, '0' for errlogger, 'U' f
|
||||||
|
|
||||||
=item B<--retention>
|
=item B<--retention>
|
||||||
|
|
||||||
Retention time of errors in seconds
|
Retention time of errors in seconds.
|
||||||
|
|
||||||
|
=item B<--retention>
|
||||||
|
|
||||||
|
Print error description in output.
|
||||||
|
|
||||||
=back
|
=back
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue