Fix indentation and some helps
This commit is contained in:
garnier-quentin 2014-04-25 23:51:09 +02:00
parent 930c83cfaf
commit 43316f9dee
3 changed files with 36 additions and 84 deletions

View File

@ -58,10 +58,9 @@ 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' },
}); });
$self->{result} = {}; $self->{result} = {};
return $self; return $self;
@ -74,33 +73,33 @@ sub check_options {
sub manage_selection { sub manage_selection {
my ($self, %options) = @_; my ($self, %options) = @_;
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 = $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 = $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};
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){
$sec = '0'.$sec; $sec = '0'.$sec;
} }
if (length($min)==1){ if (length($min)==1){
$min = '0'.$min; $min = '0'.$min;
} }
if (length($hour)==1){ if (length($hour)==1){
$hour = '0'.$hour; $hour = '0'.$hour;
} }
$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 = $extra_options.' -s '.$retention;
} }
my $stdout = centreon::plugins::misc::execute(output => $self->{output}, my $stdout = centreon::plugins::misc::execute(output => $self->{output},
@ -108,14 +107,14 @@ sub manage_selection {
sudo => $self->{option_results}->{sudo}, sudo => $self->{option_results}->{sudo},
command => $self->{option_results}->{command}, command => $self->{option_results}->{command},
command_path => $self->{option_results}->{command_path}, command_path => $self->{option_results}->{command_path},
command_options => $extra_options.' '.$self->{option_results}->{command_options}); command_options => $extra_options);
my @lines = split /\n/, $stdout; my @lines = split /\n/, $stdout;
# Header not needed # Header not needed
shift @lines; shift @lines;
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) = ($1, $2, $5);
$self->{result}->{$identifier} = {timestamp => $timestamp, resource_name => $resource_name}; $self->{result}->{$identifier} = {timestamp => $timestamp, resource_name => $resource_name};
} }
@ -126,13 +125,13 @@ sub manage_selection {
$self->{output}->output_add(short_msg => "No error found."); $self->{output}->output_add(short_msg => "No error found.");
} }
$self->{output}->display(); $self->{output}->display();
$self->{output}->exit(); $self->{output}->exit();
} }
} }
sub run { sub run {
my ($self, %options) = @_; my ($self, %options) = @_;
$self->manage_selection(); $self->manage_selection();
$self->{output}->output_add(severity => 'OK', $self->{output}->output_add(severity => 'OK',
short_msg => 'No error found.'); short_msg => 'No error found.');
@ -141,9 +140,9 @@ sub run {
my $timestamp = $self->{result}->{$identifier}->{timestamp}; my $timestamp = $self->{result}->{$identifier}->{timestamp};
my $resource_name = $self->{result}->{$identifier}->{resource_name}; my $resource_name = $self->{result}->{$identifier}->{resource_name};
my $exit; my $exit;
$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));
@ -193,45 +192,13 @@ Use 'sudo' to execute the command.
=item B<--command> =item B<--command>
Command to get information (Default: 'df'). Command to get information (Default: 'errpt').
Can be changed if you have output in a file. Can be changed if you have output in a file.
=item B<--command-path> =item B<--command-path>
Command path (Default: none). Command path (Default: none).
=item B<--command-options>
Command options (Default: '-P -k -T 2>&1').
=item B<--warning>
Threshold warning.
=item B<--critical>
Threshold critical.
=item B<--units>
Units of thresholds (Default: '%') ('%', 'B').
=item B<--free>
Thresholds are on free space left.
=item B<--name>
Set the storage mount point (empty means 'check all storages')
=item B<--regexp>
Allows to use regexp to filter storage mount point (with option --name).
=item B<--regexp-isensitive>
Allows to use regexp non case-sensitive (with --regexp).
=item B<--error-type> =item B<--error-type>
Filter error type separated by a coma (INFO, PEND, PERF, PERM, TEMP, UNKN). Filter error type separated by a coma (INFO, PEND, PERF, PERM, TEMP, UNKN).

View File

@ -116,7 +116,7 @@ sub manage_selection {
sub run { sub run {
my ($self, %options) = @_; my ($self, %options) = @_;
$self->manage_selection(); $self->manage_selection();
if (!defined($self->{option_results}->{name}) || defined($self->{option_results}->{use_regexp})) { if (!defined($self->{option_results}->{name}) || defined($self->{option_results}->{use_regexp})) {
$self->{output}->output_add(severity => 'OK', $self->{output}->output_add(severity => 'OK',
@ -130,13 +130,13 @@ sub run {
my $type = $self->{result}->{$name}->{type}; my $type = $self->{result}->{$name}->{type};
my $lp = $self->{result}->{$name}->{lp}; my $lp = $self->{result}->{$name}->{lp};
my $pp = $self->{result}->{$name}->{pp}; my $pp = $self->{result}->{$name}->{pp};
my $pv = $self->{result}->{$name}->{pv}; my $pv = $self->{result}->{$name}->{pv};
my $lvstate = $self->{result}->{$name}->{lvstate}; my $lvstate = $self->{result}->{$name}->{lvstate};
my $mount = $name; my $mount = $name;
$self->{output}->output_add(long_msg => sprintf("LV '%s' MountPoint: '%s' State: '%s' [LP: %s PP: %s PV: %s]", $lv, $self->{output}->output_add(long_msg => sprintf("LV '%s' MountPoint: '%s' State: '%s' [LP: %s PP: %s PV: %s]", $lv,
$mount, $lvstate, $mount, $lvstate,
$lp, $pp, $pv)); $lp, $pp, $pv));
$self->{output}->output_add(severity => 'critical', $self->{output}->output_add(severity => 'critical',
short_msg => sprintf("LV '%s' MountPoint: '%s' State: '%s' [LP: %s PP: %s PV: %s]", $lv, short_msg => sprintf("LV '%s' MountPoint: '%s' State: '%s' [LP: %s PP: %s PV: %s]", $lv,
$mount, $lvstate, $mount, $lvstate,

View File

@ -47,25 +47,10 @@ sub new {
$self->{version} = '0.1'; $self->{version} = '0.1';
%{$self->{modes}} = ( %{$self->{modes}} = (
'cpu' => 'os::aix::local::mode::cpu', 'errpt' => 'os::aix::local::mode::errpt',
'cmd-return' => 'os::aix::local::mode::cmdreturn',
'diskio' => 'os::aix::local::mode::diskio',
'files-size' => 'os::aix::local::mode::filessize',
'files-date' => 'os::aix::local::mode::filesdate',
'inodes' => 'os::aix::local::mode::inodes',
'load' => 'os::aix::local::mode::loadaverage',
'list-interfaces' => 'os::aix::local::mode::listinterfaces',
'list-partitions' => 'os::aix::local::mode::listpartitions',
'list-storages' => 'os::aix::local::mode::liststorages', 'list-storages' => 'os::aix::local::mode::liststorages',
'memory' => 'os::aix::local::mode::memory',
'packet-errors' => 'os::aix::local::mode::packeterrors',
'process' => 'os::aix::local::mode::process',
'storage' => 'os::aix::local::mode::storage', 'storage' => 'os::aix::local::mode::storage',
'swap' => 'os::aix::local::mode::swap', 'mirrorvg' => 'os::aix::local::mode::mirrorvg',
'traffic' => 'os::aix::local::mode::traffic',
'uptime' => 'os::aix::local::mode::uptime',
'mirrorvg' => 'os::aix::local::mode::mirrorvg',
'errpt' => 'os::aix::local::mode::errpt',
); );
return $self; return $self;
@ -77,6 +62,6 @@ __END__
=head1 PLUGIN DESCRIPTION =head1 PLUGIN DESCRIPTION
Check Linux through local commands (the plugin can use SSH). Check AIX through local commands (the plugin can use SSH).
=cut =cut