From c558ddc9b39d81fdf1b58444e58e227b990ba56d Mon Sep 17 00:00:00 2001 From: Florian Asche Date: Thu, 8 May 2014 15:29:59 +0200 Subject: [PATCH 1/3] Ref #5529 Bugfix: Added uri_unescape --- apps/tomcat/web/mode/requestinfo.pm | 2 ++ apps/tomcat/web/mode/threads.pm | 2 ++ apps/tomcat/web/mode/traffic.pm | 2 ++ 3 files changed, 6 insertions(+) diff --git a/apps/tomcat/web/mode/requestinfo.pm b/apps/tomcat/web/mode/requestinfo.pm index 4412a7139..ab0a9f815 100644 --- a/apps/tomcat/web/mode/requestinfo.pm +++ b/apps/tomcat/web/mode/requestinfo.pm @@ -42,6 +42,7 @@ use centreon::plugins::httplib; use centreon::plugins::statefile; use Digest::MD5 qw(md5_hex); use XML::XPath; +use URI::Escape; sub new { my ($class, %options) = @_; @@ -203,6 +204,7 @@ sub manage_selection { my $connector_name = $node->getParentNode()->getParentNode()->getAttribute("name"); $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}) && $connector_name !~ /$self->{option_results}->{name}/i); diff --git a/apps/tomcat/web/mode/threads.pm b/apps/tomcat/web/mode/threads.pm index 89fbcaea0..6e386ba0b 100644 --- a/apps/tomcat/web/mode/threads.pm +++ b/apps/tomcat/web/mode/threads.pm @@ -40,6 +40,7 @@ use strict; use warnings; use centreon::plugins::httplib; use XML::XPath; +use URI::Escape; sub new { my ($class, %options) = @_; @@ -160,6 +161,7 @@ sub manage_selection { my $connector_name = $node->getParentNode()->getParentNode()->getAttribute("name"); $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}) && $connector_name !~ /$self->{option_results}->{name}/i); diff --git a/apps/tomcat/web/mode/traffic.pm b/apps/tomcat/web/mode/traffic.pm index f212c2572..a8f02933e 100644 --- a/apps/tomcat/web/mode/traffic.pm +++ b/apps/tomcat/web/mode/traffic.pm @@ -43,6 +43,7 @@ use centreon::plugins::misc; use centreon::plugins::statefile; use Digest::MD5 qw(md5_hex); use XML::XPath; +use URI::Escape; sub new { my ($class, %options) = @_; @@ -188,6 +189,7 @@ sub manage_selection { my $connector_name = $node->getParentNode()->getParentNode()->getAttribute("name"); $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}) && $connector_name !~ /$self->{option_results}->{name}/i); From 2d6297c266994d170109cc66ad85db2ff544646e Mon Sep 17 00:00:00 2001 From: Florian Asche Date: Fri, 9 May 2014 11:27:18 +0200 Subject: [PATCH 2/3] Refs #5529: Bugfix - Added Port to Cache File to avoid problems with multiple tomcat instances on one server. --- apps/tomcat/web/mode/requestinfo.pm | 2 +- apps/tomcat/web/mode/traffic.pm | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/apps/tomcat/web/mode/requestinfo.pm b/apps/tomcat/web/mode/requestinfo.pm index ab0a9f815..1c888cf01 100644 --- a/apps/tomcat/web/mode/requestinfo.pm +++ b/apps/tomcat/web/mode/requestinfo.pm @@ -238,7 +238,7 @@ sub run { $self->manage_selection(); 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(); my $old_timestamp = $self->{statefile_value}->get(name => 'last_timestamp'); diff --git a/apps/tomcat/web/mode/traffic.pm b/apps/tomcat/web/mode/traffic.pm index a8f02933e..0b0d7a117 100644 --- a/apps/tomcat/web/mode/traffic.pm +++ b/apps/tomcat/web/mode/traffic.pm @@ -223,7 +223,7 @@ sub run { $self->manage_selection(); 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(); my $old_timestamp = $self->{statefile_value}->get(name => 'last_timestamp'); From 8e43523f1659a8bef612d0776f5646ee84c481a6 Mon Sep 17 00:00:00 2001 From: Kevin Duret Date: Fri, 9 May 2014 12:28:23 +0200 Subject: [PATCH 3/3] fix some bugs and add option --description #5491 --- os/aix/local/mode/errpt.pm | 63 +++++++++++++++++++++++++++----------- 1 file changed, 45 insertions(+), 18 deletions(-) diff --git a/os/aix/local/mode/errpt.pm b/os/aix/local/mode/errpt.pm index 779bc37ae..e3d8af0fd 100644 --- a/os/aix/local/mode/errpt.pm +++ b/os/aix/local/mode/errpt.pm @@ -58,9 +58,12 @@ sub new { "sudo" => { name => 'sudo' }, "command:s" => { name => 'command', default => 'errpt' }, "command-path:s" => { name => 'command_path' }, + "command-options:s" => { name => 'command_options', default => '' }, "error-type:s" => { name => 'error_type' }, "error-class:s" => { name => 'error_class' }, "retention:s" => { name => 'retention' }, + "timezone:s" => { name => 'timezone' }, + "description" => { name => 'description' }, }); $self->{result} = {}; return $self; @@ -76,13 +79,16 @@ sub manage_selection { my $extra_options = ''; 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})){ - $extra_options = $extra_options.' -d '.$self->{option_results}->{error_class}; + $extra_options .= ' -d '.$self->{option_results}->{error_class}; } if (defined($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); $year = $year - 100; if (length($sec)==1){ @@ -94,13 +100,18 @@ sub manage_selection { if (length($hour)==1){ $hour = '0'.$hour; } + if (length($mday)==1){ + $mday = '0'.$mday; + } $mon = $mon + 1; if (length($mon)==1){ $mon = '0'.$mon; } $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}, options => $self->{option_results}, @@ -114,14 +125,16 @@ sub manage_selection { foreach my $line (@lines) { next if ($line !~ /^(\S+)\s+(\S+)\s+(\S+)\s+(\S+)\s+(\S+)\s+(.*)/); - my ($identifier, $timestamp, $resource_name) = ($1, $2, $5); - $self->{result}->{$identifier} = {timestamp => $timestamp, resource_name => $resource_name}; + my ($identifier, $timestamp, $resource_name, $description) = ($1, $2, $5, $6); + $self->{result}->{$timestamp.'~'.$identifier.'~'.$resource_name} = {description => $description}; } if (scalar(keys %{$self->{result}}) <= 0) { - if (defined($self->{option_results}->{name})) { - $self->{output}->output_add(long_msg => "No error found with these options."); + if (defined($self->{option_results}->{retention})) { + $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 { + $self->{output}->output_add(long_msg => "No error found with these options."); $self->{output}->output_add(short_msg => "No error found."); } $self->{output}->display(); @@ -135,17 +148,27 @@ sub run { $self->manage_selection(); $self->{output}->output_add(severity => 'OK', short_msg => 'No error found.'); - - foreach my $identifier (sort(keys %{$self->{result}})) { - my $timestamp = $self->{result}->{$identifier}->{timestamp}; - my $resource_name = $self->{result}->{$identifier}->{resource_name}; + + foreach my $errpt_error (sort(keys %{$self->{result}})) { + my @split_error = split ('~',$errpt_error); + 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; - - $self->{output}->output_add(long_msg => sprintf("Error '%s' Date: %s ResourceName: %s", $identifier, - $timestamp, $resource_name)); - $self->{output}->output_add(severity => 'critical', - short_msg => sprintf("Error '%s' Date: %s ResourceName: %s", $identifier, - $timestamp, $resource_name)); + 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, + $timestamp, $resource_name)); + $self->{output}->output_add(severity => 'critical', + short_msg => sprintf("Error '%s' Date: %s ResourceName: %s", $identifier, + $timestamp, $resource_name)); + } } $self->{output}->display(); @@ -209,7 +232,11 @@ Filter error class ('H' for hardware, 'S' for software, '0' for errlogger, 'U' f =item B<--retention> -Retention time of errors in seconds +Retention time of errors in seconds. + +=item B<--retention> + +Print error description in output. =back