diff --git a/centreon-plugins/network/cisco/common/mode/environment.pm b/centreon-plugins/network/cisco/common/mode/environment.pm index 0fb57d760..cae3feb1e 100644 --- a/centreon-plugins/network/cisco/common/mode/environment.pm +++ b/centreon-plugins/network/cisco/common/mode/environment.pm @@ -79,7 +79,7 @@ sub new { $self->{version} = '1.0'; $options{options}->add_options(arguments => { - "exclude" => { name => 'exclude' }, + "exclude:s" => { name => 'exclude' }, }); return $self; @@ -296,4 +296,4 @@ Exclude some parts (comma seperated list) (Example: --exclude=temperatures,psu). =back =cut - \ No newline at end of file + diff --git a/centreon-plugins/network/cisco/common/mode/memory.pm b/centreon-plugins/network/cisco/common/mode/memory.pm index 23b9fab5f..21c676922 100644 --- a/centreon-plugins/network/cisco/common/mode/memory.pm +++ b/centreon-plugins/network/cisco/common/mode/memory.pm @@ -70,44 +70,31 @@ sub check_options { } } -sub run { +sub check_table_memory { my ($self, %options) = @_; - # $options{snmp} = snmp object - $self->{snmp} = $options{snmp}; - my $oid_ciscoMemoryPoolEntry = '.1.3.6.1.4.1.9.9.48.1.1.1'; - my $oid_ciscoMemoryPoolName = '.1.3.6.1.4.1.9.9.48.1.1.1.2'; - my $oid_ciscoMemoryPoolUsed = '.1.3.6.1.4.1.9.9.48.1.1.1.5'; # in B - my $oid_ciscoMemoryPoolFree = '.1.3.6.1.4.1.9.9.48.1.1.1.6'; # in B - my $result = $self->{snmp}->get_table(oid => $oid_ciscoMemoryPoolEntry, nothing_quit => 1); - - $self->{output}->output_add(severity => 'OK', - short_msg => 'All pool memories are ok.'); - - foreach my $oid (keys %$result) { - next if ($oid !~ /^$oid_ciscoMemoryPoolName/); + my $checked = 0; + foreach my $oid (keys %{$self->{results}->{$options{entry}}}) { + next if ($oid !~ /^$options{poolName}/); $oid =~ /\.([0-9]+)$/; - - if (defined($self->{option_results}->{filter_pool}) && $self->{option_results}->{filter_pool} ne '' && - $result->{$oid} !~ /$self->{option_results}->{filter_pool}/) { - $self->{output}->output_add(long_msg => "Skipping pool '" . $result->{$oid} . "'."); - next; - } - my $instance = $1; - my $memory_name = $result->{$oid}; - my $memory_used = $result->{$oid_ciscoMemoryPoolUsed . '.' . $instance}; - my $memory_free =$result->{$oid_ciscoMemoryPoolFree . '.' . $instance}; + my $memory_name = $self->{results}->{$options{entry}}->{$oid}; + my $memory_used = $self->{results}->{$options{entry}}->{$options{poolUsed} . '.' . $instance}; + my $memory_free = $self->{results}->{$options{entry}}->{$options{poolFree} . '.' . $instance}; + next if ($memory_name eq ''); + + $checked = 1; + my $total_size = $memory_used + $memory_free; my $prct_used = $memory_used * 100 / $total_size; my $prct_free = 100 - $prct_used; - + my $exit = $self->{perfdata}->threshold_check(value => $prct_used, threshold => [ { label => 'critical', 'exit_litteral' => 'critical' }, { label => 'warning', exit_litteral => 'warning' } ]); my ($total_value, $total_unit) = $self->{perfdata}->change_bytes(value => $total_size); my ($used_value, $used_unit) = $self->{perfdata}->change_bytes(value => $memory_used); my ($free_value, $free_unit) = $self->{perfdata}->change_bytes(value => $memory_free); - + $self->{output}->output_add(long_msg => sprintf("Memory '%s' Total: %s Used: %s (%.2f%%) Free: %s (%.2f%%)", $memory_name, $total_value . " " . $total_unit, $used_value . " " . $used_unit, $prct_used, @@ -119,7 +106,7 @@ sub run { $used_value . " " . $used_unit, $prct_used, $free_value . " " . $free_unit, $prct_free)); } - + $self->{output}->perfdata_add(label => "used_" . $memory_name, value => $memory_used, warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning', total => $total_size), @@ -127,8 +114,76 @@ sub run { min => 0, max => $total_size); } + return $checked; +} + +sub check_percent_memory { + my ($self, %options) = @_; + + my $checked = 0; + foreach my $oid (keys %{$self->{results}->{$options{entry}}}) { + next if ($oid !~ /^$options{memUsage}/); + $oid =~ /\.([0-9]+)$/; + my $instance = $1; + my $memory_usage = $self->{results}->{$options{entry}}->{$oid}; + + next if ($memory_usage eq ''); + + $checked = 1; + + my $exit = $self->{perfdata}->threshold_check(value => $memory_usage, + 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("Memory used : %.2f%%", $memory_usage)); + } + + $self->{output}->perfdata_add(label => "utilization", + value => $memory_usage, + unit => "%", + warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning'), + critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical'), + min => 0, max => 100); + } + + return $checked; +} + +sub run { + my ($self, %options) = @_; + # $options{snmp} = snmp object + $self->{snmp} = $options{snmp}; + + my $oid_ciscoMemoryPoolEntry = '.1.3.6.1.4.1.9.9.48.1.1.1'; + my $oid_ciscoMemoryPoolName = '.1.3.6.1.4.1.9.9.48.1.1.1.2'; + my $oid_ciscoMemoryPoolUsed = '.1.3.6.1.4.1.9.9.48.1.1.1.5'; # in B + my $oid_ciscoMemoryPoolFree = '.1.3.6.1.4.1.9.9.48.1.1.1.6'; # in B + + # OIDs for Nexus + my $oid_cseSysMemoryEntry = '.1.3.6.1.4.1.9.9.305.1.1'; + my $oid_cseSysMemoryUtilization = '.1.3.6.1.4.1.9.9.305.1.1.2'; + + $self->{results} = $self->{snmp}->get_multiple_table(oids => [ + { oid => $oid_ciscoMemoryPoolEntry, + start => $oid_ciscoMemoryPoolName, end => $oid_ciscoMemoryPoolFree + }, + { oid => $oid_cseSysMemoryEntry, + start => $oid_cseSysMemoryUtilization, end => $oid_cseSysMemoryUtilization }], + nothing_quit => 1); + + $self->{output}->output_add(severity => 'OK', + short_msg => 'Memory is ok.'); + + if (!$self->check_table_memory(entry => $oid_ciscoMemoryPoolEntry, poolName => $oid_ciscoMemoryPoolName, poolUsed => $oid_ciscoMemoryPoolUsed, poolFree => $oid_ciscoMemoryPoolFree) + && !$self->check_percent_memory(entry => $oid_cseSysMemoryEntry, memUsage => $oid_cseSysMemoryUtilization) + ) { + $self->{output}->output_add(severity => 'UNKNOWN', + short_msg => sprintf("Cannot find Memory informations.")); + } + $self->{output}->display(); $self->{output}->exit(); + } 1; @@ -137,7 +192,7 @@ __END__ =head1 MODE -Check memory usage (CISCO-MEMORY-POOL-MIB). +Check memory usage (CISCO-MEMORY-POOL-MIB and CISCO-SYSTEM-EXT-MIB). =over 8 @@ -156,4 +211,4 @@ Filter pool to check (can use regexp). =back =cut - \ No newline at end of file + diff --git a/centreon-plugins/network/cisco/nexus/5000/mode/environment.pm b/centreon-plugins/network/cisco/nexus/5000/mode/environment.pm new file mode 100644 index 000000000..9d0399ff8 --- /dev/null +++ b/centreon-plugins/network/cisco/nexus/5000/mode/environment.pm @@ -0,0 +1,305 @@ +################################################################################ +# Copyright 2005-2013 MERETHIS +# Centreon is developped by : Julien Mathis and Romain Le Merlus under +# GPL Licence 2.0. +# +# This program is free software; you can redistribute it and/or modify it under +# the terms of the GNU General Public License as published by the Free Software +# Foundation ; either version 2 of the License. +# +# This program is distributed in the hope that it will be useful, but WITHOUT ANY +# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A +# PARTICULAR PURPOSE. See the GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License along with +# this program; if not, see . +# +# Linking this program statically or dynamically with other modules is making a +# combined work based on this program. Thus, the terms and conditions of the GNU +# General Public License cover the whole combination. +# +# As a special exception, the copyright holders of this program give MERETHIS +# permission to link this program with independent modules to produce an executable, +# regardless of the license terms of these independent modules, and to copy and +# distribute the resulting executable under terms of MERETHIS choice, provided that +# MERETHIS also meet, for each linked independent module, the terms and conditions +# of the license of that module. An independent module is a module which is not +# derived from this program. If you modify this program, you may extend this +# exception to your version of the program, but you are not obliged to do so. If you +# do not wish to do so, delete this exception statement from your version. +# +# For more information : contact@centreon.com +# Authors : Quentin Garnier +# +#################################################################################### + +package network::cisco::nexus::5000::mode::environment; + +use base qw(centreon::plugins::mode); + +use strict; +use warnings; + + +my %map_states_fan = ( + 1 => ['unknown', 'WARNING'], + 2 => ['up', 'OK'], + 3 => ['down', 'CRITICAL'], + 4 => ['warning', 'WARNING'] +); + +my %map_states_psu = ( + 1 => ['offEnvOther', 'WARNING'], + 2 => ['on', 'OK'], + 3 => ['offAdmin', 'WARNING'], + 4 => ['offDenied', 'WARNING'], + 5 => ['offEnvPower', 'WARNING'], + 6 => ['offEnvTemp', 'WARNING'], + 7 => ['offEnvFan', 'WARNING'], + 8 => ['failed', 'CRITICAL'], + 9 => ['onButFanFail', 'WARNING'], + 10 => ['offCooling', 'WARNING'], + 11 => ['offConnectorRating', 'WARNING'], + 12 => ['onButInlinePowerFail', 'WARNING'], +); + +my %map_states_mod = ( + 1 => ['unknown', 'WARNING'], + 2 => ['ok', 'OK'], + 3 => ['disabled', 'WARNING'], + 4 => ['okButDiagFailed', 'WARNING'], + 5 => ['boot', 'WARNING'], + 6 => ['selfTest', 'WARNING'], + 7 => ['failed', 'CRITICAL'], + 8 => ['missing', 'CRITICAL'], + 9 => ['mismatchWithParent', 'WARNING'], + 10 => ['mismatchConfig', 'WARNING'], + 11 => ['diagFailed', 'CRITICAL'], + 12 => ['dormant', 'WARNING'], + 13 => ['outOfServiceAdmin', 'WARNING'], + 14 => ['outOfServiceEnvTemp', 'WARNING'], + 15 => ['poweredDown', 'CRITICAL'], + 16 => ['poweredUp', 'OK'], + 17 => ['powerDenied', 'CRITICAL'], + 18 => ['powerCycled', 'WARNING'], + 19 => ['okButPowerOverWarning', 'WARNING'], + 20 => ['okButPowerOverCritical', 'CRITICAL'], + 21 => ['syncInProgress', 'WARNING'], + 22 => ['upgrading', 'WARNING'], + 23 => ['okButAuthFailed', 'WARNING'], + 24 => ['mdr', 'WARNING'], + 25 => ['fwMismatchFound', 'WARNING'], + 26 => ['fwDownloadSuccess', 'OK'], + 27 => ['fwDownloadFailure', 'WARNING'], +); + +my %map_states_phy = ( + 1 => ['other', 'WARNING'], + 2 => ['supported', 'OK'], + 3 => ['unsupported', 'CRITICAL'], + 4 => ['incompatible', 'CRITICAL'], +); + +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 => + { + "exclude:s" => { name => 'exclude' }, + }); + + return $self; +} + +sub check_options { + my ($self, %options) = @_; + $self->SUPER::init(%options); +} + +sub run { + my ($self, %options) = @_; + # $options{snmp} = snmp object + $self->{snmp} = $options{snmp}; + + $self->{components_fans} = 0; + $self->{components_psus} = 0; + $self->{components_mods} = 0; + $self->{components_phys} = 0; + + $self->check_fans(); + $self->check_psus(); + $self->check_mods(); + $self->check_phys(); + + $self->{output}->output_add(severity => 'OK', + short_msg => sprintf("All %d components [%d fans, %d power supplies, %d modules, %d physical entities] are ok.", + ($self->{components_fans} + $self->{components_psus} + $self->{components_mods}, $self->{components_phys}), + $self->{components_fans}, $self->{components_psus}, $self->{components_mods}, $self->{components_phys})); + + $self->{output}->display(); + $self->{output}->exit(); +} + +sub check_fans { + my ($self) = @_; + + $self->{output}->output_add(long_msg => "Checking fans"); + return if ($self->check_exclude('fan')); + + my $oid_entPhysicalDescr = '.1.3.6.1.2.1.47.1.1.1.1.2'; + my $oid_cefcFanTrayOperStatus = '.1.3.6.1.4.1.9.9.117.1.4.1.1.1'; + + my $results = $self->{snmp}->get_multiple_table(oids => [ + { oid => $oid_entPhysicalDescr + }, + { oid => $oid_cefcFanTrayOperStatus + }], + nothing_quit => 1); + + foreach my $oid (keys %{$results->{$oid_cefcFanTrayOperStatus}}) { + return if (scalar(keys %$results) <= 0); + $oid =~ /\.([0-9]+)$/; + my $instance = $1; + my $fan_descr = $results->{$oid_entPhysicalDescr}->{$oid_entPhysicalDescr . '.' . $instance}; + my $fan_state = $results->{$oid_cefcFanTrayOperStatus}->{$oid}; + + $self->{components_fans}++; + $self->{output}->output_add(long_msg => sprintf("Fan '%s' state is %s.", + $fan_descr, ${$map_states_fan{$fan_state}}[0])); + if (${$map_states_fan{$fan_state}}[1] ne 'OK') { + $self->{output}->output_add(severity => ${$map_states_fan{$fan_state}}[1], + short_msg => sprintf("Fan '%s' state is %s.", $fan_descr, ${$map_states_fan{$fan_state}}[0])); + } + } +} + +sub check_psus { + my ($self) = @_; + + $self->{output}->output_add(long_msg => "Checking power supplies"); + return if ($self->check_exclude('psu')); + + my $oid_entPhysicalDescr = '.1.3.6.1.2.1.47.1.1.1.1.2'; + my $oid_cefcFRUPowerOperStatus = '.1.3.6.1.4.1.9.9.117.1.1.2.1.2'; + + my $results = $self->{snmp}->get_multiple_table(oids => [ + { oid => $oid_entPhysicalDescr + }, + { oid => $oid_cefcFRUPowerOperStatus + }], + nothing_quit => 1); + + foreach my $oid (keys %{$results->{$oid_cefcFRUPowerOperStatus}}) { + return if (scalar(keys %$results) <= 0); + $oid =~ /\.([0-9]+)$/; + my $instance = $1; + my $psu_descr = $results->{$oid_entPhysicalDescr}->{$oid_entPhysicalDescr . '.' . $instance}; + my $psu_state = $results->{$oid_cefcFRUPowerOperStatus}->{$oid}; + + $self->{components_psus}++; + $self->{output}->output_add(long_msg => sprintf("Power Supply '%s' state is %s.", + $psu_descr, ${$map_states_psu{$psu_state}}[0])); + if (${$map_states_psu{$psu_state}}[1] ne 'OK') { + $self->{output}->output_add(severity => ${$map_states_psu{$psu_state}}[1], + short_msg => sprintf("Power Supply '%s' state is %s.", $psu_descr, ${$map_states_psu{$psu_state}}[0])); + } + } +} + +sub check_mods { + my ($self) = @_; + + $self->{output}->output_add(long_msg => "Checking modules"); + return if ($self->check_exclude('mod')); + + my $oid_entPhysicalDescr = '.1.3.6.1.2.1.47.1.1.1.1.2'; + my $oid_cefcModuleOperStatus = '.1.3.6.1.4.1.9.9.117.1.2.1.1.2'; + + my $results = $self->{snmp}->get_multiple_table(oids => [ + { oid => $oid_entPhysicalDescr + }, + { oid => $oid_cefcModuleOperStatus + }], + nothing_quit => 1); + + foreach my $oid (keys %{$results->{$oid_cefcModuleOperStatus}}) { + return if (scalar(keys %$results) <= 0); + $oid =~ /\.([0-9]+)$/; + my $instance = $1; + my $mod_descr = $results->{$oid_entPhysicalDescr}->{$oid_entPhysicalDescr . '.' . $instance}; + my $mod_state = $results->{$oid_cefcModuleOperStatus}->{$oid}; + + $self->{components_mods}++; + $self->{output}->output_add(long_msg => sprintf("Module '%s' state is %s.", + $mod_descr, ${$map_states_mod{$mod_state}}[0])); + if (${$map_states_mod{$mod_state}}[1] ne 'OK') { + $self->{output}->output_add(severity => ${$map_states_mod{$mod_state}}[1], + short_msg => sprintf("Power Supply '%s' state is %s.", $mod_descr, ${$map_states_mod{$mod_state}}[0])); + } + } +} + +sub check_phys { + my ($self) = @_; + + $self->{output}->output_add(long_msg => "Checking modules"); + return if ($self->check_exclude('phy')); + + my $oid_entPhysicalDescr = '.1.3.6.1.2.1.47.1.1.1.1.2'; + my $oid_cefcPhysicalStatus = '.1.3.6.1.4.1.9.9.117.1.5.1.1.1'; + + my $results = $self->{snmp}->get_multiple_table(oids => [ + { oid => $oid_entPhysicalDescr + }, + { oid => $oid_cefcPhysicalStatus + }], + nothing_quit => 1); + + foreach my $oid (keys %{$results->{$oid_cefcPhysicalStatus}}) { + return if (scalar(keys %$results) <= 0); + $oid =~ /\.([0-9]+)$/; + my $instance = $1; + my $phy_descr = $results->{$oid_entPhysicalDescr}->{$oid_entPhysicalDescr . '.' . $instance}; + my $phy_state = $results->{$oid_cefcPhysicalStatus}->{$oid}; + + $self->{components_phys}++; + $self->{output}->output_add(long_msg => sprintf("Physical entity '%s' state is %s.", + $phy_descr, ${$map_states_phy{$phy_state}}[0])); + if (${$map_states_phy{$phy_state}}[1] ne 'OK') { + $self->{output}->output_add(severity => ${$map_states_phy{$phy_state}}[1], + short_msg => sprintf("Power Supply '%s' state is %s.", $phy_descr, ${$map_states_phy{$phy_state}}[0])); + } + } +} + +sub check_exclude { + my ($self, $section) = @_; + + if (defined($self->{option_results}->{exclude}) && $self->{option_results}->{exclude} =~ /(^|\s|,)$section(\s|,|$)/) { + $self->{output}->output_add(long_msg => sprintf("Skipping $section section.")); + return 1; + } + return 0; +} + +1; + +__END__ + +=head1 MODE + +Check Environment monitor (CISCO-ENTITY-SENSOR-MIB) (Fans, Power Supplies, Modules, Physical Entities). + +=over 8 + +=item B<--exclude> + +Exclude some parts (comma seperated list) (Example: --exclude=fan,psu,mod,phy). + +=back + +=cut + diff --git a/centreon-plugins/network/cisco/nexus/5000/plugin.pm b/centreon-plugins/network/cisco/nexus/5000/plugin.pm new file mode 100644 index 000000000..71b55f0c3 --- /dev/null +++ b/centreon-plugins/network/cisco/nexus/5000/plugin.pm @@ -0,0 +1,70 @@ +################################################################################ +# Copyright 2005-2013 MERETHIS +# Centreon is developped by : Julien Mathis and Romain Le Merlus under +# GPL Licence 2.0. +# +# This program is free software; you can redistribute it and/or modify it under +# the terms of the GNU General Public License as published by the Free Software +# Foundation ; either version 2 of the License. +# +# This program is distributed in the hope that it will be useful, but WITHOUT ANY +# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A +# PARTICULAR PURPOSE. See the GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License along with +# this program; if not, see . +# +# Linking this program statically or dynamically with other modules is making a +# combined work based on this program. Thus, the terms and conditions of the GNU +# General Public License cover the whole combination. +# +# As a special exception, the copyright holders of this program give MERETHIS +# permission to link this program with independent modules to produce an executable, +# regardless of the license terms of these independent modules, and to copy and +# distribute the resulting executable under terms of MERETHIS choice, provided that +# MERETHIS also meet, for each linked independent module, the terms and conditions +# of the license of that module. An independent module is a module which is not +# derived from this program. If you modify this program, you may extend this +# exception to your version of the program, but you are not obliged to do so. If you +# do not wish to do so, delete this exception statement from your version. +# +# For more information : contact@centreon.com +# Authors : Quentin Garnier +# +#################################################################################### + +package network::cisco::nexus::5000::plugin; + +use strict; +use warnings; +use base qw(centreon::plugins::script_snmp); + +sub new { + my ($class, %options) = @_; + my $self = $class->SUPER::new(package => __PACKAGE__, %options); + bless $self, $class; + # $options->{options} = options object + + $self->{version} = '1.0'; + %{$self->{modes}} = ( + 'cpu' => 'network::cisco::common::mode::cpu', + 'environment' => 'network::cisco::nexus::5000::mode::environment', + 'list-interfaces' => 'snmp_standard::mode::listinterfaces', + 'memory' => 'network::cisco::common::mode::memory', + 'packet-errors' => 'snmp_standard::mode::packeterrors', + 'spanning-tree' => 'snmp_standard::mode::spanningtree', + 'traffic' => 'snmp_standard::mode::traffic', + ); + + return $self; +} + +1; + +__END__ + +=head1 PLUGIN DESCRIPTION + +Check Cisco Nexus 5000 in SNMP. + +=cut diff --git a/centreon-plugins/network/fritzbox/mode/traffic.pm b/centreon-plugins/network/fritzbox/mode/traffic.pm index c4fd2e64c..8e079fb2d 100644 --- a/centreon-plugins/network/fritzbox/mode/traffic.pm +++ b/centreon-plugins/network/fritzbox/mode/traffic.pm @@ -52,6 +52,7 @@ sub new { "hostname:s" => { name => 'hostname' }, "port:s" => { name => 'port', default => '49000' }, "timeout:s" => { name => 'timeout', default => 30 }, + "agent:s" => { name => 'agent', default => 'igdupnp' }, "warning-in:s" => { name => 'warning_in', }, "critical-in:s" => { name => 'critical_in', }, "warning-out:s" => { name => 'warning_out', }, @@ -100,7 +101,7 @@ sub run { my $old_timestamp = $self->{statefile_value}->get(name => 'last_timestamp'); ### GET DATA START - network::fritzbox::mode::libgetdata::init($self, pfad => '/upnp/control/WANCommonIFC1', + network::fritzbox::mode::libgetdata::init($self, pfad => '/' . $self->{option_results}->{agent} . '/control/WANCommonIFC1', uri => 'urn:schemas-upnp-org:service:WANCommonInterfaceConfig:1'); network::fritzbox::mode::libgetdata::call($self, soap_method => 'GetAddonInfos'); my $NewTotalBytesSent = network::fritzbox::mode::libgetdata::value($self, path => '//GetAddonInfosResponse/NewTotalBytesSent'); @@ -208,6 +209,10 @@ This Mode needs UPNP. =over 8 +=item B<--agent> + +Fritzbox has two different UPNP Agents. upnp or igdupnp. (Default: igdupnp) + =item B<--warning-in> Threshold warning for 'in' traffic. diff --git a/centreon-plugins/network/fritzbox/mode/upstatus.pm b/centreon-plugins/network/fritzbox/mode/upstatus.pm index 7241a8ff1..c5339b0df 100644 --- a/centreon-plugins/network/fritzbox/mode/upstatus.pm +++ b/centreon-plugins/network/fritzbox/mode/upstatus.pm @@ -53,6 +53,7 @@ sub new { "hostname:s" => { name => 'hostname' }, "port:s" => { name => 'port', default => '49000' }, "timeout:s" => { name => 'timeout', default => 30 }, + "agent:s" => { name => 'agent', default => 'igdupnp' }, "warning:s" => { name => 'warning', }, "critical:s" => { name => 'critical', }, "seconds" => { name => 'seconds', }, @@ -83,13 +84,13 @@ sub run { my ($self, %options) = @_; my $exit_code; - network::fritzbox::mode::libgetdata::init($self, pfad => '/upnp/control/WANCommonIFC1', + network::fritzbox::mode::libgetdata::init($self, pfad => '/' . $self->{option_results}->{agent} . '/control/WANCommonIFC1', uri => 'urn:schemas-upnp-org:service:WANCommonInterfaceConfig:1'); network::fritzbox::mode::libgetdata::call($self, soap_method => 'GetCommonLinkProperties'); my $WANAccessType = network::fritzbox::mode::libgetdata::value($self, path => '//GetCommonLinkPropertiesResponse/NewWANAccessType'); my $LinkStatus = network::fritzbox::mode::libgetdata::value($self, path => '//GetCommonLinkPropertiesResponse/NewPhysicalLinkStatus'); - network::fritzbox::mode::libgetdata::init($self, pfad => '/upnp/control/WANIPConn1', + network::fritzbox::mode::libgetdata::init($self, pfad => '/' . $self->{option_results}->{agent} . '/control/WANIPConn1', uri => 'urn:schemas-upnp-org:service:WANIPConnection:1'); network::fritzbox::mode::libgetdata::call($self, soap_method => 'GetStatusInfo'); my $uptime = network::fritzbox::mode::libgetdata::value($self, path => '//GetStatusInfoResponse/NewUptime'); @@ -128,6 +129,10 @@ This Mode needs UPNP. =over 8 +=item B<--agent> + +Fritzbox has two different UPNP Agents. upnp or igdupnp. (Default: igdupnp) + =item B<--warning> Threshold warning in seconds.