2015-06-18 13:40:15 +02:00
|
|
|
#
|
2020-01-06 15:19:23 +01:00
|
|
|
# Copyright 2020 Centreon (http://www.centreon.com/)
|
2015-07-21 11:51:02 +02:00
|
|
|
#
|
|
|
|
# Centreon is a full-fledged industry-strength solution that meets
|
|
|
|
# the needs in IT infrastructure and application monitoring for
|
|
|
|
# service performance.
|
|
|
|
#
|
|
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
# you may not use this file except in compliance with the License.
|
|
|
|
# You may obtain a copy of the License at
|
|
|
|
#
|
|
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
#
|
|
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
# See the License for the specific language governing permissions and
|
|
|
|
# limitations under the License.
|
|
|
|
#
|
2015-06-18 13:40:15 +02:00
|
|
|
|
|
|
|
package network::hirschmann::standard::snmp::mode::components::psu;
|
|
|
|
|
|
|
|
use strict;
|
|
|
|
use warnings;
|
|
|
|
|
|
|
|
my %map_psu_status = (
|
|
|
|
1 => 'ok',
|
|
|
|
2 => 'failed',
|
|
|
|
3 => 'notInstalled',
|
|
|
|
4 => 'unknown',
|
|
|
|
);
|
2019-05-24 17:09:32 +02:00
|
|
|
my %map_psu_state = (
|
|
|
|
1 => 'error', 2 => 'ignore',
|
|
|
|
);
|
|
|
|
my %map_psid = (
|
|
|
|
1 => 9, # hmDevMonSensePS1State
|
|
|
|
2 => 10, # hmDevMonSensePS2State
|
|
|
|
3 => 14, # hmDevMonSensePS3State
|
|
|
|
4 => 15, # hmDevMonSensePS4State
|
|
|
|
5 => 17, # hmDevMonSensePS5State
|
|
|
|
6 => 18, # hmDevMonSensePS6State
|
|
|
|
7 => 19, # hmDevMonSensePS7State
|
|
|
|
8 => 20, # hmDevMonSensePS8State
|
|
|
|
);
|
2015-06-18 13:40:15 +02:00
|
|
|
|
|
|
|
# In MIB 'hmpriv.mib'
|
|
|
|
my $mapping = {
|
2018-05-14 16:04:36 +02:00
|
|
|
hmPSState => { oid => '.1.3.6.1.4.1.248.14.1.2.1.3', map => \%map_psu_status },
|
2015-06-18 13:40:15 +02:00
|
|
|
};
|
2019-05-24 17:09:32 +02:00
|
|
|
my $oid_hmDevMonConfigEntry = '.1.3.6.1.4.1.248.14.2.12.3.1';
|
2015-06-18 13:40:15 +02:00
|
|
|
|
|
|
|
sub load {
|
2016-01-08 14:29:55 +01:00
|
|
|
my ($self) = @_;
|
2015-06-18 13:40:15 +02:00
|
|
|
|
2019-05-24 17:09:32 +02:00
|
|
|
push @{$self->{request}}, { oid => $mapping->{hmPSState}->{oid} }, { oid => $oid_hmDevMonConfigEntry };
|
2015-06-18 13:40:15 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
sub check {
|
|
|
|
my ($self) = @_;
|
|
|
|
|
|
|
|
$self->{output}->output_add(long_msg => "Checking power supplies");
|
2019-05-24 17:09:32 +02:00
|
|
|
$self->{components}->{psu} = { name => 'psus', total => 0, skip => 0 };
|
2016-01-08 14:29:55 +01:00
|
|
|
return if ($self->check_filter(section => 'psu'));
|
2015-06-18 13:40:15 +02:00
|
|
|
|
|
|
|
foreach my $oid ($self->{snmp}->oid_lex_sort(keys %{$self->{results}->{$mapping->{hmPSState}->{oid}}})) {
|
2019-05-24 17:09:32 +02:00
|
|
|
next if ($oid !~ /^$mapping->{hmPSState}->{oid}\.(\d+)\.(\d+)$/);
|
|
|
|
my $instance = $1 . '.' . $2;
|
|
|
|
my ($sysid, $psid) = ($1, $2);
|
2015-06-18 13:40:15 +02:00
|
|
|
my $result = $self->{snmp}->map_instance(mapping => $mapping, results => $self->{results}->{$mapping->{hmPSState}->{oid}}, instance => $instance);
|
|
|
|
|
2019-05-24 17:09:32 +02:00
|
|
|
if (defined($map_psid{$psid}) &&
|
|
|
|
defined($self->{results}->{$oid_hmDevMonConfigEntry}->{$oid_hmDevMonConfigEntry . '.' . $map_psid{$psid} . '.' . $sysid})) {
|
|
|
|
my $state = $map_psu_state{$self->{results}->{$oid_hmDevMonConfigEntry}->{$oid_hmDevMonConfigEntry . '.' . $map_psid{$psid} . '.' . $sysid}};
|
|
|
|
$result->{hmPSState} = 'ignore' if ($state eq 'ignore');
|
|
|
|
}
|
|
|
|
|
2016-01-08 14:29:55 +01:00
|
|
|
next if ($self->check_filter(section => 'psu', instance => $instance));
|
2015-06-18 13:40:15 +02:00
|
|
|
next if ($result->{hmPSState} =~ /notInstalled/i &&
|
2018-05-14 16:04:36 +02:00
|
|
|
$self->absent_problem(section => 'psu', instance => $instance));
|
2015-06-18 13:40:15 +02:00
|
|
|
$self->{components}->{psu}->{total}++;
|
|
|
|
|
|
|
|
$self->{output}->output_add(long_msg => sprintf("Power supply '%s' status is %s [instance: %s].",
|
|
|
|
$instance, $result->{hmPSState},
|
|
|
|
$instance
|
|
|
|
));
|
|
|
|
my $exit = $self->get_severity(section => 'psu', value => $result->{hmPSState});
|
|
|
|
if (!$self->{output}->is_status(value => $exit, compare => 'ok', litteral => 1)) {
|
|
|
|
$self->{output}->output_add(severity => $exit,
|
|
|
|
short_msg => sprintf("Power supply '%s' status is %s",
|
|
|
|
$instance, $result->{hmPSState}));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-05-24 17:09:32 +02:00
|
|
|
1;
|