mirror of
https://github.com/centreon/centreon-plugins.git
synced 2025-07-27 07:34:35 +02:00
update ups powerware environment
This commit is contained in:
parent
9e3dca91ab
commit
5959b78f08
@ -20,44 +20,39 @@
|
|||||||
|
|
||||||
package hardware::ups::powerware::snmp::mode::environment;
|
package hardware::ups::powerware::snmp::mode::environment;
|
||||||
|
|
||||||
use base qw(centreon::plugins::mode);
|
use base qw(centreon::plugins::templates::counter);
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::values;
|
|
||||||
|
|
||||||
my $maps_counters = {
|
sub set_counters {
|
||||||
temperature => { class => 'centreon::plugins::values', obj => undef,
|
my ($self, %options) = @_;
|
||||||
set => {
|
|
||||||
key_values => [
|
$self->{maps_counters_type} = [
|
||||||
{ name => 'temperature', no_value => 0, },
|
{ name => 'global', type => 0, skipped_code => { -10 => 1 } }
|
||||||
],
|
];
|
||||||
output_template => 'Ambiant Temperature: %.2f C', output_error_template => 'Ambiant Temperature: %s',
|
|
||||||
|
$self->{maps_counters}->{global} = [
|
||||||
|
{ label => 'temperature', set => {
|
||||||
|
key_values => [ { name => 'temperature' } ],
|
||||||
|
output_template => 'Ambiant Temperature: %.2f C',
|
||||||
perfdatas => [
|
perfdatas => [
|
||||||
{ value => 'temperature_absolute', label => 'temperature', template => '%.2f',
|
{ label => 'temperature', value => 'temperature_absolute', template => '%.2f',
|
||||||
unit => 'C' },
|
min => 0, unit => 'C' },
|
||||||
],
|
],
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
humidity => { class => 'centreon::plugins::values', obj => undef,
|
{ label => 'total-connections', set => {
|
||||||
set => {
|
key_values => [ { name => 'humidity' } ],
|
||||||
key_values => [
|
output_template => 'Humidity: %.2f %%',
|
||||||
{ name => 'humidity', no_value => 0 },
|
|
||||||
],
|
|
||||||
output_template => 'Humidity: %.2f %%', output_error_template => 'Humidity: %s',
|
|
||||||
perfdatas => [
|
perfdatas => [
|
||||||
{ value => 'humidity_absolute', label => 'humidity', template => '%.2f',
|
{ label => 'humidity', value => 'humidity_absolute', template => '%.2f',
|
||||||
unit => '%', min => 0, max => 100 },
|
min => 0, max => 100, unit => '%' },
|
||||||
],
|
],
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
};
|
];
|
||||||
|
}
|
||||||
my $oid_xupsEnvironment = '.1.3.6.1.4.1.534.1.6';
|
|
||||||
my $oid_xupsEnvAmbientTemp = '.1.3.6.1.4.1.534.1.6.1.0'; # in degree centigrade
|
|
||||||
my $oid_xupsEnvAmbientLowerLimit = '.1.3.6.1.4.1.534.1.6.2.0';
|
|
||||||
my $oid_xupsEnvAmbientUpperLimit = '.1.3.6.1.4.1.534.1.6.3.0';
|
|
||||||
my $oid_xupsEnvAmbientHumidity = '.1.3.6.1.4.1.534.1.6.4.0'; # in %
|
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
my ($class, %options) = @_;
|
my ($class, %options) = @_;
|
||||||
@ -69,100 +64,48 @@ sub new {
|
|||||||
{
|
{
|
||||||
});
|
});
|
||||||
|
|
||||||
$self->{instance_selected} = {};
|
|
||||||
|
|
||||||
foreach (keys %{$maps_counters}) {
|
|
||||||
$options{options}->add_options(arguments => {
|
|
||||||
'warning-' . $_ . ':s' => { name => 'warning-' . $_ },
|
|
||||||
'critical-' . $_ . ':s' => { name => 'critical-' . $_ },
|
|
||||||
});
|
|
||||||
my $class = $maps_counters->{$_}->{class};
|
|
||||||
$maps_counters->{$_}->{obj} = $class->new(output => $self->{output}, perfdata => $self->{perfdata},
|
|
||||||
label => $_);
|
|
||||||
$maps_counters->{$_}->{obj}->set(%{$maps_counters->{$_}->{set}});
|
|
||||||
}
|
|
||||||
|
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
sub check_options {
|
|
||||||
my ($self, %options) = @_;
|
|
||||||
$self->SUPER::init(%options);
|
|
||||||
|
|
||||||
foreach (keys %{$maps_counters}) {
|
|
||||||
$maps_counters->{$_}->{obj}->init(option_results => $self->{option_results});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
sub manage_counters {
|
|
||||||
my ($self, %options) = @_;
|
|
||||||
|
|
||||||
foreach (sort keys %{$options{maps_counters}}) {
|
|
||||||
$options{maps_counters}->{$_}->{obj}->set(instance => $options{instance});
|
|
||||||
|
|
||||||
my ($value_check) = $options{maps_counters}->{$_}->{obj}->execute(values => $self->{instance_selected}->{$options{instance}});
|
|
||||||
|
|
||||||
# We don't want to display no value
|
|
||||||
next if ($value_check == -10);
|
|
||||||
if ($value_check != 0) {
|
|
||||||
next;
|
|
||||||
}
|
|
||||||
my $exit = $options{maps_counters}->{$_}->{obj}->threshold_check();
|
|
||||||
|
|
||||||
my $output = $options{maps_counters}->{$_}->{obj}->output();
|
|
||||||
|
|
||||||
$self->{output}->output_add(severity => $exit,
|
|
||||||
short_msg => $output
|
|
||||||
);
|
|
||||||
|
|
||||||
$options{maps_counters}->{$_}->{obj}->perfdata();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
sub run {
|
|
||||||
my ($self, %options) = @_;
|
|
||||||
$self->{snmp} = $options{snmp};
|
|
||||||
|
|
||||||
$self->manage_selection();
|
|
||||||
|
|
||||||
$self->manage_counters(instance => 'ambiant', maps_counters => $maps_counters);
|
|
||||||
|
|
||||||
$self->{output}->display();
|
|
||||||
$self->{output}->exit();
|
|
||||||
}
|
|
||||||
|
|
||||||
sub manage_selection {
|
sub manage_selection {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
my $values_ok = 0;
|
|
||||||
$self->{instance_selected}->{ambiant} = {};
|
|
||||||
|
|
||||||
$self->{results} = $self->{snmp}->get_table(oid => $oid_xupsEnvironment,
|
my $oids = {
|
||||||
nothing_quit => 1);
|
xupsEnvAmbientTemp => '.1.3.6.1.4.1.534.1.6.1.0',
|
||||||
|
xupsEnvAmbientLowerLimit => '.1.3.6.1.4.1.534.1.6.2.0',
|
||||||
|
xupsEnvAmbientUpperLimit => '.1.3.6.1.4.1.534.1.6.3.0',
|
||||||
|
xupsEnvAmbientHumidity => '.1.3.6.1.4.1.534.1.6.4.0',
|
||||||
|
xupsEnvRemoteTemp => '.1.3.6.1.4.1.534.1.6.5.0',
|
||||||
|
xupsEnvRemoteHumidity => '.1.3.6.1.4.1.534.1.6.6.0',
|
||||||
|
xupsEnvRemoteTempLowerLimit => '.1.3.6.1.4.1.534.1.6.9.0',
|
||||||
|
xupsEnvRemoteTempUpperLimit => '.1.3.6.1.4.1.534.1.6.10.0',
|
||||||
|
xupsEnvRemoteHumidityLowerLimit => '.1.3.6.1.4.1.534.1.6.11.0',
|
||||||
|
xupsEnvRemoteHumidityUpperLimit => '.1.3.6.1.4.1.534.1.6.11.0',
|
||||||
|
};
|
||||||
|
my $snmp_result = $options{snmp}->get_leef(oids => [
|
||||||
|
values %$oids
|
||||||
|
], nothing_quit => 1);
|
||||||
|
|
||||||
if (defined($self->{results}->{$oid_xupsEnvAmbientTemp}) && $self->{results}->{$oid_xupsEnvAmbientTemp} ne '' &&
|
$self->{global} = {};
|
||||||
$self->{results}->{$oid_xupsEnvAmbientTemp} != 0) {
|
$self->{global}->{temperature} = defined($snmp_result->{$oids->{xupsEnvAmbientTemp}}) && $snmp_result->{$oids->{xupsEnvAmbientTemp}} ne '' && $snmp_result->{$oids->{xupsEnvAmbientTemp}} != 0 ?
|
||||||
$self->{instance_selected}->{ambiant}->{temperature} = $self->{results}->{$oid_xupsEnvAmbientTemp};
|
$snmp_result->{$oids->{xupsEnvAmbientTemp}} :
|
||||||
$values_ok++;
|
(defined($snmp_result->{$oids->{xupsEnvRemoteTemp}}) && $snmp_result->{$oids->{xupsEnvRemoteTemp}} ne '' && $snmp_result->{$oids->{xupsEnvRemoteTemp}} != 0 ?
|
||||||
}
|
$snmp_result->{$oids->{xupsEnvRemoteTemp}} : undef);
|
||||||
if (defined($self->{results}->{$oid_xupsEnvAmbientHumidity}) && $self->{results}->{$oid_xupsEnvAmbientHumidity} ne '' &&
|
$self->{global}->{humidity} = defined($snmp_result->{$oids->{xupsEnvAmbientHumidity}}) && $snmp_result->{$oids->{xupsEnvAmbientHumidity}} ne '' && $snmp_result->{$oids->{xupsEnvAmbientHumidity}} != 0 ?
|
||||||
$self->{results}->{$oid_xupsEnvAmbientHumidity} != 0) {
|
$snmp_result->{$oids->{xupsEnvAmbientHumidity}} :
|
||||||
$self->{instance_selected}->{ambiant}->{humidity} = $self->{results}->{$oid_xupsEnvAmbientHumidity};
|
(defined($snmp_result->{$oids->{xupsEnvRemoteHumidity}}) && $snmp_result->{$oids->{xupsEnvRemoteHumidity}} ne '' && $snmp_result->{$oids->{xupsEnvRemoteHumidity}} != 0 ?
|
||||||
$values_ok++;
|
$snmp_result->{$oids->{xupsEnvRemoteHumidity}} : undef);
|
||||||
}
|
|
||||||
|
|
||||||
if (!defined($self->{option_results}->{'critical-temperature'}) || $self->{option_results}->{'critical-temperature'} eq '') {
|
if (!defined($self->{option_results}->{'critical-temperature'}) || $self->{option_results}->{'critical-temperature'} eq '') {
|
||||||
my $crit_val = '';
|
my $crit_val = '';
|
||||||
$crit_val = $self->{results}->{$oid_xupsEnvAmbientLowerLimit} . ':' if (defined($self->{results}->{$oid_xupsEnvAmbientLowerLimit}) &&
|
$crit_val = $snmp_result->{$oids->{xupsEnvAmbientLowerLimit}} . ':'
|
||||||
$self->{results}->{$oid_xupsEnvAmbientLowerLimit} ne '');
|
if (defined($snmp_result->{$oids->{xupsEnvAmbientLowerLimit}}) &&
|
||||||
$crit_val .= $self->{results}->{$oid_xupsEnvAmbientUpperLimit} if (defined($self->{results}->{$oid_xupsEnvAmbientUpperLimit}) &&
|
$snmp_result->{$oids->{xupsEnvAmbientLowerLimit}} ne '' && $snmp_result->{$oids->{xupsEnvAmbientLowerLimit}} != 0);
|
||||||
$self->{results}->{$oid_xupsEnvAmbientUpperLimit} ne '' && $self->{results}->{$oid_xupsEnvAmbientUpperLimit} ne 0);
|
$crit_val .= $snmp_result->{$oids->{xupsEnvAmbientUpperLimit}}
|
||||||
|
if (defined($snmp_result->{$oids->{xupsEnvAmbientUpperLimit}}) &&
|
||||||
|
$snmp_result->{$oids->{xupsEnvAmbientUpperLimit}} ne '' && $snmp_result->{$oids->{xupsEnvAmbientUpperLimit}} != 0);
|
||||||
$self->{perfdata}->threshold_validate(label => 'critical-temperature', value => $crit_val);
|
$self->{perfdata}->threshold_validate(label => 'critical-temperature', value => $crit_val);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($values_ok == 0) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Cannot get temperature and humidity values.");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
1;
|
1;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user