mirror of
https://github.com/centreon/centreon-plugins.git
synced 2025-07-28 08:04:36 +02:00
(plugin) storage::emc::xtremio::restapi - ssdendurance inverse thresholds (#3555)
This commit is contained in:
parent
251dc85bbc
commit
4e3e29ae6c
@ -66,34 +66,54 @@ sub run {
|
|||||||
my $xtremio = $options{custom};
|
my $xtremio = $options{custom};
|
||||||
|
|
||||||
my $urlbase = '/api/json/types/';
|
my $urlbase = '/api/json/types/';
|
||||||
my @items = $xtremio->get_items(url => $urlbase,
|
my @items = $xtremio->get_items(
|
||||||
obj => 'ssds');
|
url => $urlbase,
|
||||||
|
obj => 'ssds'
|
||||||
|
);
|
||||||
|
|
||||||
$self->{output}->output_add(severity => 'OK',
|
$self->{output}->output_add(
|
||||||
short_msg => 'All SSDs Endurance are OK');
|
severity => 'OK',
|
||||||
|
short_msg => 'All SSDs Endurance are OK'
|
||||||
|
);
|
||||||
|
|
||||||
foreach my $item (@items) {
|
foreach my $item (@items) {
|
||||||
next if ($self->check_filter(section => 'ssds', instance => $item));
|
next if ($self->check_filter(section => 'ssds', instance => $item));
|
||||||
my $details = $xtremio->get_details(url => $urlbase,
|
my $details = $xtremio->get_details(
|
||||||
obj => 'ssds',
|
url => $urlbase,
|
||||||
name => $item);
|
obj => 'ssds',
|
||||||
|
name => $item
|
||||||
|
);
|
||||||
|
|
||||||
$self->{output}->output_add(long_msg => sprintf("SSD '%s' endurance remaining is %i%%",
|
$self->{output}->output_add(
|
||||||
$item, $details->{'percent-endurance-remaining'}));
|
long_msg => sprintf(
|
||||||
|
"SSD '%s' endurance remaining is %i%%",
|
||||||
|
$item, $details->{'percent-endurance-remaining'}
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
my $exit = $self->{perfdata}->threshold_check(
|
||||||
my $exit = $self->{perfdata}->threshold_check(value => $details->{'percent-endurance-remaining'},
|
value => $details->{'percent-endurance-remaining'},
|
||||||
threshold => [ { label => 'warning', exit_litteral => 'warning' }, { label => 'critical', exit_litteral => 'critical' } ]);
|
threshold => [
|
||||||
|
{ label => 'critical', exit_litteral => 'critical' },
|
||||||
|
{ label => 'warning', exit_litteral => 'warning' }
|
||||||
|
]
|
||||||
|
);
|
||||||
if (!$self->{output}->is_status(value => $exit, compare => 'ok', litteral => 1)) {
|
if (!$self->{output}->is_status(value => $exit, compare => 'ok', litteral => 1)) {
|
||||||
$self->{output}->output_add(severity => $exit,
|
$self->{output}->output_add(
|
||||||
short_msg => sprintf("SSD '%s' endurance is %i%%",
|
severity => $exit,
|
||||||
$item, $details->{'percent-endurance-remaining'}));
|
short_msg => sprintf(
|
||||||
|
"SSD '%s' endurance is %i%%",
|
||||||
|
$item, $details->{'percent-endurance-remaining'}
|
||||||
|
)
|
||||||
|
);
|
||||||
}
|
}
|
||||||
$self->{output}->perfdata_add(label => $item . "_endurance", unit => '%',
|
$self->{output}->perfdata_add(
|
||||||
value => $details->{'percent-endurance-remaining'},
|
label => $item . "_endurance", unit => '%',
|
||||||
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning'),
|
value => $details->{'percent-endurance-remaining'},
|
||||||
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical'),
|
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning'),
|
||||||
min => 0, max => 100);
|
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical'),
|
||||||
|
min => 0, max => 100
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
$self->{output}->display();
|
$self->{output}->display();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user