mirror of
https://github.com/centreon/centreon-plugins.git
synced 2025-07-28 16:14:21 +02:00
parent
2fcd3e8ebd
commit
55abf42a3b
@ -41,10 +41,10 @@ use strict;
|
|||||||
use warnings;
|
use warnings;
|
||||||
|
|
||||||
my %states = (
|
my %states = (
|
||||||
'ok' => 'OK',
|
'ok' => 'OK',
|
||||||
'new' => 'OK',
|
'new' => 'OK',
|
||||||
'degraded' => 'WARNING',
|
'degraded' => 'WARNING',
|
||||||
'failed' => 'CRITICAL',
|
'failed' => 'CRITICAL',
|
||||||
);
|
);
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
@ -55,7 +55,7 @@ sub new {
|
|||||||
$self->{version} = '1.0';
|
$self->{version} = '1.0';
|
||||||
$options{options}->add_options(arguments =>
|
$options{options}->add_options(arguments =>
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
"timeout:s" => { name => 'timeout', default => 30 },
|
"timeout:s" => { name => 'timeout', default => 30 },
|
||||||
"sudo" => { name => 'sudo' },
|
"sudo" => { name => 'sudo' },
|
||||||
"ssh-option:s@" => { name => 'ssh_option' },
|
"ssh-option:s@" => { name => 'ssh_option' },
|
||||||
@ -72,9 +72,9 @@ sub check_options {
|
|||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->SUPER::init(%options);
|
$self->SUPER::init(%options);
|
||||||
|
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
if (!defined($self->{option_results}->{hostname})) {
|
||||||
$self->{output}->add_option_msg(short_msg => "Need to specify a hostname.");
|
$self->{output}->add_option_msg(short_msg => "Need to specify a hostname.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (defined($self->{option_results}->{no_component})) {
|
if (defined($self->{option_results}->{no_component})) {
|
||||||
@ -89,8 +89,8 @@ sub check_options {
|
|||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{option_results}->{remote} = 1;
|
$self->{option_results}->{remote} = 1;
|
||||||
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},
|
||||||
command => "showbattery",
|
command => "showbattery",
|
||||||
@ -98,25 +98,25 @@ sub run {
|
|||||||
command_options => $self->{option_results}->{command_options});
|
command_options => $self->{option_results}->{command_options});
|
||||||
|
|
||||||
|
|
||||||
my $total_components = 0;
|
my $total_components = 0;
|
||||||
my @batteries = split("\n",$stdout);
|
my @batteries = split("\n",$stdout);
|
||||||
foreach my $battery (@batteries) {
|
foreach my $battery (@batteries) {
|
||||||
if ($battery =~ /\d+\s+(\d+)\s+(\d+)\s+\S+\s+(\S+)\s+(\d+)/) {
|
if ($battery =~ /\d+\s+(\d+)\s+(\d+)\s+\S+\s+(\S+)\s+(\d+)/) {
|
||||||
$total_components++;
|
$total_components++;
|
||||||
my $psuId = $1;
|
my $psuId = $1;
|
||||||
my $batteryId = $2;
|
my $batteryId = $2;
|
||||||
my $batteryState = $3;
|
my $batteryState = $3;
|
||||||
my $batteryChrgLvl = $4;
|
my $batteryChrgLvl = $4;
|
||||||
|
|
||||||
$self->{output}->output_add(long_msg => sprintf("Battery '%d' on power supply '%d' is '%s' [Battery charge level: '%d%%']", $batteryId, $psuId, $batteryState, $batteryChrgLvl));
|
$self->{output}->output_add(long_msg => sprintf("Battery '%d' on power supply '%d' is '%s' [Battery charge level: '%d%%']", $batteryId, $psuId, $batteryState, $batteryChrgLvl));
|
||||||
if ($states{lc($batteryState)} ne 'OK'){
|
if ($states{lc($batteryState)} ne 'OK'){
|
||||||
$self->{output}->output_add(severity => $states{lc($batteryState)},
|
$self->{output}->output_add(severity => $states{lc($batteryState)},
|
||||||
short_msg => sprintf("Battery '%d' on power supply '%d' state is '%s' [Battery charge level: '%d%%']", $batteryId, $psuId, $batteryState, $batteryChrgLvl));
|
short_msg => sprintf("Battery '%d' on power supply '%d' state is '%s' [Battery charge level: '%d%%']", $batteryId, $psuId, $batteryState, $batteryChrgLvl));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$self->{output}->output_add(severity => 'OK',
|
$self->{output}->output_add(severity => 'OK',
|
||||||
short_msg => sprintf("All %d batteries are ok.", $total_components));
|
short_msg => sprintf("All %d batteries are ok.", $total_components));
|
||||||
|
|
||||||
if (defined($self->{option_results}->{no_component}) && $total_components == 0) {
|
if (defined($self->{option_results}->{no_component}) && $total_components == 0) {
|
||||||
@ -170,5 +170,3 @@ If total (with skipped) is 0. (Default: 'critical' returns).
|
|||||||
=back
|
=back
|
||||||
|
|
||||||
=cut
|
=cut
|
||||||
|
|
||||||
|
|
||||||
|
@ -48,13 +48,13 @@ sub new {
|
|||||||
$self->{version} = '1.0';
|
$self->{version} = '1.0';
|
||||||
$options{options}->add_options(arguments =>
|
$options{options}->add_options(arguments =>
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
"timeout:s" => { name => 'timeout', default => 30 },
|
"timeout:s" => { name => 'timeout', default => 30 },
|
||||||
"sudo" => { name => 'sudo' },
|
"sudo" => { name => 'sudo' },
|
||||||
"ssh-option:s@" => { name => 'ssh_option' },
|
"ssh-option:s@" => { name => 'ssh_option' },
|
||||||
"ssh-path:s" => { name => 'ssh_path' },
|
"ssh-path:s" => { name => 'ssh_path' },
|
||||||
"ssh-command:s" => { name => 'ssh_command', default => 'ssh' },
|
"ssh-command:s" => { name => 'ssh_command', default => 'ssh' },
|
||||||
"no-cim:s" => { name => 'no_cim' },
|
"no-cim:s" => { name => 'no_cim' },
|
||||||
});
|
});
|
||||||
$self->{no_cim} = undef;
|
$self->{no_cim} = undef;
|
||||||
return $self;
|
return $self;
|
||||||
@ -64,9 +64,9 @@ sub check_options {
|
|||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->SUPER::init(%options);
|
$self->SUPER::init(%options);
|
||||||
|
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
if (!defined($self->{option_results}->{hostname})) {
|
||||||
$self->{output}->add_option_msg(short_msg => "Need to specify a hostname.");
|
$self->{output}->add_option_msg(short_msg => "Need to specify a hostname.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (defined($self->{option_results}->{no_cim})) {
|
if (defined($self->{option_results}->{no_cim})) {
|
||||||
@ -81,8 +81,8 @@ sub check_options {
|
|||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{option_results}->{remote} = 1;
|
$self->{option_results}->{remote} = 1;
|
||||||
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},
|
||||||
command => "showcim",
|
command => "showcim",
|
||||||
@ -90,34 +90,34 @@ sub run {
|
|||||||
command_options => $self->{option_results}->{command_options});
|
command_options => $self->{option_results}->{command_options});
|
||||||
|
|
||||||
|
|
||||||
my @results = split("\n",$stdout);
|
my @results = split("\n",$stdout);
|
||||||
my $total_cim = 0;
|
my $total_cim = 0;
|
||||||
foreach my $result (@results) {
|
foreach my $result (@results) {
|
||||||
if ($result =~ /(\S+)\s+(\S+)\s+(\S+)\s+(\d+)\s+(\S+)\s+(\d+)\s+(\S+)\s+(\d+)\s+\S+/) {
|
if ($result =~ /(\S+)\s+(\S+)\s+(\S+)\s+(\d+)\s+(\S+)\s+(\d+)\s+(\S+)\s+(\d+)\s+\S+/) {
|
||||||
$total_cim++;
|
$total_cim++;
|
||||||
my $serviceStatus = $1;
|
my $serviceStatus = $1;
|
||||||
my $serviceState = $2;
|
my $serviceState = $2;
|
||||||
my $slpState = $3;
|
my $slpState = $3;
|
||||||
my $slpPort = $4;
|
my $slpPort = $4;
|
||||||
my $httpState = $5;
|
my $httpState = $5;
|
||||||
my $httpPort = $6;
|
my $httpPort = $6;
|
||||||
my $httpsState = $7;
|
my $httpsState = $7;
|
||||||
my $httpsPort = $8;
|
my $httpsPort = $8;
|
||||||
|
|
||||||
$self->{output}->output_add(long_msg => sprintf("CIM service is '%s' and '%s' [SLP on port %d is %s] [HTTP on port %d is %s] [HTTPS on port %d is %s]",
|
$self->{output}->output_add(long_msg => sprintf("CIM service is '%s' and '%s' [SLP on port %d is %s] [HTTP on port %d is %s] [HTTPS on port %d is %s]",
|
||||||
$serviceStatus, $serviceState, $slpPort, $slpState, $httpPort, $httpState, $httpsPort ,$httpsState));
|
|
||||||
if ((lc($serviceStatus) ne 'enabled') || (lc($serviceState) ne 'active')){
|
|
||||||
$self->{output}->output_add(severity => 'critical',
|
|
||||||
short_msg => sprintf("CIM service is '%s' and '%s' [SLP on port %d is %s] [HTTP on port %d is %s] [HTTPS on port %d is %s]",
|
|
||||||
$serviceStatus, $serviceState, $slpPort, $slpState, $httpPort, $httpState, $httpsPort ,$httpsState));
|
$serviceStatus, $serviceState, $slpPort, $slpState, $httpPort, $httpState, $httpsPort ,$httpsState));
|
||||||
}
|
if ((lc($serviceStatus) ne 'enabled') || (lc($serviceState) ne 'active')){
|
||||||
}
|
$self->{output}->output_add(severity => 'critical',
|
||||||
}
|
short_msg => sprintf("CIM service is '%s' and '%s' [SLP on port %d is %s] [HTTP on port %d is %s] [HTTPS on port %d is %s]",
|
||||||
|
$serviceStatus, $serviceState, $slpPort, $slpState, $httpPort, $httpState, $httpsPort ,$httpsState));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
$self->{output}->output_add(severity => 'OK',
|
$self->{output}->output_add(severity => 'OK',
|
||||||
short_msg => 'CIM service is ok.');
|
short_msg => 'CIM service is ok.');
|
||||||
|
|
||||||
if (defined($self->{option_results}->{no_cim}) && $total_cim == 0) {
|
if (defined($self->{option_results}->{no_cim}) && $total_cim == 0) {
|
||||||
$self->{output}->output_add(severity => $self->{no_cim},
|
$self->{output}->output_add(severity => $self->{no_cim},
|
||||||
short_msg => 'No CIM service is checked.');
|
short_msg => 'No CIM service is checked.');
|
||||||
}
|
}
|
||||||
@ -168,5 +168,3 @@ If total (with skipped) is 0. (Default: 'critical' returns).
|
|||||||
=back
|
=back
|
||||||
|
|
||||||
=cut
|
=cut
|
||||||
|
|
||||||
|
|
||||||
|
@ -41,9 +41,9 @@ use strict;
|
|||||||
use warnings;
|
use warnings;
|
||||||
|
|
||||||
my %states = (
|
my %states = (
|
||||||
'ready' => 'OK',
|
'ready' => 'OK',
|
||||||
'loss_sync' => 'WARNING',
|
'loss_sync' => 'WARNING',
|
||||||
'offline' => 'CRITICAL',
|
'offline' => 'CRITICAL',
|
||||||
);
|
);
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
@ -54,7 +54,7 @@ sub new {
|
|||||||
$self->{version} = '1.0';
|
$self->{version} = '1.0';
|
||||||
$options{options}->add_options(arguments =>
|
$options{options}->add_options(arguments =>
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
"timeout:s" => { name => 'timeout', default => 30 },
|
"timeout:s" => { name => 'timeout', default => 30 },
|
||||||
"sudo" => { name => 'sudo' },
|
"sudo" => { name => 'sudo' },
|
||||||
"ssh-option:s@" => { name => 'ssh_option' },
|
"ssh-option:s@" => { name => 'ssh_option' },
|
||||||
@ -71,9 +71,9 @@ sub check_options {
|
|||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->SUPER::init(%options);
|
$self->SUPER::init(%options);
|
||||||
|
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
if (!defined($self->{option_results}->{hostname})) {
|
||||||
$self->{output}->add_option_msg(short_msg => "Need to specify a hostname.");
|
$self->{output}->add_option_msg(short_msg => "Need to specify a hostname.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (defined($self->{option_results}->{no_component})) {
|
if (defined($self->{option_results}->{no_component})) {
|
||||||
@ -88,8 +88,8 @@ sub check_options {
|
|||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{option_results}->{remote} = 1;
|
$self->{option_results}->{remote} = 1;
|
||||||
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},
|
||||||
command => "showport",
|
command => "showport",
|
||||||
@ -97,25 +97,25 @@ sub run {
|
|||||||
command_options => $self->{option_results}->{command_options});
|
command_options => $self->{option_results}->{command_options});
|
||||||
|
|
||||||
|
|
||||||
my $total_components = 0;
|
my $total_components = 0;
|
||||||
my @iscsis = split("\n",$stdout);
|
my @iscsis = split("\n",$stdout);
|
||||||
foreach my $iscsi (@iscsis) {
|
foreach my $iscsi (@iscsis) {
|
||||||
if ($iscsi =~ /(\S+)\s+\S+\s+(\S+)\s+\S+\s+\S+\s+(\S+)/) {
|
if ($iscsi =~ /(\S+)\s+\S+\s+(\S+)\s+\S+\s+\S+\s+(\S+)/) {
|
||||||
my $iscsiNsp = $1;
|
my $iscsiNsp = $1;
|
||||||
my $iscsiState = $2;
|
my $iscsiState = $2;
|
||||||
my $iscsiType = $3;
|
my $iscsiType = $3;
|
||||||
if($iscsiType eq 'iscsi') {
|
if($iscsiType eq 'iscsi') {
|
||||||
$self->{output}->output_add(long_msg => sprintf("Interface '%s' is '%s'", $iscsiNsp, $iscsiState));
|
$self->{output}->output_add(long_msg => sprintf("Interface '%s' is '%s'", $iscsiNsp, $iscsiState));
|
||||||
if ($states{lc($iscsiState)} ne 'OK'){
|
if ($states{lc($iscsiState)} ne 'OK'){
|
||||||
$self->{output}->output_add(severity => $states{lc($iscsiState)},
|
$self->{output}->output_add(severity => $states{lc($iscsiState)},
|
||||||
short_msg => sprintf("Interface '%s' is '%s'", $iscsiNsp, $iscsiState));
|
short_msg => sprintf("Interface '%s' is '%s'", $iscsiNsp, $iscsiState));
|
||||||
}
|
}
|
||||||
$total_components++;
|
$total_components++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$self->{output}->output_add(severity => 'OK',
|
$self->{output}->output_add(severity => 'OK',
|
||||||
short_msg => sprintf("All %d ISCSIs are ok.", $total_components));
|
short_msg => sprintf("All %d ISCSIs are ok.", $total_components));
|
||||||
|
|
||||||
if (defined($self->{option_results}->{no_component}) && $total_components == 0) {
|
if (defined($self->{option_results}->{no_component}) && $total_components == 0) {
|
||||||
@ -169,5 +169,3 @@ If total (with skipped) is 0. (Default: 'critical' returns).
|
|||||||
=back
|
=back
|
||||||
|
|
||||||
=cut
|
=cut
|
||||||
|
|
||||||
|
|
||||||
|
@ -41,10 +41,10 @@ use strict;
|
|||||||
use warnings;
|
use warnings;
|
||||||
|
|
||||||
my %states = (
|
my %states = (
|
||||||
'ok' => 'OK',
|
'ok' => 'OK',
|
||||||
'new' => 'OK',
|
'new' => 'OK',
|
||||||
'degraded' => 'WARNING',
|
'degraded' => 'WARNING',
|
||||||
'failed' => 'CRITICAL',
|
'failed' => 'CRITICAL',
|
||||||
);
|
);
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
@ -55,7 +55,7 @@ sub new {
|
|||||||
$self->{version} = '1.0';
|
$self->{version} = '1.0';
|
||||||
$options{options}->add_options(arguments =>
|
$options{options}->add_options(arguments =>
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
"timeout:s" => { name => 'timeout', default => 30 },
|
"timeout:s" => { name => 'timeout', default => 30 },
|
||||||
"sudo" => { name => 'sudo' },
|
"sudo" => { name => 'sudo' },
|
||||||
"ssh-option:s@" => { name => 'ssh_option' },
|
"ssh-option:s@" => { name => 'ssh_option' },
|
||||||
@ -72,9 +72,9 @@ sub check_options {
|
|||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->SUPER::init(%options);
|
$self->SUPER::init(%options);
|
||||||
|
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
if (!defined($self->{option_results}->{hostname})) {
|
||||||
$self->{output}->add_option_msg(short_msg => "Need to specify a hostname.");
|
$self->{output}->add_option_msg(short_msg => "Need to specify a hostname.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (defined($self->{option_results}->{no_component})) {
|
if (defined($self->{option_results}->{no_component})) {
|
||||||
@ -89,8 +89,8 @@ sub check_options {
|
|||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{option_results}->{remote} = 1;
|
$self->{option_results}->{remote} = 1;
|
||||||
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},
|
||||||
command => "shownode -s",
|
command => "shownode -s",
|
||||||
@ -98,24 +98,24 @@ sub run {
|
|||||||
command_options => $self->{option_results}->{command_options});
|
command_options => $self->{option_results}->{command_options});
|
||||||
|
|
||||||
|
|
||||||
my $total_components = 0;
|
my $total_components = 0;
|
||||||
my @nodes = split("\n",$stdout);
|
my @nodes = split("\n",$stdout);
|
||||||
foreach my $node (@nodes) {
|
foreach my $node (@nodes) {
|
||||||
if ($node =~ /(\d+)\s+(\S+)\s+(\S+)/) {
|
if ($node =~ /(\d+)\s+(\S+)\s+(\S+)/) {
|
||||||
$total_components++;
|
$total_components++;
|
||||||
my $nodeId = $1;
|
my $nodeId = $1;
|
||||||
my $nodeState = $2;
|
my $nodeState = $2;
|
||||||
my $detailNodeState = $3;
|
my $detailNodeState = $3;
|
||||||
|
|
||||||
$self->{output}->output_add(long_msg => sprintf("Node '%d' state is '%s' [Detailed State: %s]", $nodeId, $nodeState, $detailNodeState));
|
$self->{output}->output_add(long_msg => sprintf("Node '%d' state is '%s' [Detailed State: %s]", $nodeId, $nodeState, $detailNodeState));
|
||||||
if ($states{lc($nodeState)} ne 'OK'){
|
if ($states{lc($nodeState)} ne 'OK'){
|
||||||
$self->{output}->output_add(severity => $states{lc($nodeState)},
|
$self->{output}->output_add(severity => $states{lc($nodeState)},
|
||||||
short_msg => sprintf("Node '%d' state is '%s' [Detailed State: %s]", $nodeId, $nodeState, $detailNodeState));
|
short_msg => sprintf("Node '%d' state is '%s' [Detailed State: %s]", $nodeId, $nodeState, $detailNodeState));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$self->{output}->output_add(severity => 'OK',
|
$self->{output}->output_add(severity => 'OK',
|
||||||
short_msg => sprintf("All %d nodes are ok.", $total_components));
|
short_msg => sprintf("All %d nodes are ok.", $total_components));
|
||||||
|
|
||||||
if (defined($self->{option_results}->{no_component}) && $total_components == 0) {
|
if (defined($self->{option_results}->{no_component}) && $total_components == 0) {
|
||||||
@ -169,5 +169,3 @@ If total (with skipped) is 0. (Default: 'critical' returns).
|
|||||||
=back
|
=back
|
||||||
|
|
||||||
=cut
|
=cut
|
||||||
|
|
||||||
|
|
||||||
|
@ -41,10 +41,10 @@ use strict;
|
|||||||
use warnings;
|
use warnings;
|
||||||
|
|
||||||
my %states = (
|
my %states = (
|
||||||
'normal' => 'OK',
|
'normal' => 'OK',
|
||||||
'new' => 'OK',
|
'new' => 'OK',
|
||||||
'degraded' => 'WARNING',
|
'degraded' => 'WARNING',
|
||||||
'failed' => 'CRITICAL',
|
'failed' => 'CRITICAL',
|
||||||
);
|
);
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
@ -55,7 +55,7 @@ sub new {
|
|||||||
$self->{version} = '1.0';
|
$self->{version} = '1.0';
|
||||||
$options{options}->add_options(arguments =>
|
$options{options}->add_options(arguments =>
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
"timeout:s" => { name => 'timeout', default => 30 },
|
"timeout:s" => { name => 'timeout', default => 30 },
|
||||||
"sudo" => { name => 'sudo' },
|
"sudo" => { name => 'sudo' },
|
||||||
"ssh-option:s@" => { name => 'ssh_option' },
|
"ssh-option:s@" => { name => 'ssh_option' },
|
||||||
@ -72,9 +72,9 @@ sub check_options {
|
|||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->SUPER::init(%options);
|
$self->SUPER::init(%options);
|
||||||
|
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
if (!defined($self->{option_results}->{hostname})) {
|
||||||
$self->{output}->add_option_msg(short_msg => "Need to specify a hostname.");
|
$self->{output}->add_option_msg(short_msg => "Need to specify a hostname.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (defined($self->{option_results}->{no_component})) {
|
if (defined($self->{option_results}->{no_component})) {
|
||||||
@ -89,8 +89,8 @@ sub check_options {
|
|||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{option_results}->{remote} = 1;
|
$self->{option_results}->{remote} = 1;
|
||||||
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},
|
||||||
command => "showpd -showcols Id,State",
|
command => "showpd -showcols Id,State",
|
||||||
@ -98,23 +98,23 @@ sub run {
|
|||||||
command_options => $self->{option_results}->{command_options});
|
command_options => $self->{option_results}->{command_options});
|
||||||
|
|
||||||
|
|
||||||
my $total_components = 0;
|
my $total_components = 0;
|
||||||
my @disks = split("\n",$stdout);
|
my @disks = split("\n",$stdout);
|
||||||
foreach my $disk (@disks) {
|
foreach my $disk (@disks) {
|
||||||
if ($disk =~ /(\d+)\s+(\S+)/) {
|
if ($disk =~ /(\d+)\s+(\S+)/) {
|
||||||
$total_components++;
|
$total_components++;
|
||||||
my $diskId = $1;
|
my $diskId = $1;
|
||||||
my $diskState = $2;
|
my $diskState = $2;
|
||||||
|
|
||||||
$self->{output}->output_add(long_msg => sprintf("Physical Disk '%d' state is '%s'", $diskId, $diskState));
|
$self->{output}->output_add(long_msg => sprintf("Physical Disk '%d' state is '%s'", $diskId, $diskState));
|
||||||
if ($states{$diskState} ne 'OK'){
|
if ($states{$diskState} ne 'OK'){
|
||||||
$self->{output}->output_add(severity => $states{$diskState},
|
$self->{output}->output_add(severity => $states{$diskState},
|
||||||
short_msg => sprintf("Physical Disk '%d' state is '%s'.", $diskId, $diskState));
|
short_msg => sprintf("Physical Disk '%d' state is '%s'.", $diskId, $diskState));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$self->{output}->output_add(severity => 'OK',
|
$self->{output}->output_add(severity => 'OK',
|
||||||
short_msg => sprintf("All %d physical disks are ok.", $total_components));
|
short_msg => sprintf("All %d physical disks are ok.", $total_components));
|
||||||
|
|
||||||
if (defined($self->{option_results}->{no_component}) && $total_components == 0) {
|
if (defined($self->{option_results}->{no_component}) && $total_components == 0) {
|
||||||
@ -168,5 +168,3 @@ If total (with skipped) is 0. (Default: 'critical' returns).
|
|||||||
=back
|
=back
|
||||||
|
|
||||||
=cut
|
=cut
|
||||||
|
|
||||||
|
|
||||||
|
@ -41,10 +41,10 @@ use strict;
|
|||||||
use warnings;
|
use warnings;
|
||||||
|
|
||||||
my %states = (
|
my %states = (
|
||||||
'ok' => 'OK',
|
'ok' => 'OK',
|
||||||
'new' => 'OK',
|
'new' => 'OK',
|
||||||
'degraded' => 'WARNING',
|
'degraded' => 'WARNING',
|
||||||
'failed' => 'CRITICAL',
|
'failed' => 'CRITICAL',
|
||||||
);
|
);
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
@ -55,7 +55,7 @@ sub new {
|
|||||||
$self->{version} = '1.0';
|
$self->{version} = '1.0';
|
||||||
$options{options}->add_options(arguments =>
|
$options{options}->add_options(arguments =>
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
"timeout:s" => { name => 'timeout', default => 30 },
|
"timeout:s" => { name => 'timeout', default => 30 },
|
||||||
"sudo" => { name => 'sudo' },
|
"sudo" => { name => 'sudo' },
|
||||||
"ssh-option:s@" => { name => 'ssh_option' },
|
"ssh-option:s@" => { name => 'ssh_option' },
|
||||||
@ -72,9 +72,9 @@ sub check_options {
|
|||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->SUPER::init(%options);
|
$self->SUPER::init(%options);
|
||||||
|
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
if (!defined($self->{option_results}->{hostname})) {
|
||||||
$self->{output}->add_option_msg(short_msg => "Need to specify a hostname.");
|
$self->{output}->add_option_msg(short_msg => "Need to specify a hostname.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (defined($self->{option_results}->{no_component})) {
|
if (defined($self->{option_results}->{no_component})) {
|
||||||
@ -89,8 +89,8 @@ sub check_options {
|
|||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{option_results}->{remote} = 1;
|
$self->{option_results}->{remote} = 1;
|
||||||
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},
|
||||||
command => "shownode -ps",
|
command => "shownode -ps",
|
||||||
@ -98,25 +98,25 @@ sub run {
|
|||||||
command_options => $self->{option_results}->{command_options});
|
command_options => $self->{option_results}->{command_options});
|
||||||
|
|
||||||
|
|
||||||
my $total_components = 0;
|
my $total_components = 0;
|
||||||
my @psus = split("\n",$stdout);
|
my @psus = split("\n",$stdout);
|
||||||
foreach my $psu (@psus) {
|
foreach my $psu (@psus) {
|
||||||
if ($psu =~ /\S+\s+(\d+)\s+\S+\s+\S+\s+(\S+)\s+(\S+)\s+(\S+)/) {
|
if ($psu =~ /\S+\s+(\d+)\s+\S+\s+\S+\s+(\S+)\s+(\S+)\s+(\S+)/) {
|
||||||
$total_components++;
|
$total_components++;
|
||||||
my $psuId = $1;
|
my $psuId = $1;
|
||||||
my $ACState = $2;
|
my $ACState = $2;
|
||||||
my $DCState = $3;
|
my $DCState = $3;
|
||||||
my $psuState = $4;
|
my $psuState = $4;
|
||||||
|
|
||||||
$self->{output}->output_add(long_msg => sprintf("Power Suppply '%d' state is '%s' [AC: %s] [DC: %s]", $psuId, $psuState, $ACState ,$DCState));
|
$self->{output}->output_add(long_msg => sprintf("Power Suppply '%d' state is '%s' [AC: %s] [DC: %s]", $psuId, $psuState, $ACState ,$DCState));
|
||||||
if ($states{lc($psuState)} ne 'OK'){
|
if ($states{lc($psuState)} ne 'OK'){
|
||||||
$self->{output}->output_add(severity => $states{lc($psuState)},
|
$self->{output}->output_add(severity => $states{lc($psuState)},
|
||||||
short_msg => sprintf("Power Suppply '%d' state is '%s' [AC: %s] [DC: %s]", $psuId, $psuState, $ACState ,$DCState));
|
short_msg => sprintf("Power Suppply '%d' state is '%s' [AC: %s] [DC: %s]", $psuId, $psuState, $ACState ,$DCState));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$self->{output}->output_add(severity => 'OK',
|
$self->{output}->output_add(severity => 'OK',
|
||||||
short_msg => sprintf("All %d power supplies are ok.", $total_components));
|
short_msg => sprintf("All %d power supplies are ok.", $total_components));
|
||||||
|
|
||||||
if (defined($self->{option_results}->{no_component}) && $total_components == 0) {
|
if (defined($self->{option_results}->{no_component}) && $total_components == 0) {
|
||||||
@ -170,5 +170,3 @@ If total (with skipped) is 0. (Default: 'critical' returns).
|
|||||||
=back
|
=back
|
||||||
|
|
||||||
=cut
|
=cut
|
||||||
|
|
||||||
|
|
||||||
|
@ -48,17 +48,17 @@ sub new {
|
|||||||
$self->{version} = '1.0';
|
$self->{version} = '1.0';
|
||||||
$options{options}->add_options(arguments =>
|
$options{options}->add_options(arguments =>
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
"timeout:s" => { name => 'timeout', default => 30 },
|
"timeout:s" => { name => 'timeout', default => 30 },
|
||||||
"sudo" => { name => 'sudo' },
|
"sudo" => { name => 'sudo' },
|
||||||
"ssh-option:s@" => { name => 'ssh_option' },
|
"ssh-option:s@" => { name => 'ssh_option' },
|
||||||
"ssh-path:s" => { name => 'ssh_path' },
|
"ssh-path:s" => { name => 'ssh_path' },
|
||||||
"ssh-command:s" => { name => 'ssh_command', default => 'ssh' },
|
"ssh-command:s" => { name => 'ssh_command', default => 'ssh' },
|
||||||
"warning:s" => { name => 'warning' },
|
"warning:s" => { name => 'warning' },
|
||||||
"critical:s" => { name => 'critical' },
|
"critical:s" => { name => 'critical' },
|
||||||
"filter-type:s" => { name => 'filter_type' },
|
"filter-type:s" => { name => 'filter_type' },
|
||||||
"disk:s" => { name => 'disk' },
|
"disk:s" => { name => 'disk' },
|
||||||
"regexp" => { name => 'regexp' },
|
"regexp" => { name => 'regexp' },
|
||||||
});
|
});
|
||||||
$self->{components} = {};
|
$self->{components} = {};
|
||||||
$self->{no_components} = undef;
|
$self->{no_components} = undef;
|
||||||
@ -69,17 +69,17 @@ sub check_options {
|
|||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->SUPER::init(%options);
|
$self->SUPER::init(%options);
|
||||||
|
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
if (!defined($self->{option_results}->{hostname})) {
|
||||||
$self->{output}->add_option_msg(short_msg => "Need to specify a hostname.");
|
$self->{output}->add_option_msg(short_msg => "Need to specify a hostname.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (($self->{perfdata}->threshold_validate(label => 'warning', value => $self->{option_results}->{warning})) == 0) {
|
if (($self->{perfdata}->threshold_validate(label => 'warning', value => $self->{option_results}->{warning})) == 0) {
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong warning threshold '" . $self->{option_results}->{warning} . "'.");
|
$self->{output}->add_option_msg(short_msg => "Wrong warning threshold '" . $self->{option_results}->{warning} . "'.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (($self->{perfdata}->threshold_validate(label => 'critical', value => $self->{option_results}->{critical})) == 0) {
|
if (($self->{perfdata}->threshold_validate(label => 'critical', value => $self->{option_results}->{critical})) == 0) {
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong critical threshold '" . $self->{option_results}->{critical} . "'.");
|
$self->{output}->add_option_msg(short_msg => "Wrong critical threshold '" . $self->{option_results}->{critical} . "'.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
@ -88,8 +88,8 @@ sub check_options {
|
|||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{option_results}->{remote} = 1;
|
$self->{option_results}->{remote} = 1;
|
||||||
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},
|
||||||
command => "showpd",
|
command => "showpd",
|
||||||
@ -97,46 +97,46 @@ sub run {
|
|||||||
command_options => $self->{option_results}->{command_options});
|
command_options => $self->{option_results}->{command_options});
|
||||||
|
|
||||||
|
|
||||||
my $total_disks = 0;
|
my $total_disks = 0;
|
||||||
my @disks = split("\n",$stdout);
|
my @disks = split("\n",$stdout);
|
||||||
foreach my $disk (@disks) {
|
foreach my $disk (@disks) {
|
||||||
if ($disk =~ /(\d+)\s+\S+\s+(\S+)\s+\d+\s+\S+\s+(\d+)\s+(\d+)\s+\S+\s+\S+\s+\d+/) {
|
if ($disk =~ /(\d+)\s+\S+\s+(\S+)\s+\d+\s+\S+\s+(\d+)\s+(\d+)\s+\S+\s+\S+\s+\d+/) {
|
||||||
$total_disks++;
|
$total_disks++;
|
||||||
my $diskId = $1;
|
my $diskId = $1;
|
||||||
my $diskType = $2;
|
my $diskType = $2;
|
||||||
my $diskSize = $3 * 1024 * 1024;
|
my $diskSize = $3 * 1024 * 1024;
|
||||||
my $diskFree = $4 * 1024 * 1024;
|
my $diskFree = $4 * 1024 * 1024;
|
||||||
my $diskUsed = $diskSize - $diskFree;
|
my $diskUsed = $diskSize - $diskFree;
|
||||||
my $percentUsed = ($diskUsed / $diskSize) * 100;
|
my $percentUsed = ($diskUsed / $diskSize) * 100;
|
||||||
my $percentFree = ($diskFree / $diskSize) * 100;
|
my $percentFree = ($diskFree / $diskSize) * 100;
|
||||||
|
|
||||||
next if (defined($self->{option_results}->{filter_type}) && ($diskType !~ /$self->{option_results}->{filter_type}/i));
|
next if (defined($self->{option_results}->{filter_type}) && ($diskType !~ /$self->{option_results}->{filter_type}/i));
|
||||||
next if (defined($self->{option_results}->{disk}) && defined($self->{option_results}->{regexp}) && ($diskId !~ /$self->{option_results}->{disk}/i));
|
next if (defined($self->{option_results}->{disk}) && defined($self->{option_results}->{regexp}) && ($diskId !~ /$self->{option_results}->{disk}/i));
|
||||||
next if (defined($self->{option_results}->{disk}) && !defined($self->{option_results}->{regexp}) && ($diskId != $self->{option_results}->{disk}));
|
next if (defined($self->{option_results}->{disk}) && !defined($self->{option_results}->{regexp}) && ($diskId != $self->{option_results}->{disk}));
|
||||||
|
|
||||||
my ($diskSizeValue, $diskSizeUnit) = $self->{perfdata}->change_bytes(value => $diskSize);
|
my ($diskSizeValue, $diskSizeUnit) = $self->{perfdata}->change_bytes(value => $diskSize);
|
||||||
my ($diskUsedValue, $diskUsedUnit) = $self->{perfdata}->change_bytes(value => $diskUsed);
|
my ($diskUsedValue, $diskUsedUnit) = $self->{perfdata}->change_bytes(value => $diskUsed);
|
||||||
my ($diskFreeValue, $diskFreeUnit) = $self->{perfdata}->change_bytes(value => $diskFree);
|
my ($diskFreeValue, $diskFreeUnit) = $self->{perfdata}->change_bytes(value => $diskFree);
|
||||||
|
|
||||||
$self->{output}->output_add(long_msg => sprintf("Disk '%d' Total: %.2f%s Used: %.2f%s (%.2f%%) Free: %.2f%s (%.2f%%)",
|
$self->{output}->output_add(long_msg => sprintf("Disk '%d' Total: %.2f%s Used: %.2f%s (%.2f%%) Free: %.2f%s (%.2f%%)",
|
||||||
$diskId, $diskSizeValue, $diskSizeUnit, $diskUsedValue, $diskUsedUnit, $percentUsed, $diskFreeValue, $diskFreeUnit, $percentFree));
|
$diskId, $diskSizeValue, $diskSizeUnit, $diskUsedValue, $diskUsedUnit, $percentUsed, $diskFreeValue, $diskFreeUnit, $percentFree));
|
||||||
my $exit = $self->{perfdata}->threshold_check(value => $percentUsed, threshold => [ { label => 'critical', 'exit_litteral' => 'critical' }, { label => 'warning', exit_litteral => 'warning' } ]);
|
my $exit = $self->{perfdata}->threshold_check(value => $percentUsed, 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(severity => $exit,
|
||||||
short_msg => sprintf("Disk '%d' Total: %.2f%s Used: %.2f%s (%.2f%%) Free: %.2f%s (%.2f%%)",
|
short_msg => sprintf("Disk '%d' Total: %.2f%s Used: %.2f%s (%.2f%%) Free: %.2f%s (%.2f%%)",
|
||||||
$diskId, $diskSizeValue, $diskSizeUnit, $diskUsedValue, $diskUsedUnit, $percentUsed, $diskFreeValue, $diskFreeUnit, $percentFree));
|
$diskId, $diskSizeValue, $diskSizeUnit, $diskUsedValue, $diskUsedUnit, $percentUsed, $diskFreeValue, $diskFreeUnit, $percentFree));
|
||||||
}
|
}
|
||||||
$self->{output}->perfdata_add(label => 'disk_'.$diskId,
|
$self->{output}->perfdata_add(label => 'disk_'.$diskId,
|
||||||
unit => 'B',
|
unit => 'B',
|
||||||
value => $diskUsed,
|
value => $diskUsed,
|
||||||
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning', total => $diskSize, cast_int => 1),
|
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning', total => $diskSize, cast_int => 1),
|
||||||
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical', total => $diskSize, cast_int => 1),
|
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical', total => $diskSize, cast_int => 1),
|
||||||
min => 0,
|
min => 0,
|
||||||
max => $diskSize);
|
max => $diskSize);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$self->{output}->output_add(severity => 'OK',
|
$self->{output}->output_add(severity => 'OK',
|
||||||
short_msg => 'All disks are ok.');
|
short_msg => 'All disks are ok.');
|
||||||
|
|
||||||
$self->{output}->display();
|
$self->{output}->display();
|
||||||
@ -185,5 +185,3 @@ If total (with skipped) is 0. (Default: 'critical' returns).
|
|||||||
=back
|
=back
|
||||||
|
|
||||||
=cut
|
=cut
|
||||||
|
|
||||||
|
|
||||||
|
@ -49,15 +49,15 @@ sub new {
|
|||||||
$self->{version} = '1.0';
|
$self->{version} = '1.0';
|
||||||
$options{options}->add_options(arguments =>
|
$options{options}->add_options(arguments =>
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
"timeout:s" => { name => 'timeout', default => 30 },
|
"timeout:s" => { name => 'timeout', default => 30 },
|
||||||
"sudo" => { name => 'sudo' },
|
"sudo" => { name => 'sudo' },
|
||||||
"ssh-option:s@" => { name => 'ssh_option' },
|
"ssh-option:s@" => { name => 'ssh_option' },
|
||||||
"ssh-path:s" => { name => 'ssh_path' },
|
"ssh-path:s" => { name => 'ssh_path' },
|
||||||
"ssh-command:s" => { name => 'ssh_command', default => 'ssh' },
|
"ssh-command:s" => { name => 'ssh_command', default => 'ssh' },
|
||||||
"no-component:s" => { name => 'no_component' },
|
"no-component:s" => { name => 'no_component' },
|
||||||
"sensor:s" => { name => 'sensor' },
|
"sensor:s" => { name => 'sensor' },
|
||||||
"regexp" => { name => 'regexp' },
|
"regexp" => { name => 'regexp' },
|
||||||
});
|
});
|
||||||
$self->{components} = {};
|
$self->{components} = {};
|
||||||
$self->{no_components} = undef;
|
$self->{no_components} = undef;
|
||||||
@ -68,7 +68,7 @@ sub check_options {
|
|||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->SUPER::init(%options);
|
$self->SUPER::init(%options);
|
||||||
|
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
if (!defined($self->{option_results}->{hostname})) {
|
||||||
$self->{output}->add_option_msg(short_msg => "Need to specify a hostname.");
|
$self->{output}->add_option_msg(short_msg => "Need to specify a hostname.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
@ -85,8 +85,8 @@ sub check_options {
|
|||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{option_results}->{remote} = 1;
|
$self->{option_results}->{remote} = 1;
|
||||||
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},
|
||||||
command => "shownodeenv",
|
command => "shownodeenv",
|
||||||
@ -94,37 +94,37 @@ sub run {
|
|||||||
command_options => $self->{option_results}->{command_options});
|
command_options => $self->{option_results}->{command_options});
|
||||||
|
|
||||||
|
|
||||||
my $total_components = 0;
|
my $total_components = 0;
|
||||||
my $nodeID = 0;
|
my $nodeID = 0;
|
||||||
my @temperatures = split(/\n/,$stdout);
|
my @temperatures = split(/\n/,$stdout);
|
||||||
foreach my $temperature (@temperatures) {
|
foreach my $temperature (@temperatures) {
|
||||||
if ($temperature =~ /^Node\s(\d+)$/) {
|
if ($temperature =~ /^Node\s(\d+)$/) {
|
||||||
$nodeID = $1;
|
$nodeID = $1;
|
||||||
}
|
}
|
||||||
if ($temperature =~ /^(.+)\s(\d+)\sC\s+(\d+)\sC\s+(\d+)/) {
|
if ($temperature =~ /^(.+)\s(\d+)\sC\s+(\d+)\sC\s+(\d+)/) {
|
||||||
my $measurement = $1;
|
my $measurement = $1;
|
||||||
my $readTemp = $2;
|
my $readTemp = $2;
|
||||||
my $loTemp = $3;
|
my $loTemp = $3;
|
||||||
my $hiTemp= $4;
|
my $hiTemp= $4;
|
||||||
$measurement =~ s/^\s+//;
|
$measurement =~ s/^\s+//;
|
||||||
$measurement =~ s/\s+$//;
|
$measurement =~ s/\s+$//;
|
||||||
$total_components++;
|
$total_components++;
|
||||||
|
|
||||||
next if (defined($self->{option_results}->{sensor}) && defined($self->{option_results}->{regexp}) && ($measurement !~ /$self->{option_results}->{sensor}/i));
|
next if (defined($self->{option_results}->{sensor}) && defined($self->{option_results}->{regexp}) && ($measurement !~ /$self->{option_results}->{sensor}/i));
|
||||||
next if (defined($self->{option_results}->{sensor}) && !defined($self->{option_results}->{regexp}) && ($measurement != $self->{option_results}->{sensor}));
|
next if (defined($self->{option_results}->{sensor}) && !defined($self->{option_results}->{regexp}) && ($measurement != $self->{option_results}->{sensor}));
|
||||||
|
|
||||||
$self->{output}->output_add(long_msg => sprintf("Temperature '%s' on node '%d' is '%dC' [Max temperature: '%dC'] [Min temperature: '%dC'", $measurement, $nodeID, $readTemp, $hiTemp, $loTemp));
|
$self->{output}->output_add(long_msg => sprintf("Temperature '%s' on node '%d' is '%dC' [Max temperature: '%dC'] [Min temperature: '%dC'", $measurement, $nodeID, $readTemp, $hiTemp, $loTemp));
|
||||||
if (($readTemp > $hiTemp) || ($readTemp < $loTemp)){
|
if (($readTemp > $hiTemp) || ($readTemp < $loTemp)){
|
||||||
$self->{output}->output_add(severity => 'critical',
|
$self->{output}->output_add(severity => 'critical',
|
||||||
short_msg => sprintf("Temperature '%s' on node '%d' is '%dC' [Max temperature: '%dC'] [Min temperature: '%dC'", $measurement, $nodeID, $readTemp, $hiTemp, $loTemp));
|
short_msg => sprintf("Temperature '%s' on node '%d' is '%dC' [Max temperature: '%dC'] [Min temperature: '%dC'", $measurement, $nodeID, $readTemp, $hiTemp, $loTemp));
|
||||||
}
|
}
|
||||||
$self->{output}->perfdata_add(label => $measurement.'_temperature',
|
$self->{output}->perfdata_add(label => $measurement.'_temperature',
|
||||||
unit => 'C',
|
unit => 'C',
|
||||||
value => $readTemp);
|
value => $readTemp);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$self->{output}->output_add(severity => 'OK',
|
$self->{output}->output_add(severity => 'OK',
|
||||||
short_msg => sprintf("All %d temperatures are ok.", $total_components));
|
short_msg => sprintf("All %d temperatures are ok.", $total_components));
|
||||||
|
|
||||||
if (defined($self->{option_results}->{no_component}) && $total_components == 0) {
|
if (defined($self->{option_results}->{no_component}) && $total_components == 0) {
|
||||||
|
@ -48,18 +48,18 @@ sub new {
|
|||||||
$self->{version} = '1.0';
|
$self->{version} = '1.0';
|
||||||
$options{options}->add_options(arguments =>
|
$options{options}->add_options(arguments =>
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
"timeout:s" => { name => 'timeout', default => 30 },
|
"timeout:s" => { name => 'timeout', default => 30 },
|
||||||
"sudo" => { name => 'sudo' },
|
"sudo" => { name => 'sudo' },
|
||||||
"ssh-option:s@" => { name => 'ssh_option' },
|
"ssh-option:s@" => { name => 'ssh_option' },
|
||||||
"ssh-path:s" => { name => 'ssh_path' },
|
"ssh-path:s" => { name => 'ssh_path' },
|
||||||
"ssh-command:s" => { name => 'ssh_command', default => 'ssh' },
|
"ssh-command:s" => { name => 'ssh_command', default => 'ssh' },
|
||||||
"warning:s" => { name => 'warning' },
|
"warning:s" => { name => 'warning' },
|
||||||
"critical:s" => { name => 'critical' },
|
"critical:s" => { name => 'critical' },
|
||||||
"filter-type:s" => { name => 'filter_type' },
|
"filter-type:s" => { name => 'filter_type' },
|
||||||
"volume:s" => { name => 'volume' },
|
"volume:s" => { name => 'volume' },
|
||||||
"name" => { name => 'name' },
|
"name" => { name => 'name' },
|
||||||
"regexp" => { name => 'regexp' },
|
"regexp" => { name => 'regexp' },
|
||||||
});
|
});
|
||||||
$self->{components} = {};
|
$self->{components} = {};
|
||||||
$self->{no_components} = undef;
|
$self->{no_components} = undef;
|
||||||
@ -70,17 +70,17 @@ sub check_options {
|
|||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->SUPER::init(%options);
|
$self->SUPER::init(%options);
|
||||||
|
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
if (!defined($self->{option_results}->{hostname})) {
|
||||||
$self->{output}->add_option_msg(short_msg => "Need to specify a hostname.");
|
$self->{output}->add_option_msg(short_msg => "Need to specify a hostname.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (($self->{perfdata}->threshold_validate(label => 'warning', value => $self->{option_results}->{warning})) == 0) {
|
if (($self->{perfdata}->threshold_validate(label => 'warning', value => $self->{option_results}->{warning})) == 0) {
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong warning threshold '" . $self->{option_results}->{warning} . "'.");
|
$self->{output}->add_option_msg(short_msg => "Wrong warning threshold '" . $self->{option_results}->{warning} . "'.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (($self->{perfdata}->threshold_validate(label => 'critical', value => $self->{option_results}->{critical})) == 0) {
|
if (($self->{perfdata}->threshold_validate(label => 'critical', value => $self->{option_results}->{critical})) == 0) {
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong critical threshold '" . $self->{option_results}->{critical} . "'.");
|
$self->{output}->add_option_msg(short_msg => "Wrong critical threshold '" . $self->{option_results}->{critical} . "'.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
@ -89,8 +89,8 @@ sub check_options {
|
|||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{option_results}->{remote} = 1;
|
$self->{option_results}->{remote} = 1;
|
||||||
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},
|
||||||
command => "showvv -showcols Id,Name,VSize_MB,Snp_Rsvd_MB,Snp_Used_MB,Adm_Rsvd_MB,Adm_Used_MB,Usr_Rsvd_MB,Usr_Used_MB",
|
command => "showvv -showcols Id,Name,VSize_MB,Snp_Rsvd_MB,Snp_Used_MB,Adm_Rsvd_MB,Adm_Used_MB,Usr_Rsvd_MB,Usr_Used_MB",
|
||||||
@ -98,72 +98,72 @@ sub run {
|
|||||||
command_options => $self->{option_results}->{command_options});
|
command_options => $self->{option_results}->{command_options});
|
||||||
|
|
||||||
|
|
||||||
my $total_volumes = 0;
|
my $total_volumes = 0;
|
||||||
my @volumes = split("\n",$stdout);
|
my @volumes = split("\n",$stdout);
|
||||||
foreach my $volume (@volumes) {
|
foreach my $volume (@volumes) {
|
||||||
if ($volume =~ /(\d+)\s+(\S+)\s+(\d+)\s+(\d+)\s+(\d+)\s+(\d+)\s+(\d+)\s+(\d+)\s+(\d+)/) {
|
if ($volume =~ /(\d+)\s+(\S+)\s+(\d+)\s+(\d+)\s+(\d+)\s+(\d+)\s+(\d+)\s+(\d+)\s+(\d+)/) {
|
||||||
$total_volumes++;
|
$total_volumes++;
|
||||||
my $volumeId = $1;
|
my $volumeId = $1;
|
||||||
my $volumeName = $2;
|
my $volumeName = $2;
|
||||||
my $volumeSize = $3 * 1024 * 1024;
|
my $volumeSize = $3 * 1024 * 1024;
|
||||||
my $volumeSnpSize = $4 * 1024 * 1024;
|
my $volumeSnpSize = $4 * 1024 * 1024;
|
||||||
my $volumeSnpUsed = $5 * 1024 * 1024;
|
my $volumeSnpUsed = $5 * 1024 * 1024;
|
||||||
my $volumeAdmSize = $6 * 1024 * 1024;
|
my $volumeAdmSize = $6 * 1024 * 1024;
|
||||||
my $volumeAdmUsed = $7 * 1024 * 1024;
|
my $volumeAdmUsed = $7 * 1024 * 1024;
|
||||||
my $volumeUsrSize = $8 * 1024 * 1024;
|
my $volumeUsrSize = $8 * 1024 * 1024;
|
||||||
my $volumeUsrUsed = $9 * 1024 * 1024;
|
my $volumeUsrUsed = $9 * 1024 * 1024;
|
||||||
my $volumeUsed = $volumeSnpUsed + $volumeAdmUsed + $volumeUsrUsed;
|
my $volumeUsed = $volumeSnpUsed + $volumeAdmUsed + $volumeUsrUsed;
|
||||||
my $volumeFree = $volumeSize - $volumeUsed;
|
my $volumeFree = $volumeSize - $volumeUsed;
|
||||||
my $percentUsed = ($volumeUsed / $volumeSize) * 100;
|
my $percentUsed = ($volumeUsed / $volumeSize) * 100;
|
||||||
my $percentFree = 100 - $percentUsed;
|
my $percentFree = 100 - $percentUsed;
|
||||||
|
|
||||||
my $string_to_compare = $volumeId;
|
my $string_to_compare = $volumeId;
|
||||||
if (defined($self->{option_results}->{name})) {
|
if (defined($self->{option_results}->{name})) {
|
||||||
$string_to_compare = $volumeName;
|
$string_to_compare = $volumeName;
|
||||||
}
|
}
|
||||||
|
|
||||||
next if (defined($self->{option_results}->{volume}) && defined($self->{option_results}->{regexp}) && ($string_to_compare !~ /$self->{option_results}->{volume}/i));
|
next if (defined($self->{option_results}->{volume}) && defined($self->{option_results}->{regexp}) && ($string_to_compare !~ /$self->{option_results}->{volume}/i));
|
||||||
next if (defined($self->{option_results}->{volume}) && !defined($self->{option_results}->{regexp}) && ($string_to_compare ne $self->{option_results}->{volume}));
|
next if (defined($self->{option_results}->{volume}) && !defined($self->{option_results}->{regexp}) && ($string_to_compare ne $self->{option_results}->{volume}));
|
||||||
|
|
||||||
my ($volumeSizeValue, $volumeSizeUnit) = $self->{perfdata}->change_bytes(value => $volumeSize);
|
my ($volumeSizeValue, $volumeSizeUnit) = $self->{perfdata}->change_bytes(value => $volumeSize);
|
||||||
my ($volumeUsedValue, $volumeUsedUnit) = $self->{perfdata}->change_bytes(value => $volumeUsed);
|
my ($volumeUsedValue, $volumeUsedUnit) = $self->{perfdata}->change_bytes(value => $volumeUsed);
|
||||||
my ($volumeFreeValue, $volumeFreeUnit) = $self->{perfdata}->change_bytes(value => $volumeFree);
|
my ($volumeFreeValue, $volumeFreeUnit) = $self->{perfdata}->change_bytes(value => $volumeFree);
|
||||||
my ($volumeSnpSizeValue, $volumeSnpSizeUnit) = $self->{perfdata}->change_bytes(value => $volumeSnpSize);
|
my ($volumeSnpSizeValue, $volumeSnpSizeUnit) = $self->{perfdata}->change_bytes(value => $volumeSnpSize);
|
||||||
my ($volumeSnpUsedValue, $volumeSnpUsedUnit) = $self->{perfdata}->change_bytes(value => $volumeSnpUsed);
|
my ($volumeSnpUsedValue, $volumeSnpUsedUnit) = $self->{perfdata}->change_bytes(value => $volumeSnpUsed);
|
||||||
my ($volumeAdmSizeValue, $volumeAdmSizeUnit) = $self->{perfdata}->change_bytes(value => $volumeAdmSize);
|
my ($volumeAdmSizeValue, $volumeAdmSizeUnit) = $self->{perfdata}->change_bytes(value => $volumeAdmSize);
|
||||||
my ($volumeAdmUsedValue, $volumeAdmUsedUnit) = $self->{perfdata}->change_bytes(value => $volumeAdmUsed);
|
my ($volumeAdmUsedValue, $volumeAdmUsedUnit) = $self->{perfdata}->change_bytes(value => $volumeAdmUsed);
|
||||||
my ($volumeUsrSizeValue, $volumeUsrSizeUnit) = $self->{perfdata}->change_bytes(value => $volumeUsrSize);
|
my ($volumeUsrSizeValue, $volumeUsrSizeUnit) = $self->{perfdata}->change_bytes(value => $volumeUsrSize);
|
||||||
my ($volumeUsrUsedValue, $volumeUsrUsedUnit) = $self->{perfdata}->change_bytes(value => $volumeUsrUsed);
|
my ($volumeUsrUsedValue, $volumeUsrUsedUnit) = $self->{perfdata}->change_bytes(value => $volumeUsrUsed);
|
||||||
|
|
||||||
$self->{output}->output_add(long_msg => sprintf("Volume %d '%s' Total: %.2f%s Used: %.2f%s (%.2f%%) Free: %.2f%s (%.2f%%) Usr: %.2f%s Adm: %.2f%s Snp: %.2f%s",
|
$self->{output}->output_add(long_msg => sprintf("Volume %d '%s' Total: %.2f%s Used: %.2f%s (%.2f%%) Free: %.2f%s (%.2f%%) Usr: %.2f%s Adm: %.2f%s Snp: %.2f%s",
|
||||||
$volumeId, $volumeName, $volumeSizeValue, $volumeSizeUnit,
|
|
||||||
$volumeUsedValue, $volumeUsedUnit, $percentUsed,
|
|
||||||
$volumeFreeValue, $volumeFreeUnit, $percentFree,
|
|
||||||
$volumeUsrUsedValue, $volumeUsrUsedUnit,
|
|
||||||
$volumeAdmUsedValue, $volumeAdmUsedUnit,
|
|
||||||
$volumeSnpUsedValue, $volumeSnpUsedUnit,));
|
|
||||||
my $exit = $self->{perfdata}->threshold_check(value => $percentUsed, threshold => [ { label => 'critical', 'exit_litteral' => 'critical' }, { label => 'warning', exit_litteral => 'warning' } ]);
|
|
||||||
if (!$self->{output}->is_status(value => $exit, compare => 'ok', litteral => 1)) {
|
|
||||||
$self->{output}->output_add(severity => $exit,
|
|
||||||
short_msg => sprintf("Volume %d '%s' Total: %.2f%s Used: %.2f%s (%.2f%%) Free: %.2f%s (%.2f%%) Usr: %.2f%s Adm: %.2f%s Snp: %.2f%s",
|
|
||||||
$volumeId, $volumeName, $volumeSizeValue, $volumeSizeUnit,
|
$volumeId, $volumeName, $volumeSizeValue, $volumeSizeUnit,
|
||||||
$volumeUsedValue, $volumeUsedUnit, $percentUsed,
|
$volumeUsedValue, $volumeUsedUnit, $percentUsed,
|
||||||
$volumeFreeValue, $volumeFreeUnit, $percentFree,
|
$volumeFreeValue, $volumeFreeUnit, $percentFree,
|
||||||
$volumeUsrUsedValue, $volumeUsrUsedUnit,
|
$volumeUsrUsedValue, $volumeUsrUsedUnit,
|
||||||
$volumeAdmUsedValue, $volumeAdmUsedUnit,
|
$volumeAdmUsedValue, $volumeAdmUsedUnit,
|
||||||
$volumeSnpUsedValue, $volumeSnpUsedUnit,));
|
$volumeSnpUsedValue, $volumeSnpUsedUnit,));
|
||||||
}
|
my $exit = $self->{perfdata}->threshold_check(value => $percentUsed, threshold => [ { label => 'critical', 'exit_litteral' => 'critical' }, { label => 'warning', exit_litteral => 'warning' } ]);
|
||||||
$self->{output}->perfdata_add(label => 'volume_'.$volumeName,
|
if (!$self->{output}->is_status(value => $exit, compare => 'ok', litteral => 1)) {
|
||||||
unit => 'B',
|
$self->{output}->output_add(severity => $exit,
|
||||||
value => $volumeUsed,
|
short_msg => sprintf("Volume %d '%s' Total: %.2f%s Used: %.2f%s (%.2f%%) Free: %.2f%s (%.2f%%) Usr: %.2f%s Adm: %.2f%s Snp: %.2f%s",
|
||||||
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning', total => $volumeSize, cast_int => 1),
|
$volumeId, $volumeName, $volumeSizeValue, $volumeSizeUnit,
|
||||||
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical', total => $volumeSize, cast_int => 1),
|
$volumeUsedValue, $volumeUsedUnit, $percentUsed,
|
||||||
min => 0,
|
$volumeFreeValue, $volumeFreeUnit, $percentFree,
|
||||||
max => $volumeSize);
|
$volumeUsrUsedValue, $volumeUsrUsedUnit,
|
||||||
}
|
$volumeAdmUsedValue, $volumeAdmUsedUnit,
|
||||||
}
|
$volumeSnpUsedValue, $volumeSnpUsedUnit,));
|
||||||
|
}
|
||||||
|
$self->{output}->perfdata_add(label => 'volume_'.$volumeName,
|
||||||
|
unit => 'B',
|
||||||
|
value => $volumeUsed,
|
||||||
|
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning', total => $volumeSize, cast_int => 1),
|
||||||
|
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical', total => $volumeSize, cast_int => 1),
|
||||||
|
min => 0,
|
||||||
|
max => $volumeSize);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
$self->{output}->output_add(severity => 'OK',
|
$self->{output}->output_add(severity => 'OK',
|
||||||
short_msg => 'All volumes are ok.');
|
short_msg => 'All volumes are ok.');
|
||||||
|
|
||||||
$self->{output}->display();
|
$self->{output}->display();
|
||||||
|
@ -48,13 +48,13 @@ sub new {
|
|||||||
$self->{version} = '1.0';
|
$self->{version} = '1.0';
|
||||||
$options{options}->add_options(arguments =>
|
$options{options}->add_options(arguments =>
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
"timeout:s" => { name => 'timeout', default => 30 },
|
"timeout:s" => { name => 'timeout', default => 30 },
|
||||||
"sudo" => { name => 'sudo' },
|
"sudo" => { name => 'sudo' },
|
||||||
"ssh-option:s@" => { name => 'ssh_option' },
|
"ssh-option:s@" => { name => 'ssh_option' },
|
||||||
"ssh-path:s" => { name => 'ssh_path' },
|
"ssh-path:s" => { name => 'ssh_path' },
|
||||||
"ssh-command:s" => { name => 'ssh_command', default => 'ssh' },
|
"ssh-command:s" => { name => 'ssh_command', default => 'ssh' },
|
||||||
"no-wsapi:s" => { name => 'no_wsapi' },
|
"no-wsapi:s" => { name => 'no_wsapi' },
|
||||||
});
|
});
|
||||||
$self->{no_wsapi} = undef;
|
$self->{no_wsapi} = undef;
|
||||||
return $self;
|
return $self;
|
||||||
@ -64,9 +64,9 @@ sub check_options {
|
|||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->SUPER::init(%options);
|
$self->SUPER::init(%options);
|
||||||
|
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
if (!defined($self->{option_results}->{hostname})) {
|
||||||
$self->{output}->add_option_msg(short_msg => "Need to specify a hostname.");
|
$self->{output}->add_option_msg(short_msg => "Need to specify a hostname.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (defined($self->{option_results}->{no_wsapi})) {
|
if (defined($self->{option_results}->{no_wsapi})) {
|
||||||
@ -81,8 +81,8 @@ sub check_options {
|
|||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{option_results}->{remote} = 1;
|
$self->{option_results}->{remote} = 1;
|
||||||
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},
|
||||||
command => "showwsapi",
|
command => "showwsapi",
|
||||||
@ -90,32 +90,32 @@ sub run {
|
|||||||
command_options => $self->{option_results}->{command_options});
|
command_options => $self->{option_results}->{command_options});
|
||||||
|
|
||||||
|
|
||||||
my @results = split("\n",$stdout);
|
my @results = split("\n",$stdout);
|
||||||
my $total_wsapi = 0;
|
my $total_wsapi = 0;
|
||||||
foreach my $result (@results) {
|
foreach my $result (@results) {
|
||||||
if ($result =~ /(\S+)\s+(\S+)\s+(\S+)\s+(\d+)\s+(\S+)\s+(\d+)\s+\S+/) {
|
if ($result =~ /(\S+)\s+(\S+)\s+(\S+)\s+(\d+)\s+(\S+)\s+(\d+)\s+\S+/) {
|
||||||
$total_wsapi++;
|
$total_wsapi++;
|
||||||
my $serviceStatus = $1;
|
my $serviceStatus = $1;
|
||||||
my $serviceState = $2;
|
my $serviceState = $2;
|
||||||
my $httpState = $3;
|
my $httpState = $3;
|
||||||
my $httpPort = $4;
|
my $httpPort = $4;
|
||||||
my $httpsState = $5;
|
my $httpsState = $5;
|
||||||
my $httpsPort = $6;
|
my $httpsPort = $6;
|
||||||
|
|
||||||
$self->{output}->output_add(long_msg => sprintf("WSAPI service is '%s' and '%s' [HTTP on port %d is %s] [HTTPS on port %d is %s]",
|
$self->{output}->output_add(long_msg => sprintf("WSAPI service is '%s' and '%s' [HTTP on port %d is %s] [HTTPS on port %d is %s]",
|
||||||
$serviceStatus, $serviceState, $httpPort, $httpState, $httpsPort ,$httpsState));
|
|
||||||
if ((lc($serviceStatus) ne 'enabled') || (lc($serviceState) ne 'active')){
|
|
||||||
$self->{output}->output_add(severity => 'critical',
|
|
||||||
short_msg => sprintf("WSAPI service is '%s' and '%s' [HTTP on port %d is %s] [HTTPS on port %d is %s]",
|
|
||||||
$serviceStatus, $serviceState, $httpPort, $httpState, $httpsPort ,$httpsState));
|
$serviceStatus, $serviceState, $httpPort, $httpState, $httpsPort ,$httpsState));
|
||||||
}
|
if ((lc($serviceStatus) ne 'enabled') || (lc($serviceState) ne 'active')){
|
||||||
}
|
$self->{output}->output_add(severity => 'critical',
|
||||||
}
|
short_msg => sprintf("WSAPI service is '%s' and '%s' [HTTP on port %d is %s] [HTTPS on port %d is %s]",
|
||||||
|
$serviceStatus, $serviceState, $httpPort, $httpState, $httpsPort ,$httpsState));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
$self->{output}->output_add(severity => 'OK',
|
$self->{output}->output_add(severity => 'OK',
|
||||||
short_msg => 'WSAPI service is ok.');
|
short_msg => 'WSAPI service is ok.');
|
||||||
|
|
||||||
if (defined($self->{option_results}->{no_wsapi}) && $total_wsapi == 0) {
|
if (defined($self->{option_results}->{no_wsapi}) && $total_wsapi == 0) {
|
||||||
$self->{output}->output_add(severity => $self->{no_wsapi},
|
$self->{output}->output_add(severity => $self->{no_wsapi},
|
||||||
short_msg => 'No WSAPI service is checked.');
|
short_msg => 'No WSAPI service is checked.');
|
||||||
}
|
}
|
||||||
@ -166,5 +166,3 @@ If total (with skipped) is 0. (Default: 'critical' returns).
|
|||||||
=back
|
=back
|
||||||
|
|
||||||
=cut
|
=cut
|
||||||
|
|
||||||
|
|
||||||
|
@ -48,15 +48,15 @@ sub new {
|
|||||||
$self->{version} = '1.0';
|
$self->{version} = '1.0';
|
||||||
%{$self->{modes}} = (
|
%{$self->{modes}} = (
|
||||||
'physicaldisk' => 'storage::hp::3par::7000::mode::physicaldisk',
|
'physicaldisk' => 'storage::hp::3par::7000::mode::physicaldisk',
|
||||||
'psu' => 'storage::hp::3par::7000::mode::psu',
|
'psu' => 'storage::hp::3par::7000::mode::psu',
|
||||||
'node' => 'storage::hp::3par::7000::mode::node',
|
'node' => 'storage::hp::3par::7000::mode::node',
|
||||||
'battery' => 'storage::hp::3par::7000::mode::battery',
|
'battery' => 'storage::hp::3par::7000::mode::battery',
|
||||||
'wsapi' => 'storage::hp::3par::7000::mode::wsapi',
|
'wsapi' => 'storage::hp::3par::7000::mode::wsapi',
|
||||||
'cim' => 'storage::hp::3par::7000::mode::cim',
|
'cim' => 'storage::hp::3par::7000::mode::cim',
|
||||||
'temperature' => 'storage::hp::3par::7000::mode::temperature',
|
'temperature' => 'storage::hp::3par::7000::mode::temperature',
|
||||||
'storage' => 'storage::hp::3par::7000::mode::storage',
|
'storage' => 'storage::hp::3par::7000::mode::storage',
|
||||||
'iscsi' => 'storage::hp::3par::7000::mode::iscsi',
|
'iscsi' => 'storage::hp::3par::7000::mode::iscsi',
|
||||||
'volume' => 'storage::hp::3par::7000::mode::volume',
|
'volume' => 'storage::hp::3par::7000::mode::volume',
|
||||||
);
|
);
|
||||||
|
|
||||||
return $self;
|
return $self;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user