diff --git a/ChangeLog b/ChangeLog index 32550e6a..a47de1da 100644 --- a/ChangeLog +++ b/ChangeLog @@ -2,6 +2,10 @@ SNMP::Info - Friendly OO-style interface to Network devices using SNMP. version 3.06 () + [ENHANCEMENTS] + + * Support for Pica8 switches in L3::Pica8 + [BUG FIXES] * [#48] Switch duplicate J9624A for J9626A in Layer2/HP (R. Kerr) diff --git a/Info.pm b/Info.pm index 3c5da69c..e84b8e20 100644 --- a/Info.pm +++ b/Info.pm @@ -1392,6 +1392,7 @@ sub device_type { 14988 => 'SNMP::Info::Layer3::Mikrotik', 25506 => 'SNMP::Info::Layer3::H3C', 30065 => 'SNMP::Info::Layer3::Arista', + 35098 => 'SNMP::Info::Layer3::Pica8', ); my %l2sysoidmap = ( diff --git a/Info/Layer3/Pica8.pm b/Info/Layer3/Pica8.pm new file mode 100644 index 00000000..7212b329 --- /dev/null +++ b/Info/Layer3/Pica8.pm @@ -0,0 +1,221 @@ +# SNMP::Info::Layer3::Pica8 +# +# Copyright (c) 2013 Jeroen van Ingen +# All rights reserved. +# +# Redistribution and use in source and binary forms, with or without +# modification, are permitted provided that the following conditions are met: +# +# * Redistributions of source code must retain the above copyright notice, +# this list of conditions and the following disclaimer. +# * Redistributions in binary form must reproduce the above copyright +# notice, this list of conditions and the following disclaimer in the +# documentation and/or other materials provided with the distribution. +# * Neither the name of the University of California, Santa Cruz nor the +# names of its contributors may be used to endorse or promote products +# derived from this software without specific prior written permission. +# +# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" +# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE +# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE +# ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE +# LIABLE FOR # ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR +# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF +# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS +# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN +# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) +# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +# POSSIBILITY OF SUCH DAMAGE. + +package SNMP::Info::Layer3::Pica8; + +use strict; +use Exporter; +use SNMP::Info::Layer3; +use SNMP::Info::LLDP; + +@SNMP::Info::Layer3::Pica8::ISA = qw/SNMP::Info::LLDP SNMP::Info::Layer3 Exporter/; +@SNMP::Info::Layer3::Pica8::EXPORT_OK = qw//; + +use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %MUNGE/; + +$VERSION = '3.05'; + +%MIBS = ( + %SNMP::Info::Layer3::MIBS, + %SNMP::Info::LLDP::MIBS, +); + +%GLOBALS = ( + %SNMP::Info::Layer3::GLOBALS, + %SNMP::Info::LLDP::GLOBALS, +); + +%FUNCS = ( + %SNMP::Info::Layer3::FUNCS, + %SNMP::Info::LLDP::FUNCS, +); + +%MUNGE = ( + %SNMP::Info::Layer3::MUNGE, + %SNMP::Info::LLDP::MUNGE, +); + +sub vendor { + return 'Pica8'; +} + +sub os { + my $pica8 = shift; + my $descr = $pica8->description(); + + return $1 if ( $descr =~ /(\S+)\s+Platform Software/i ); + return; +} + +sub os_ver { + my $pica8 = shift; + my $descr = $pica8->description(); + + return $1 if ( $descr =~ /Software version ([\d\.]+)/i ); + return; +} + +sub model { + my $pica8 = shift; + my $descr = $pica8->description(); + + return $1 if ( $descr =~ /Hardware model (P-\d{4})/i ); + return; +} + +# Use Q-BRIDGE-MIB + +sub fw_mac { + my $l3 = shift; + my $partial = shift; + + return $l3->qb_fw_mac($partial); +} + +sub fw_port { + my $l3 = shift; + my $partial = shift; + + return $l3->qb_fw_port($partial); +} + +1; +__END__ + +=head1 NAME + +SNMP::Info::Layer3::Pica8 - SNMP Interface to L3 Devices, Pica8 + +=head1 AUTHORS + +Jeroen van Ingen + +=head1 SYNOPSIS + + # Let SNMP::Info determine the correct subclass for you. + my $pica8 = new SNMP::Info( + AutoSpecify => 1, + Debug => 1, + DestHost => 'myrouter', + Community => 'public', + Version => 2 + ) + or die "Can't connect to DestHost.\n"; + + my $class = $pica8->class(); + print "SNMP::Info determined this device to fall under subclass : $class\n"; + +=head1 DESCRIPTION + +Subclass for Pica8 devices + +=head2 Inherited Classes + +=over + +=item SNMP::Info::Layer3 + +=item SNMP::Info::LLDP + +=back + +=head2 Required MIBs + +=over + +=item F + +=item Inherited Classes' MIBs + +See L for its own MIB requirements. + +See L for its own MIB requirements. + +=back + +=head1 GLOBALS + +These are methods that return scalar value from SNMP + +=over + +=item $pica8->vendor() + +Returns 'Pica8' + +=item $pica8->model() + +Returns the model name extracted from C. + +=item $pica8->os() + +Returns the OS extracted from C. + +=item $pica8->os_ver() + +Returns the OS version extracted from C. + +=back + +=head2 Globals imported from SNMP::Info::Layer3 + +See documentation in L for details. + +=head2 Globals imported from SNMP::Info::LLDP + +See documentation in L for details. + +=head1 TABLE ENTRIES + +These are methods that return tables of information in the form of a reference +to a hash. + +=head2 Overrides + +=over + +=item $pica8->fw_mac() + +Use the F instead of F + +=item $pica8->fw_port() + +Use the F instead of F + +=back + +=head2 Table Methods imported from SNMP::Info::Layer3 + +See documentation in L for details. + +=head2 Table Methods imported from SNMP::Info::LLDP + +See documentation in L for details. + +=cut diff --git a/MANIFEST b/MANIFEST index a6148184..2a1cae9c 100644 --- a/MANIFEST +++ b/MANIFEST @@ -87,6 +87,7 @@ Info/Layer3/Nexus.pm Info/Layer3/PacketFront.pm Info/Layer3/Passport.pm Info/Layer3/Pf.pm +Info/Layer3/Pica8.pm Info/Layer3/SonicWALL.pm Info/Layer3/Sun.pm Info/Layer3/Tasman.pm