This commit is contained in:
garnier-quentin 2019-06-06 15:17:29 +02:00
parent fb813c45ba
commit e5176fd40e
10 changed files with 227 additions and 282 deletions

View File

@ -30,10 +30,6 @@ sub new {
my ($class, %options) = @_; my ($class, %options) = @_;
my $self = {}; my $self = {};
bless $self, $class; bless $self, $class;
# $options{options} = options object
# $options{output} = output object
# $options{exit_value} = integer
# $options{noptions} = integer
if (!defined($options{output})) { if (!defined($options{output})) {
print "Class Custom: Need to specify 'output' argument.\n"; print "Class Custom: Need to specify 'output' argument.\n";
@ -46,13 +42,13 @@ sub new {
if (!defined($options{noptions})) { if (!defined($options{noptions})) {
$options{options}->add_options(arguments => { $options{options}->add_options(arguments => {
"hostname:s@" => { name => 'hostname' }, 'hostname:s@' => { name => 'hostname' },
"port:s@" => { name => 'port' }, 'port:s@' => { name => 'port' },
"proto:s@" => { name => 'proto' }, 'proto:s@' => { name => 'proto' },
"urlpath:s@" => { name => 'url_path' }, 'urlpath:s@' => { name => 'url_path' },
"username:s@" => { name => 'username' }, 'username:s@' => { name => 'username' },
"password:s@" => { name => 'password' }, 'password:s@' => { name => 'password' },
"timeout:s@" => { name => 'timeout' }, 'timeout:s@' => { name => 'timeout' },
}); });
} }
$options{options}->add_help(package => __PACKAGE__, sections => 'P2000 OPTIONS', once => 1); $options{options}->add_help(package => __PACKAGE__, sections => 'P2000 OPTIONS', once => 1);
@ -68,20 +64,15 @@ sub new {
return $self; return $self;
} }
# Method to manage multiples
sub set_options { sub set_options {
my ($self, %options) = @_; my ($self, %options) = @_;
# options{options_result}
$self->{option_results} = $options{option_results}; $self->{option_results} = $options{option_results};
} }
# Method to manage multiples
sub set_defaults { sub set_defaults {
my ($self, %options) = @_; my ($self, %options) = @_;
# options{default}
# Manage default value
foreach (keys %{$options{default}}) { foreach (keys %{$options{default}}) {
if ($_ eq $self->{mode}) { if ($_ eq $self->{mode}) {
for (my $i = 0; $i < scalar(@{$options{default}->{$_}}); $i++) { for (my $i = 0; $i < scalar(@{$options{default}->{$_}}); $i++) {
@ -97,8 +88,6 @@ sub set_defaults {
sub check_options { sub check_options {
my ($self, %options) = @_; my ($self, %options) = @_;
# return 1 = ok still hostname
# return 0 = no hostname left
$self->{hostname} = (defined($self->{option_results}->{hostname})) ? shift(@{$self->{option_results}->{hostname}}) : undef; $self->{hostname} = (defined($self->{option_results}->{hostname})) ? shift(@{$self->{option_results}->{hostname}}) : undef;
$self->{username} = (defined($self->{option_results}->{username})) ? shift(@{$self->{option_results}->{username}}) : undef; $self->{username} = (defined($self->{option_results}->{username})) ? shift(@{$self->{option_results}->{username}}) : undef;
@ -109,7 +98,7 @@ sub check_options {
$self->{url_path} = (defined($self->{option_results}->{url_path})) ? shift(@{$self->{option_results}->{url_path}}) : '/api/'; $self->{url_path} = (defined($self->{option_results}->{url_path})) ? shift(@{$self->{option_results}->{url_path}}) : '/api/';
if (!defined($self->{hostname})) { if (!defined($self->{hostname})) {
$self->{output}->add_option_msg(short_msg => "Need to specify hostname option."); $self->{output}->add_option_msg(short_msg => 'Need to specify hostname option.');
$self->{output}->option_exit(); $self->{output}->option_exit();
} }
if (!defined($self->{username}) || !defined($self->{password})) { if (!defined($self->{username}) || !defined($self->{password})) {
@ -216,7 +205,8 @@ sub get_infos {
if ($return_code != 0) { if ($return_code != 0) {
$nodestatus = $xpath->find("//OBJECT[\@basetype='status']//PROPERTY[\@name='response']"); $nodestatus = $xpath->find("//OBJECT[\@basetype='status']//PROPERTY[\@name='response']");
@nodes = $nodestatus->get_nodelist(); @nodes = $nodestatus->get_nodelist();
$node = shift @nodes; $node = shift @nodes;
return ({}, 0, $node->string_value) if (defined($options{no_quit}) && $options{no_quit} == 1);
$self->{output}->add_option_msg(short_msg => $node->string_value); $self->{output}->add_option_msg(short_msg => $node->string_value);
$self->{output}->option_exit(); $self->{output}->option_exit();
} }
@ -240,7 +230,7 @@ sub get_infos {
} }
} }
return $results; return ($results, 1);
} }
############## ##############

View File

@ -23,12 +23,6 @@ package storage::hp::p2000::xmlapi::mode::components::disk;
use strict; use strict;
use warnings; use warnings;
my @conditions = (
['^degraded$' => 'WARNING'],
['^failed$' => 'CRITICAL'],
['^(unknown|not available)$' => 'UNKNOWN'],
);
my %health = ( my %health = (
0 => 'ok', 0 => 'ok',
1 => 'degraded', 1 => 'degraded',
@ -41,32 +35,32 @@ sub check {
my ($self) = @_; my ($self) = @_;
$self->{output}->output_add(long_msg => "Checking disks"); $self->{output}->output_add(long_msg => "Checking disks");
$self->{components}->{disk} = {name => 'disks', total => 0, skip => 0}; $self->{components}->{disk} = { name => 'disks', total => 0, skip => 0 };
return if ($self->check_exclude(section => 'disk')); return if ($self->check_filter(section => 'disk'));
my $results = $self->{p2000}->get_infos(cmd => 'show disks',
base_type => 'drives',
key => 'durable-id',
properties_name => '^health-numeric$');
my ($results) = $self->{custom}->get_infos(
cmd => 'show disks',
base_type => 'drives',
key => 'durable-id',
properties_name => '^health-numeric$',
no_quit => 1
);
foreach my $disk_id (keys %$results) { foreach my $disk_id (keys %$results) {
next if ($self->check_exclude(section => 'disk', instance => $disk_id)); next if ($self->check_filter(section => 'disk', instance => $disk_id));
$self->{components}->{disk}->{total}++; $self->{components}->{disk}->{total}++;
my $state = $health{$results->{$disk_id}->{'health-numeric'}}; my $state = $health{$results->{$disk_id}->{'health-numeric'}};
$self->{output}->output_add(long_msg => sprintf("Disk '%s' status is %s.", $self->{output}->output_add(long_msg => sprintf("disk '%s' status is %s [instance: %s]",
$disk_id, $state) $disk_id, $state, $disk_id)
); );
foreach (@conditions) { my $exit = $self->get_severity(label => 'default', section => 'disk', value => $state);
if ($state =~ /$$_[0]/i) { if (!$self->{output}->is_status(value => $exit, compare => 'ok', litteral => 1)) {
$self->{output}->output_add(severity => $$_[1], $self->{output}->output_add(severity => $exit,
short_msg => sprintf("Disk '%s' status is %s", short_msg => sprintf("Disk '%s' status is '%s'", $disk_id, $state));
$disk_id, $state));
last;
}
} }
} }
} }
1; 1;

View File

@ -23,12 +23,6 @@ package storage::hp::p2000::xmlapi::mode::components::enclosure;
use strict; use strict;
use warnings; use warnings;
my @conditions = (
['^degraded$' => 'WARNING'],
['^failed$' => 'CRITICAL'],
['^(unknown|not available)$' => 'UNKNOWN'],
);
my %health = ( my %health = (
0 => 'ok', 0 => 'ok',
1 => 'degraded', 1 => 'degraded',
@ -42,30 +36,30 @@ sub check {
$self->{output}->output_add(long_msg => "Checking enclosures"); $self->{output}->output_add(long_msg => "Checking enclosures");
$self->{components}->{enclosure} = {name => 'enclosures', total => 0, skip => 0}; $self->{components}->{enclosure} = {name => 'enclosures', total => 0, skip => 0};
return if ($self->check_exclude(section => 'enclosure')); return if ($self->check_filter(section => 'enclosure'));
my $results = $self->{p2000}->get_infos(cmd => 'show enclosures', my ($results) = $self->{custom}->get_infos(
base_type => 'enclosures', cmd => 'show enclosures',
key => 'durable-id', base_type => 'enclosures',
properties_name => '^health-numeric|health-reason$'); key => 'durable-id',
properties_name => '^health-numeric|health-reason$',
no_quit => 1
);
foreach my $enc_id (keys %$results) { foreach my $enc_id (keys %$results) {
next if ($self->check_exclude(section => 'enclosure', instance => $enc_id)); next if ($self->check_filter(section => 'enclosure', instance => $enc_id));
$self->{components}->{enclosure}->{total}++; $self->{components}->{enclosure}->{total}++;
my $state = $health{$results->{$enc_id}->{'health-numeric'}}; my $state = $health{$results->{$enc_id}->{'health-numeric'}};
$self->{output}->output_add(long_msg => sprintf("enclosure '%s' status is %s.", $self->{output}->output_add(long_msg => sprintf("enclosure '%s' status is %s [instance: %s] [reason: %s]",
$enc_id, $state) $enc_id, $state, $enc_id, $health{$results->{$enc_id}->{'health-reason'}})
); );
foreach (@conditions) { my $exit = $self->get_severity(label => 'default', section => 'enclosure', value => $state);
if ($state =~ /$$_[0]/i) { if (!$self->{output}->is_status(value => $exit, compare => 'ok', litteral => 1)) {
$self->{output}->output_add(severity => $$_[1], $self->{output}->output_add(severity => $exit,
short_msg => sprintf("enclosure '%s' status is %s (reason: %s)", short_msg => sprintf("Enclosure '%s' status is '%s'", $enc_id, $state));
$enc_id, $state, $health{$results->{$enc_id}->{'health-reason'}}));
last;
}
} }
} }
} }
1; 1;

View File

@ -23,43 +23,37 @@ package storage::hp::p2000::xmlapi::mode::components::fru;
use strict; use strict;
use warnings; use warnings;
my @conditions = (
['^absent$' => 'WARNING'],
['^fault$' => 'CRITICAL'],
['^not available$' => 'UNKNOWN'],
);
sub check { sub check {
my ($self) = @_; my ($self) = @_;
$self->{output}->output_add(long_msg => "Checking frus"); $self->{output}->output_add(long_msg => "Checking frus");
$self->{components}->{fru} = {name => 'frus', total => 0, skip => 0}; $self->{components}->{fru} = {name => 'frus', total => 0, skip => 0};
return if ($self->check_exclude(section => 'fru')); return if ($self->check_filter(section => 'fru'));
my $results = $self->{p2000}->get_infos(cmd => 'show frus', my ($results) = $self->{custom}->get_infos(
base_type => 'enclosure-fru', cmd => 'show frus',
key => 'part-number', base_type => 'enclosure-fru',
properties_name => '^(fru-status|fru-location)$'); key => 'part-number',
properties_name => '^(fru-status|fru-location)$',
no_quit => 1,
);
foreach my $part_number (keys %$results) { foreach my $part_number (keys %$results) {
my $instance = $results->{$part_number}->{'fru-location'}; my $instance = $results->{$part_number}->{'fru-location'};
next if ($self->check_exclude(section => 'fru', instance => $instance)); next if ($self->check_filter(section => 'fru', instance => $instance));
$self->{components}->{fru}->{total}++; $self->{components}->{fru}->{total}++;
my $state = $results->{$part_number}->{'fru-status'}; my $state = $results->{$part_number}->{'fru-status'};
$self->{output}->output_add(long_msg => sprintf("fru '%s' status is %s.", $self->{output}->output_add(long_msg => sprintf("fru '%s' status is %s [instance: %s]",
$instance, $state) $instance, $state, $instance)
); );
foreach (@conditions) { my $exit = $self->get_severity(section => 'fru', value => $state);
if ($state =~ /$$_[0]/i) { if (!$self->{output}->is_status(value => $exit, compare => 'ok', litteral => 1)) {
$self->{output}->output_add(severity => $$_[1], $self->{output}->output_add(severity => $exit,
short_msg => sprintf("fru '%s' status is %s", short_msg => sprintf("Fru '%s' status is '%s'", $instance, $state));
$instance, $state));
last;
}
} }
} }
} }
1; 1;

View File

@ -18,36 +18,38 @@
# limitations under the License. # limitations under the License.
# #
package storage::hp::p2000::xmlapi::mode::components::sensors; package storage::hp::p2000::xmlapi::mode::components::sensor;
use strict; use strict;
use warnings; use warnings;
my @conditions = (
['^warning|not installed|unavailable$' => 'WARNING'],
['^error|unrecoverable$' => 'CRITICAL'],
['^unknown|unsupported$' => 'UNKNOWN'],
);
my %sensor_type = ( my %sensor_type = (
# 2 it's other. Can be ok or '%'. Need to regexp # 2 it's other. Can be ok or '%'. Need to regexp
3 => { unit => 'C' }, 3 => { unit => 'C', nunit => 'celsius', type => 'temperature' },
6 => { unit => 'V' }, 6 => { unit => 'V', nunit => 'volt', type => 'voltage' },
9 => { unit => 'V' }, 9 => { unit => 'V', nunit => 'volt', type => 'voltage' },
);
my %units = (
C => { long => 'celsius', type => 'temperature' },
V => { long => 'volt', type => 'voltage' },
'' => { long => undef, type => 'misc' },
'%' => { long => 'percentage', type => 'misc' },
); );
sub check { sub check {
my ($self) = @_; my ($self) = @_;
$self->{output}->output_add(long_msg => "Checking sensors"); $self->{output}->output_add(long_msg => "Checking sensor");
$self->{components}->{sensor} = {name => 'sensors', total => 0, skip => 0}; $self->{components}->{sensor} = {name => 'sensor', total => 0, skip => 0};
return if ($self->check_exclude(section => 'sensor')); return if ($self->check_filter(section => 'sensor'));
# We don't use status-numeric. Values are buggy !!!??? # We don't use status-numeric. Values are buggy !!!???
my $results = $self->{p2000}->get_infos(cmd => 'show sensor-status', my ($results) = $self->{custom}->get_infos(
base_type => 'sensors', cmd => 'show sensor-status',
key => 'sensor-name', base_type => 'sensors',
properties_name => '^(value|sensor-type|status)$'); key => 'sensor-name',
properties_name => '^(value|sensor-type|status)$'
);
#<OBJECT basetype="sensors" name="sensor" oid="22" format="rows"> #<OBJECT basetype="sensors" name="sensor" oid="22" format="rows">
# <PROPERTY name="sensor-name" key="true" type="string" size="33" draw="true" sort="string" display-name="Sensor Name">Capacitor Charge-Ctlr B</PROPERTY> # <PROPERTY name="sensor-name" key="true" type="string" size="33" draw="true" sort="string" display-name="Sensor Name">Capacitor Charge-Ctlr B</PROPERTY>
@ -60,35 +62,43 @@ sub check {
# <PROPERTY name="status" type="string" size="8" draw="true" sort="string" display-name="Status">Warning</PROPERTY> # <PROPERTY name="status" type="string" size="8" draw="true" sort="string" display-name="Status">Warning</PROPERTY>
#</OBJECT> #</OBJECT>
foreach my $sensor_id (keys %$results) { foreach my $sensor_id (keys %$results) {
next if ($self->check_exclude(section => 'sensor', instance => $sensor_id));
$self->{components}->{sensor}->{total}++;
my $state = $results->{$sensor_id}->{status};
my ($value, $unit); my ($value, $unit);
($value, $unit) = ($1, $2) if ($results->{$sensor_id}->{value} =~ /\s*([0-9\.,]+)\s*(\S*)\s*/); ($value, $unit) = ($1, $2) if ($results->{$sensor_id}->{value} =~ /\s*([0-9\.,]+)\s*(\S*)\s*/);
if (defined($results->{$sensor_id}->{'sensor-type'}) && defined($sensor_type{$results->{$sensor_id}->{'sensor-type'}})) { if (defined($results->{$sensor_id}->{'sensor-type'}) && defined($sensor_type{$results->{$sensor_id}->{'sensor-type'}})) {
$unit = $sensor_type{$results->{$sensor_id}->{'sensor-type'}}->{unit}; $unit = $sensor_type{$results->{$sensor_id}->{'sensor-type'}}->{unit};
} }
my $type = $units{$unit}->{type};
next if ($self->check_filter(section => 'sensor', instance => $type . '.' . $sensor_id));
$self->{components}->{sensor}->{total}++;
$self->{output}->output_add(long_msg => sprintf("sensor '%s' status is %s (value: %s %s).", my $state = $results->{$sensor_id}->{status};
$self->{output}->output_add(long_msg => sprintf("sensor '%s' status is %s (value: %s %s)",
$sensor_id, $state, defined($value) ? $value : '-', defined($unit) ? $unit : '-') $sensor_id, $state, defined($value) ? $value : '-', defined($unit) ? $unit : '-')
); );
foreach (@conditions) { my $exit = $self->get_severity(section => 'sensor', value => $state);
if ($state =~ /$$_[0]/i) { if (!$self->{output}->is_status(value => $exit, compare => 'ok', litteral => 1)) {
$self->{output}->output_add(severity => $$_[1], $self->{output}->output_add(severity => $exit,
short_msg => sprintf("sensor '%s' status is %s", short_msg => sprintf("sensor '%s' status is '%s'", $sensor_id, $state));
$sensor_id, $state));
last;
}
} }
if (defined($value)) { next if (!defined($value));
$self->{output}->perfdata_add(
label => $sensor_id, unit => $unit, my ($exit2, $warn, $crit, $checked) = $self->get_severity_numeric(section => 'sensor', instance => $type . '.' . $sensor_id, value => $value);
value => $value if (!$self->{output}->is_status(value => $exit2, compare => 'ok', litteral => 1)) {
); $self->{output}->output_add(severity => $exit,
short_msg => sprintf("Sensor '%s' is %s %s", $sensor_id, $value, defined($unit) ? $unit : '-'));
} }
$self->{output}->perfdata_add(
label => 'sensor', unit => $unit,
nlabel => 'hardware.sensor.' . $type . (defined($units{$unit}->{long}) ? $units{$unit}->{long} : ''),
instances => $sensor_id,
value => $value,
warning => $warn,
critical => $crit,
);
} }
} }

View File

@ -23,12 +23,6 @@ package storage::hp::p2000::xmlapi::mode::components::vdisk;
use strict; use strict;
use warnings; use warnings;
my @conditions = (
['^degraded$' => 'WARNING'],
['^failed$' => 'CRITICAL'],
['^(unknown|not available)$' => 'UNKNOWN'],
);
my %health = ( my %health = (
0 => 'ok', 0 => 'ok',
1 => 'degraded', 1 => 'degraded',
@ -37,36 +31,51 @@ my %health = (
4 => 'not available', 4 => 'not available',
); );
sub check { sub check_vdisk {
my ($self) = @_; my ($self, %options) = @_;
$self->{output}->output_add(long_msg => "Checking vdisks"); foreach my $vdisk_id (keys %{$options{results}}) {
$self->{components}->{vdisk} = {name => 'vdisks', total => 0, skip => 0}; next if ($self->check_filter(section => 'vdisk', instance => $vdisk_id));
return if ($self->check_exclude(section => 'vdisk'));
my $results = $self->{p2000}->get_infos(cmd => 'show vdisks',
base_type => 'virtual-disks',
key => 'name',
properties_name => '^health-numeric$');
foreach my $vdisk_id (keys %$results) {
next if ($self->check_exclude(section => 'vdisk', instance => $vdisk_id));
$self->{components}->{vdisk}->{total}++; $self->{components}->{vdisk}->{total}++;
my $state = $health{$results->{$vdisk_id}->{'health-numeric'}}; my $state = $health{$options{results}->{$vdisk_id}->{'health-numeric'}};
$self->{output}->output_add(long_msg => sprintf("vdisk '%s' status is %s.", $self->{output}->output_add(long_msg => sprintf("vdisk '%s' status is %s [instance: %s]",
$vdisk_id, $state) $vdisk_id, $state, $vdisk_id)
); );
foreach (@conditions) { my $exit = $self->get_severity(label => 'default', section => 'vdisk', value => $state);
if ($state =~ /$$_[0]/i) { if (!$self->{output}->is_status(value => $exit, compare => 'ok', litteral => 1)) {
$self->{output}->output_add(severity => $$_[1], $self->{output}->output_add(severity => $exit,
short_msg => sprintf("vdisk '%s' status is %s", short_msg => sprintf("Vdisk '%s' status is '%s'", $vdisk_id, $state));
$vdisk_id, $state));
last;
}
} }
} }
} }
1; sub check {
my ($self) = @_;
$self->{output}->output_add(long_msg => "Checking vdisks");
$self->{components}->{vdisk} = { name => 'vdisks', total => 0, skip => 0 };
return if ($self->check_filter(section => 'vdisk'));
my ($results, $code) = $self->{custom}->get_infos(
cmd => 'show vdisks',
base_type => 'virtual-disks',
key => 'name',
properties_name => '^health-numeric$',
no_quit => 1,
);
if ($code == 0) {
($results) = $self->{custom}->get_infos(
cmd => 'show disk-groups',
base_type => 'disk-groups',
key => 'name',
properties_name => '^health-numeric$',
no_quit => 1,
);
}
check_vdisk($self, results => $results);
}
1;

View File

@ -20,121 +20,63 @@
package storage::hp::p2000::xmlapi::mode::health; package storage::hp::p2000::xmlapi::mode::health;
use base qw(centreon::plugins::mode); use base qw(centreon::plugins::templates::hardware);
use strict; use strict;
use warnings; use warnings;
use storage::hp::p2000::xmlapi::mode::components::disk;
use storage::hp::p2000::xmlapi::mode::components::vdisk; sub set_system {
use storage::hp::p2000::xmlapi::mode::components::sensors; my ($self, %options) = @_;
use storage::hp::p2000::xmlapi::mode::components::fru;
use storage::hp::p2000::xmlapi::mode::components::enclosure; $self->{regexp_threshold_overload_check_section_option} =
'^(disk|enclosure|fru|sensor|vdisk)$';
$self->{regexp_threshold_numeric_check_section_option} =
'^(sensor)$';
$self->{cb_hook1} = 'init_health';
$self->{thresholds} = {
# disk, enclosure, vdisk
default => [
['degraded', 'WARNING'],
['failed', 'CRITICAL'],
['unknown|not available', 'UNKNOWN'],
],
fru => [
['absent', 'WARNING'],
['fault', 'CRITICAL'],
['not available', 'UNKNOWN'],
],
sensor => [
['warning|not installed|unavailable', 'WARNING'],
['error|unrecoverable', 'CRITICAL'],
['nknown|unsupported', 'UNKNOWN'],
],
};
$self->{components_exec_load} = 0;
$self->{components_path} = 'storage::hp::p2000::xmlapi::mode::components';
$self->{components_module} = ['disk', 'enclosure', 'fru', 'sensor', 'vdisk'];
}
sub init_health {
my ($self, %options) = @_;
$self->{custom} = $options{custom};
}
sub new { sub new {
my ($class, %options) = @_; my ($class, %options) = @_;
my $self = $class->SUPER::new(package => __PACKAGE__, %options); my $self = $class->SUPER::new(package => __PACKAGE__, %options, no_absent => 1);
bless $self, $class; bless $self, $class;
$self->{version} = '1.0'; $self->{version} = '1.0';
$options{options}->add_options(arguments => { $options{options}->add_options(arguments => {
"exclude:s" => { name => 'exclude' },
"component:s" => { name => 'component', default => 'all' },
"no-component:s" => { name => 'no_component' },
}); });
$self->{components} = {};
$self->{no_components} = undef;
return $self; return $self;
} }
sub check_options {
my ($self, %options) = @_;
$self->SUPER::init(%options);
if (defined($self->{option_results}->{no_component})) {
if ($self->{option_results}->{no_component} ne '') {
$self->{no_components} = $self->{option_results}->{no_component};
} else {
$self->{no_components} = 'critical';
}
}
}
sub component {
my ($self, %options) = @_;
if ($self->{option_results}->{component} eq 'all') {
storage::hp::p2000::xmlapi::mode::components::disk::check($self);
storage::hp::p2000::xmlapi::mode::components::vdisk::check($self);
storage::hp::p2000::xmlapi::mode::components::sensors::check($self);
storage::hp::p2000::xmlapi::mode::components::fru::check($self);
storage::hp::p2000::xmlapi::mode::components::enclosure::check($self);
} elsif ($self->{option_results}->{component} eq 'disk') {
storage::hp::p2000::xmlapi::mode::components::disk::check($self);
} elsif ($self->{option_results}->{component} eq 'vdisk') {
storage::hp::p2000::xmlapi::mode::components::vdisk::check($self);
} elsif ($self->{option_results}->{component} eq 'sensor') {
storage::hp::p2000::xmlapi::mode::components::sensors::check($self);
} elsif ($self->{option_results}->{component} eq 'fru') {
storage::hp::p2000::xmlapi::mode::components::fru::check($self);
} elsif ($self->{option_results}->{component} eq 'enclosure') {
storage::hp::p2000::xmlapi::mode::components::enclosure::check($self);
} else {
$self->{output}->add_option_msg(short_msg => "Wrong option. Cannot find component '" . $self->{option_results}->{component} . "'.");
$self->{output}->option_exit();
}
my $total_components = 0;
my $display_by_component = '';
my $display_by_component_append = '';
foreach my $comp (sort(keys %{$self->{components}})) {
# Skipping short msg when no components
next if ($self->{components}->{$comp}->{total} == 0 && $self->{components}->{$comp}->{skip} == 0);
$total_components += $self->{components}->{$comp}->{total} + $self->{components}->{$comp}->{skip};
$display_by_component .= $display_by_component_append . $self->{components}->{$comp}->{total} . '/' . $self->{components}->{$comp}->{skip} . ' ' . $self->{components}->{$comp}->{name};
$display_by_component_append = ', ';
}
$self->{output}->output_add(severity => 'OK',
short_msg => sprintf("All %s components [%s] are ok.",
$total_components,
$display_by_component)
);
if (defined($self->{option_results}->{no_component}) && $total_components == 0) {
$self->{output}->output_add(severity => $self->{no_components},
short_msg => 'No components are checked.');
}
}
sub run {
my ($self, %options) = @_;
$self->{p2000} = $options{custom};
$self->{p2000}->login();
$self->component();
$self->{output}->display();
$self->{output}->exit();
}
sub check_exclude {
my ($self, %options) = @_;
if (defined($options{instance})) {
if (defined($self->{option_results}->{exclude}) && $self->{option_results}->{exclude} =~ /(^|\s|,)${options{section}}[^,]*#\Q$options{instance}\E#/) {
$self->{components}->{$options{section}}->{skip}++;
$self->{output}->output_add(long_msg => sprintf("Skipping $options{section} section $options{instance} instance."));
return 1;
}
} elsif (defined($self->{option_results}->{exclude}) && $self->{option_results}->{exclude} =~ /(^|\s|,)$options{section}(\s|,|$)/) {
$self->{output}->output_add(long_msg => sprintf("Skipping $options{section} section."));
return 1;
}
return 0;
}
1; 1;
__END__ __END__
@ -147,19 +89,35 @@ Check health status of storage.
=item B<--component> =item B<--component>
Which component to check (Default: 'all'). Which component to check (Default: '.*').
Can be: 'disk', 'vdisk', 'sensor', 'enclosure', 'fru'. Can be: 'disk', 'enclosure', 'fru', 'sensor', 'vdisk'.
=item B<--exclude> =item B<--filter>
Exclude some parts (comma seperated list) (Example: --exclude=fru) Exclude some parts (comma seperated list) (Example: --filter=fru --filter=enclosure)
Can also exclude specific instance: --exclude=disk#disk_1.4#,sensor#Temperature Loc: lower-IOM B# Can also exclude specific instance: --filter=disk,1
=item B<--no-component> =item B<--no-component>
Return an error if no compenents are checked. Return an error if no compenents are checked.
If total (with skipped) is 0. (Default: 'critical' returns). If total (with skipped) is 0. (Default: 'critical' returns).
=item B<--threshold-overload>
Set to overload default threshold values (syntax: section,[instance,]status,regexp)
It used before default thresholds (order stays).
Example: --threshold-overload='disk,OK,unknown'
=item B<--warning>
Set warning threshold for 'sensor' (syntax: type,instance,threshold)
Example: --warning='sensor,temperature.*,30'
=item B<--critical>
Set warning threshold for 'sensors' (syntax: type,instance,threshold)
Example: --warning='sensor,temperature.*,30'
=back =back
=cut =cut

View File

@ -32,9 +32,9 @@ sub new {
$self->{version} = '1.0'; $self->{version} = '1.0';
$options{options}->add_options(arguments => { $options{options}->add_options(arguments => {
"name:s" => { name => 'name' }, 'name:s' => { name => 'name' },
"regexp" => { name => 'use_regexp' }, 'regexp" => { name => 'use_regexp' },
"filter-type:s" => { name => 'filter_type' }, 'filter-type:s' => { name => 'filter_type' },
}); });
$self->{volume_name_selected} = []; $self->{volume_name_selected} = [];
@ -50,10 +50,12 @@ sub check_options {
sub manage_selection { sub manage_selection {
my ($self, %options) = @_; my ($self, %options) = @_;
$self->{results} = $self->{p2000}->get_infos(cmd => 'show volumes', ($self->{results}) = $self->{p2000}->get_infos(
base_type => 'volumes', cmd => 'show volumes',
key => 'volume-name', base_type => 'volumes',
properties_name => '^volume-type$'); key => 'volume-name',
properties_name => '^volume-type$'
);
foreach my $name (keys %{$self->{results}}) { foreach my $name (keys %{$self->{results}}) {
my $volume_type = $self->{results}->{$name}->{'volume-type'}; my $volume_type = $self->{results}->{$name}->{'volume-type'};

View File

@ -127,8 +127,8 @@ sub new {
$self->{version} = '1.0'; $self->{version} = '1.0';
$options{options}->add_options(arguments => { $options{options}->add_options(arguments => {
"name:s" => { name => 'name' }, 'name:s' => { name => 'name' },
"regexp" => { name => 'use_regexp' }, 'regexp' => { name => 'use_regexp' },
}); });
return $self; return $self;
@ -143,7 +143,7 @@ sub prefix_volume_output {
sub manage_selection { sub manage_selection {
my ($self, %options) = @_; my ($self, %options) = @_;
my $result = $options{custom}->get_infos( my ($result) = $options{custom}->get_infos(
cmd => 'show volume-statistics', cmd => 'show volume-statistics',
base_type => 'volume-statistics', base_type => 'volume-statistics',
key => 'volume-name', key => 'volume-name',
@ -165,11 +165,11 @@ sub manage_selection {
} }
if (scalar(keys %{$self->{volume}}) <= 0) { if (scalar(keys %{$self->{volume}}) <= 0) {
$self->{output}->add_option_msg(short_msg => "No volume found."); $self->{output}->add_option_msg(short_msg => 'No volume found.');
$self->{output}->option_exit(); $self->{output}->option_exit();
} }
$self->{cache_name} = "hp_p2000_" . $options{custom}->{hostname} . '_' . $self->{mode} . '_' . $self->{cache_name} = 'hp_p2000_' . $options{custom}->{hostname} . '_' . $self->{mode} . '_' .
(defined($self->{option_results}->{filter_counters}) ? md5_hex($self->{option_results}->{filter_counters}) : md5_hex('all')) . '_' . (defined($self->{option_results}->{filter_counters}) ? md5_hex($self->{option_results}->{filter_counters}) : md5_hex('all')) . '_' .
(defined($self->{option_results}->{filter_name}) ? md5_hex($self->{option_results}->{filter_name}) : md5_hex('all')); (defined($self->{option_results}->{filter_name}) ? md5_hex($self->{option_results}->{filter_name}) : md5_hex('all'));
} }

View File

@ -32,21 +32,15 @@ sub new {
$self->{version} = '0.1'; $self->{version} = '0.1';
%{$self->{modes}} = ( %{$self->{modes}} = (
'health' => 'storage::hp::p2000::xmlapi::mode::health', 'health' => 'storage::hp::p2000::xmlapi::mode::health',
'list-volumes' => 'storage::hp::p2000::xmlapi::mode::listvolumes', 'list-volumes' => 'storage::hp::p2000::xmlapi::mode::listvolumes',
'volume-stats' => 'storage::hp::p2000::xmlapi::mode::volumesstats', 'volume-stats' => 'storage::hp::p2000::xmlapi::mode::volumesstats',
); );
$self->{custom_modes}{p2000xml} = 'storage::hp::p2000::xmlapi::custom'; $self->{custom_modes}{p2000xml} = 'storage::hp::p2000::xmlapi::custom';
return $self; return $self;
} }
sub init {
my ($self, %options) = @_;
$self->SUPER::init(%options);
}
1; 1;
__END__ __END__