From 2856af1d69d4623bcf4b7570ca327ac4c45cf797 Mon Sep 17 00:00:00 2001 From: Fabien THEPAUT Date: Fri, 28 Aug 2015 16:45:05 +0200 Subject: [PATCH 1/2] Add pxb-role mode --- network/alcatel/oxe/snmp/mode/pbxrole.pm | 136 +++++++++++++++++++++++ network/alcatel/oxe/snmp/plugin.pm | 1 + 2 files changed, 137 insertions(+) create mode 100644 network/alcatel/oxe/snmp/mode/pbxrole.pm diff --git a/network/alcatel/oxe/snmp/mode/pbxrole.pm b/network/alcatel/oxe/snmp/mode/pbxrole.pm new file mode 100644 index 000000000..47f60fff2 --- /dev/null +++ b/network/alcatel/oxe/snmp/mode/pbxrole.pm @@ -0,0 +1,136 @@ +# +# Copyright 2015 Centreon (http://www.centreon.com/) +# +# 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::alcatel::oxe::snmp::mode::pbxrole; + +use base qw(centreon::plugins::mode); + +use strict; +use warnings; + +my $thresholds = { + role => [ + ['indeterminate', 'UNKNOWN'], + ['main', 'OK'], + ['stand-by', 'OK'], + ['active-pcs', 'CRITICAL'], + ['inactive-pcs', 'CRITICAL'], + ], +}; +my %map_role = ( + 0 => 'indeterminate', + 1 => 'main', + 2 => 'stand-by', + 3 => 'active-pcs', + 4 => 'inactive-pcs', +); + +sub new { + my ($class, %options) = @_; + my $self = $class->SUPER::new(package => __PACKAGE__, %options); + bless $self, $class; + + $self->{version} = '1.0'; + $options{options}->add_options(arguments => + { + "threshold-overload:s@" => { name => 'threshold_overload' }, + }); + return $self; +} + +sub check_options { + my ($self, %options) = @_; + $self->SUPER::init(%options); + + $self->{overload_th} = {}; + foreach my $val (@{$self->{option_results}->{threshold_overload}}) { + if ($val !~ /^(.*?),(.*?),(.*)$/) { + $self->{output}->add_option_msg(short_msg => "Wrong threshold-overload option '" . $val . "'."); + $self->{output}->option_exit(); + } + my ($section, $status, $filter) = ($1, $2, $3); + if ($self->{output}->is_litteral_status(status => $status) == 0) { + $self->{output}->add_option_msg(short_msg => "Wrong threshold-overload status '" . $val . "'."); + $self->{output}->option_exit(); + } + $self->{overload_th}->{$section} = [] if (!defined($self->{overload_th}->{$section})); + push @{$self->{overload_th}->{$section}}, {filter => $filter, status => $status}; + } +} + +sub run { + my ($self, %options) = @_; + $self->{snmp} = $options{snmp}; + + # Seems to have a bug to get '.0' + my $oid_pbxRole = '.1.3.6.1.4.1.637.64.4400.1.4.0'; + my $oid_pbxRole_buggy = '.1.3.6.1.4.1.637.64.4400.1.4'; + my $result = $self->{snmp}->get_leef(oids => [$oid_pbxRole, $oid_pbxRole_buggy], nothing_quit => 1); + + my $pbx_role = defined($result->{$oid_pbxRole}) ? $map_role{$result->{$oid_pbxRole}} : $map_role{$result->{$oid_pbxRole_buggy}}; + my $exit = $self->get_severity(section => 'role', value => $pbx_role); + $self->{output}->output_add(severity => $exit, + short_msg => sprintf("PBX Role is '%s'", $pbx_role)); + + $self->{output}->display(); + $self->{output}->exit(); +} + +sub get_severity { + my ($self, %options) = @_; + my $status = 'UNKNOWN'; # default + + if (defined($self->{overload_th}->{$options{section}})) { + foreach (@{$self->{overload_th}->{$options{section}}}) { + if ($options{value} =~ /$_->{filter}/i) { + $status = $_->{status}; + return $status; + } + } + } + foreach (@{$thresholds->{$options{section}}}) { + if ($options{value} =~ /$$_[0]/i) { + $status = $$_[1]; + return $status; + } + } + + return $status; +} + +1; + +__END__ + +=head1 MODE + +Check PBX Role. + +=over 8 + +=item B<--threshold-overload> + +Set to overload default threshold values (syntax: section,status,regexp) +It used before default thresholds (order stays). +Example: --threshold-overload='state,CRITICAL,^(?!(normal)$)' + +=back + +=cut diff --git a/network/alcatel/oxe/snmp/plugin.pm b/network/alcatel/oxe/snmp/plugin.pm index 747ddf7d4..7e75a3b80 100644 --- a/network/alcatel/oxe/snmp/plugin.pm +++ b/network/alcatel/oxe/snmp/plugin.pm @@ -35,6 +35,7 @@ sub new { 'domain-usage' => 'network::alcatel::oxe::snmp::mode::domainusage', 'memory' => 'snmp_standard::mode::memory', 'pbx-state' => 'network::alcatel::oxe::snmp::mode::pbxstate', + 'pbx-role' => 'network::alcatel::oxe::snmp::mode::pbxrole', 'storage' => 'snmp_standard::mode::storage', 'swap' => 'snmp_standard::mode::swap', ); From 61d1536e8013d7cbe596a20acfe3645cfaed9811 Mon Sep 17 00:00:00 2001 From: THEPAUT Date: Fri, 28 Aug 2015 16:47:37 +0200 Subject: [PATCH 2/2] Update plugin.pm --- network/alcatel/oxe/snmp/plugin.pm | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/network/alcatel/oxe/snmp/plugin.pm b/network/alcatel/oxe/snmp/plugin.pm index 7e75a3b80..ca828376b 100644 --- a/network/alcatel/oxe/snmp/plugin.pm +++ b/network/alcatel/oxe/snmp/plugin.pm @@ -35,7 +35,7 @@ sub new { 'domain-usage' => 'network::alcatel::oxe::snmp::mode::domainusage', 'memory' => 'snmp_standard::mode::memory', 'pbx-state' => 'network::alcatel::oxe::snmp::mode::pbxstate', - 'pbx-role' => 'network::alcatel::oxe::snmp::mode::pbxrole', + 'pbx-role' => 'network::alcatel::oxe::snmp::mode::pbxrole', 'storage' => 'snmp_standard::mode::storage', 'swap' => 'snmp_standard::mode::swap', );