centreon-plugins/network/juniper/common/junos/mode/components/operating.pm

72 lines
2.9 KiB
Perl
Raw Normal View History

#
2019-01-09 09:57:11 +01:00
# Copyright 2019 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.
#
package network::juniper::common::junos::mode::components::operating;
use strict;
use warnings;
my %map_operating_states = (
1 => 'unknown',
2 => 'running',
3 => 'ready',
4 => 'reset',
5 => 'runningAtFullSpeed',
6 => 'down',
7 => 'standby',
);
sub check {
my ($self) = @_;
$self->{output}->output_add(long_msg => "Checking operatings");
2019-05-22 14:23:58 +02:00
$self->{components}->{operating} = { name => 'operatings', total => 0, skip => 0 };
return if ($self->check_filter(section => 'operating'));
my $mapping = {
jnxOperatingState => { oid => '.1.3.6.1.4.1.2636.3.1.13.1.6', map => \%map_operating_states },
};
2019-07-29 10:27:32 +02:00
my $results = $self->{snmp}->get_table(oid => $self->{oids_operating}->{jnxOperatingEntry},
start => $mapping->{jnxOperatingState}->{oid}, end => $mapping->{jnxOperatingState}->{oid});
2019-07-29 10:27:32 +02:00
foreach my $instance (sort $self->get_instances(oid_entry => $self->{oids_operating}->{jnxOperatingEntry},
oid_name => $self->{oids_operating}->{jnxOperatingDescr})) {
my $result = $self->{snmp}->map_instance(mapping => $mapping, results => $results, instance => $instance);
2019-07-29 10:27:32 +02:00
my $desc = $self->get_cache(oid_entry => $self->{oids_operating}->{jnxOperatingEntry},
oid_name => $self->{oids_operating}->{jnxOperatingDescr}, instance => $instance);
2019-05-22 14:23:58 +02:00
next if ($self->check_filter(section => 'operating', instance => $instance, name => $desc));
$self->{components}->{operating}->{total}++;
2019-05-22 14:23:58 +02:00
$self->{output}->output_add(long_msg => sprintf("operating '%s' state is %s [instance: %s]",
$desc, $result->{jnxOperatingState}, $instance));
2019-07-29 10:27:32 +02:00
my $exit = $self->get_severity(section => 'operating', instance => $instance,
value => $result->{jnxOperatingState});
if (!$self->{output}->is_status(value => $exit, compare => 'ok', litteral => 1)) {
$self->{output}->output_add(severity => $exit,
short_msg => sprintf("Operating '%s' state is %s",
$desc, $result->{jnxOperatingState}));
}
}
}
2019-05-22 14:23:58 +02:00
1;