From 54a0baa2fa1952b70e8aa746de8a90ce305c63c1 Mon Sep 17 00:00:00 2001 From: Rob Woodward Date: Fri, 13 Apr 2018 11:26:46 +0100 Subject: [PATCH 1/2] Add support for Arbor devices --- MANIFEST | 1 + META.json | 4 + META.yml | 3 + lib/SNMP/Info.pm | 209 +++++++++++++++++----------------- lib/SNMP/Info/Layer7/Arbor.pm | 192 +++++++++++++++++++++++++++++++ 5 files changed, 305 insertions(+), 104 deletions(-) create mode 100644 lib/SNMP/Info/Layer7/Arbor.pm diff --git a/MANIFEST b/MANIFEST index 6cdee03e..1f64a8f1 100644 --- a/MANIFEST +++ b/MANIFEST @@ -118,6 +118,7 @@ lib/SNMP/Info/Layer3/VMware.pm lib/SNMP/Info/Layer3/VyOS.pm lib/SNMP/Info/Layer7.pm lib/SNMP/Info/Layer7/APC.pm +lib/SNMP/Info/Layer7/Arbor.pm lib/SNMP/Info/Layer7/CiscoIPS.pm lib/SNMP/Info/Layer7/Gigamon.pm lib/SNMP/Info/Layer7/Neoteris.pm diff --git a/META.json b/META.json index 533240a9..8958cb4e 100644 --- a/META.json +++ b/META.json @@ -483,6 +483,10 @@ "file" : "lib/SNMP/Info/Layer7/APC.pm", "version" : "3.54" }, + "SNMP::Info::Layer7::Arbor" : { + "file" : "lib/SNMP/Info/Layer7/Arbor.pm", + "version" : "3.54" + }, "SNMP::Info::Layer7::CiscoIPS" : { "file" : "lib/SNMP/Info/Layer7/CiscoIPS.pm", "version" : "3.54" diff --git a/META.yml b/META.yml index 6e85336e..373f3588 100644 --- a/META.yml +++ b/META.yml @@ -349,6 +349,9 @@ provides: SNMP::Info::Layer7::APC: file: lib/SNMP/Info/Layer7/APC.pm version: '3.54' + SNMP::Info::Layer7::Arbor: + file: lib/SNMP/Info/Layer7/Arbor.pm + version: '3.54' SNMP::Info::Layer7::CiscoIPS: file: lib/SNMP/Info/Layer7/CiscoIPS.pm version: '3.54' diff --git a/lib/SNMP/Info.pm b/lib/SNMP/Info.pm index c312b633..c5912186 100644 --- a/lib/SNMP/Info.pm +++ b/lib/SNMP/Info.pm @@ -55,14 +55,14 @@ list any missing functionality (such as neighbor discovery tables). use SNMP::Info; - my $info = new SNMP::Info( + my $info = new SNMP::Info( # Auto Discover more specific Device Class AutoSpecify => 1, Debug => 1, # The rest is passed to SNMP::Session DestHost => 'router', Community => 'public', - Version => 2 + Version => 2 ) or die "Can't connect to device.\n"; my $err = $info->error(); @@ -93,7 +93,7 @@ list any missing functionality (such as neighbor discovery tables). # The CDP Table has table entries different than the interface tables. # So we use c_if to get the map from cdp table to interface table. - my %c_map = reverse %$c_if; + my %c_map = reverse %$c_if; my $c_key = $c_map{$iid}; unless (defined $c_key) { print "\n\n"; @@ -112,13 +112,13 @@ list any missing functionality (such as neighbor discovery tables). Please direct all support, help, and bug requests to the snmp-info-users Mailing List at L. -=head1 DESCRIPTION +=head1 DESCRIPTION SNMP::Info gives an object oriented interface to information obtained through SNMP. This module is geared towards network devices. Subclasses exist for a number -of network devices and common MIBs. +of network devices and common MIBs. The idea behind this module is to give a common interface to data from network devices, leaving the device-specific hacks behind the scenes in subclasses. @@ -169,7 +169,7 @@ install by hand. SNMP::Info operates on textual descriptors found in MIBs. -If you are using SNMP::Info separate from Netdisco, +If you are using SNMP::Info separate from Netdisco, download the Netdisco MIB package at L Make sure that your snmp.conf is updated to point to your MIB directory @@ -181,7 +181,7 @@ and that the MIBs are world-readable. =over -=item 1. Use of textual MIB leaf identifier and enumerated values +=item 1. Use of textual MIB leaf identifier and enumerated values =over @@ -194,17 +194,17 @@ instead of 1.3.6.1.2.1.1.5. For Example instead of looking up 1.3.6.1.2.1.2.2.1.3 and getting back C<23> -SNMP::Info will ask for C and will get back C. +SNMP::Info will ask for C and will get back C. =back =item 2. SNMP::Info is easily extended to new devices You can create a new subclass for a device by providing four hashes : -%GLOBALS, %MIBS, %FUNCS, and %MUNGE. +%GLOBALS, %MIBS, %FUNCS, and %MUNGE. Or you can override any existing methods from a parent class by making a short -subroutine. +subroutine. See the section EXTENDING SNMP::INFO for more details. @@ -222,7 +222,7 @@ Required MIBs not included in the install instructions above are noted here. =head2 MIB Subclasses -These subclasses implement method to access one or more MIBs. These are not +These subclasses implement method to access one or more MIBs. These are not used directly, but rather inherited from device subclasses. For more info run C on any of the following module names. @@ -326,7 +326,7 @@ See documentation in L for details. F, F, and F. Provides common interfaces for memory, cpu, and os statistics for Cisco -devices. +devices. See documentation in L for details. @@ -373,7 +373,7 @@ See documentation in L for details. =item SNMP::Info::IEEE802dot11 F. A collection of OIDs providing information about -standards based 802.11 wireless devices. +standards based 802.11 wireless devices. See documentation in L for details. @@ -424,7 +424,7 @@ See documentation in L for details. =item SNMP::Info::SONMP SynOptics Network Management Protocol (SONMP) F, -F. Inherited by +F. Inherited by Avaya/Nortel/Bay/Synoptics switches and hubs. See documentation in L for details. @@ -434,7 +434,7 @@ See documentation in L for details. =head2 Device Subclasses These subclasses inherit from one or more classes to provide a common -interface to data obtainable from network devices. +interface to data obtainable from network devices. All the required MIB files are included in the netdisco-mib package. (See Above). @@ -451,7 +451,7 @@ See documentation in L for details. =item SNMP::Info::Layer1::Allied -Subclass for Allied Telesis Repeaters / Hubs. +Subclass for Allied Telesis Repeaters / Hubs. Requires F @@ -459,7 +459,7 @@ See documentation in L for details. =item SNMP::Info::Layer1::Asante -Subclass for Asante 1012 Hubs. +Subclass for Asante 1012 Hubs. Requires F @@ -555,7 +555,7 @@ See documentation in L for details. Subclass for Cisco Catalyst switches running CatOS. These switches usually report a model number that starts with C. Note that this class -does not support everything that has the name Catalyst. +does not support everything that has the name Catalyst. See documentation in L for details. @@ -575,7 +575,7 @@ See documentation in L for details. =item SNMP::Info::Layer2::CiscoSB -Subclass for Cisco's "Small Business" product line, acquired from +Subclass for Cisco's "Small Business" product line, acquired from Linksys. This currently comprises the Sx300/500 line of switches. See documentation in L for details. @@ -584,7 +584,7 @@ See documentation in L for details. Subclass for more recent HP Procurve Switches -Requires F and F downloaded from HP. +Requires F and F downloaded from HP. See documentation in L for details. @@ -592,7 +592,7 @@ See documentation in L for details. Subclass for older HP Procurve Switches -Requires F and F downloaded from HP. +Requires F and F downloaded from HP. See documentation in L for details. @@ -679,7 +679,7 @@ are usually older devices. MIBs for these devices now included in v2.tar.gz available from ftp.cisco.com. -Note Layer2::Aironet +Note Layer2::Aironet See documentation in L for details. @@ -774,19 +774,19 @@ L for details. =item SNMP::Info::Layer3::Contivity -Subclass for Avaya/Nortel Contivity/VPN Routers. +Subclass for Avaya/Nortel Contivity/VPN Routers. See documentation in L for details. =item SNMP::Info::Layer3::Cumulus -Subclass for Cumulus Networks Routers. +Subclass for Cumulus Networks Routers. See documentation in L for details. =item SNMP::Info::Layer3::DLink -Subclass for DLink devices. +Subclass for DLink devices. See documentation in L for details. @@ -1046,7 +1046,7 @@ README! =item new() -Creates a new object and connects via SNMP::Session. +Creates a new object and connects via SNMP::Session. my $info = new SNMP::Info( 'Debug' => 1, 'AutoSpecify' => 1, @@ -1098,7 +1098,7 @@ C -> bulkwalk() for more info. Detects looping during getnext table column walks by comparing IIDs for each instance. A loop is detected if the same IID is seen more than once and the walk is aborted. Note: This will not detect loops during a bulkwalk -operation, Net-SNMP's internal bulkwalk function must detect the loop. +operation, Net-SNMP's internal bulkwalk function must detect the loop. Set to C<0> to turn off loop detection. @@ -1188,7 +1188,7 @@ Some older devices don't support SNMP version 2, and will not return anything when a connection under Version 2 is attempted. Some newer devices will support Version 1, but will not return all the data -they might have if you had connected under Version 1 +they might have if you had connected under Version 1 When trying to get info from a new device, you may have to try version 2 and then fallback to version 1. @@ -1528,8 +1528,8 @@ then Layer 2 support and subclasses are checked. This means that Layer 2 / 3 switches and routers will fall under the SNMP::Info::Layer3 subclasses. -If the device still can be connected to via SNMP::Info, then -SNMP::Info is returned. +If the device still can be connected to via SNMP::Info, then +SNMP::Info is returned. =cut @@ -1543,13 +1543,13 @@ sub device_type { my $desc = $info->description() || 'undef'; $desc =~ s/[\r\n\l]+/ /g; - # Some devices don't implement sysServices, but do return a description. + # Some devices don't implement sysServices, but do return a description. # In that case, log a warning and continue. if ( $layers eq '00000000' ) { if ($desc ne 'undef') { carp("Device doesn't implement sysServices but did return sysDescr. Might give unexpected results.\n") if $info->debug(); } else { - # No sysServices, no sysDescr + # No sysServices, no sysDescr return; } } @@ -1653,6 +1653,7 @@ sub device_type { my %l7sysoidmap = ( 318 => 'SNMP::Info::Layer7::APC', 5951 => 'SNMP::Info::Layer7::Netscaler', + 9694 => 'SNMP::Info::Layer7::Arbor', 14525 => 'SNMP::Info::Layer2::Trapeze', 12532 => 'SNMP::Info::Layer7::Neoteris', 26866 => 'SNMP::Info::Layer7::Gigamon', @@ -1757,7 +1758,7 @@ sub device_type { # Cisco FWSM $objtype = 'SNMP::Info::Layer3::CiscoFWSM' if ( $desc =~ /Cisco Firewall Services Module/i ); - + # Cisco Small Business (300 500) series override # This is for enterprises(1).cisco(9).otherEnterprises(6).ciscosb(1) $objtype = 'SNMP::Info::Layer2::CiscoSB' @@ -1788,7 +1789,7 @@ sub device_type { $desc =~ /Nortel\s+(Networks\s+)??WLAN\s+-\s+Security\s+Switch/ ); # Nortel (Trapeze) WSS 2300 Series - $objtype = 'SNMP::Info::Layer2::NWSS2300' + $objtype = 'SNMP::Info::Layer2::NWSS2300' if ( $desc =~ /^(Nortel\s)??Wireless\sSecurity\sSwitch\s23[568][012]\b/); @@ -1849,7 +1850,7 @@ sub device_type { # This is for enterprises(1).cisco(9).otherEnterprises(6).ciscosb(1) $objtype = 'SNMP::Info::Layer2::CiscoSB' if ( $soid =~ /^\.1\.3\.6\.1\.4\.1\.9\.6\.1/ ); - + # HP, older ProCurve models (1600, 2400, 2424m, 4000, 8000) $objtype = 'SNMP::Info::Layer2::HP4000' if $desc =~ /\b(J4093A|J4110A|J4120A|J4121A|J4122A|J4122B)\b/; @@ -1983,10 +1984,10 @@ sub device_type { if ( $desc =~ /HP\sVC\s/ ); # Nortel (Trapeze) WSS 2300 Series - $objtype = 'SNMP::Info::Layer2::NWSS2300' + $objtype = 'SNMP::Info::Layer2::NWSS2300' if ( $desc =~ /^(Nortel\s)??Wireless\sSecurity\sSwitch\s23[568][012]\b/); - + # Cisco IPS, older version which doesn't report layer 3 functionality $objtype = 'SNMP::Info::Layer7::CiscoIPS' if ( $soid =~ /\.1\.3\.6\.1\.4\.1\.9\.1\.1545/i ); @@ -2072,7 +2073,7 @@ sub snmp_ver { =item $info->specify() -Returns an object of a more-specific subclass. +Returns an object of a more-specific subclass. my $info = new SNMP::Info(...); # Returns more specific object type @@ -2125,7 +2126,7 @@ sub specify { =item $info->cisco_comm_indexing() Returns 0. Is an overridable method used for vlan indexing for -snmp calls on certain Cisco devices. +snmp calls on certain Cisco devices. See L @@ -2139,7 +2140,7 @@ sub cisco_comm_indexing { =head2 Globals (Scalar Methods) -These are methods to return scalar data from RFC1213. +These are methods to return scalar data from RFC1213. Some subset of these is probably available for any network device that speaks SNMP. @@ -2160,7 +2161,7 @@ Uptime in hundredths of seconds since device became available. (C) -=item $info->location() +=item $info->location() (C) @@ -2168,12 +2169,12 @@ Uptime in hundredths of seconds since device became available. This returns a binary encoded string where each digit represents a layer of the OSI model served -by the device. +by the device. - eg: 01000010 means layers 2 (physical) and 7 (Application) + eg: 01000010 means layers 2 (physical) and 7 (Application) are served. -Note: This string is 8 digits long. +Note: This string is 8 digits long. See $info->has_layer() @@ -2183,7 +2184,7 @@ See $info->has_layer() Number of interfaces available on this device. -Not too useful as the number of SNMP interfaces usually does not +Not too useful as the number of SNMP interfaces usually does not correspond with the number of physical ports (C) @@ -2203,7 +2204,7 @@ Returns either forwarding or not-forwarding Each of these methods returns a hash_reference to a hash keyed on the interface index in SNMP. -Example : $info->interfaces() might return +Example : $info->interfaces() might return { '1.12' => 'FastEthernet/0', '2.15' => 'FastEthernet/1', @@ -2222,7 +2223,7 @@ specify it in the call: $local_routes = $info->ipr_route('192.168.0'); This will only fetch entries in the table that start with C<192.168.0>, which -in this case are routes on the local network. +in this case are routes on the local network. Remember that you must supply the partial IID (a numeric OID). @@ -2234,16 +2235,16 @@ Partial table results are not cached. =item $info->interfaces() -This methods is overridden in each subclass to provide a +This methods is overridden in each subclass to provide a mapping between the Interface Table Index (iid) and the physical port name. =item $info->if_ignore() -Returns a reference to a hash where key values that exist are +Returns a reference to a hash where key values that exist are interfaces to ignore. Ignored interfaces are ones that are usually not physical ports or Virtual -Lans (VLANs) such as the Loopback interface, or the CPU interface. +Lans (VLANs) such as the Loopback interface, or the CPU interface. =cut @@ -2255,7 +2256,7 @@ sub if_ignore { =item $info->bulkwalk_no() Returns 0. Is an overridable method used for turn off bulkwalk for the -device class. +device class. =cut @@ -2269,7 +2270,7 @@ Default SNMP IID to Interface index. (C) -=item $info->i_description() +=item $info->i_description() Description of the interface. Usually a little longer single word name that is both human and machine friendly. Not always. @@ -2359,14 +2360,14 @@ i_speed() will call it if it needs to. (C) -=item $info->i_mac() +=item $info->i_mac() MAC address of the interface. Note this is just the MAC of the port, not anything connected to it. (C) -=item $info->i_up() +=item $info->i_up() Link Status of the interface. Typical values are 'up' and 'down'. @@ -2411,7 +2412,7 @@ Bandwidth. Number of octets sent/received on the interface including framing characters. -64 bit version may not exist on all devices. +64 bit version may not exist on all devices. NOTE: To manipulate 64 bit counters you need to use Math::BigInt, since the values are too large for a normal Perl scalar. Set the global @@ -2434,7 +2435,7 @@ $info->i_pkts_ucast_in64(), $info->i_pkts_ucast_out64() Number of packets not sent to a multicast or broadcast address. -64 bit version may not exist on all devices. +64 bit version may not exist on all devices. (C) (C) (C) (C) @@ -2453,7 +2454,7 @@ $info->i_pkts_multi_in64(), $info->i_pkts_multi_out64() Number of packets sent to a multicast address. -64 bit version may not exist on all devices. +64 bit version may not exist on all devices. (C) (C) (C) (C) @@ -2463,7 +2464,7 @@ $info->i_pkts_bcast_in64() $info->i_pkts_bcast_out64() Number of packets sent to a broadcast address on an interface. -64 bit version may not exist on all devices. +64 bit version may not exist on all devices. (C) (C) (C) (C) @@ -2505,7 +2506,7 @@ See C for full description =head2 IP Address Table -Each entry in this table is an IP address in use on this device. Usually +Each entry in this table is an IP address in use on this device. Usually this is implemented in Layer3 Devices. =over @@ -2554,7 +2555,7 @@ The interface (IID) that the route is on. Use interfaces() to map. =item $info->ipr_1() -Primary routing metric for this route. +Primary routing metric for this route. (C) @@ -2671,12 +2672,12 @@ Reference to MIB definition specific to routing protocol. =head2 Topology Information -Based upon the manufacturer and software version devices may support some +Based upon the manufacturer and software version devices may support some combination of Layer 2 topology protocol information. SNMP::Info supports querying Link Layer Discovery Protocol (LLDP), Cisco Discovery Protocol (CDP), SynOptics/Bay/Nortel/Avaya Network Management Protocol (SONMP), Foundry/Brocade Discovery Protocol (FDP), Extreme Discovery -Protocol (EDP), and Alcatel Mapping Adjacency Protocol (AMAP). +Protocol (EDP), and Alcatel Mapping Adjacency Protocol (AMAP). For protocol specific information and implementation: @@ -2755,7 +2756,7 @@ sub _get_topo_data { $t_data{$iid} = $ip; } } - return \%t_data; + return \%t_data; } =head3 Common Topology Table Information @@ -2778,7 +2779,7 @@ C, C, C, C, C, C. If nothing is passed in as the second argument, the methods will call has_topo() to determine supported and running topology protocols on the -device. +device. =over @@ -2792,7 +2793,7 @@ same IPv4 address, c_ip(), it may be a duplicate entry. If multiple entries exist with the same local port, c_if(), with different IPv4 addresses, c_ip(), there is either a device in between two or more devices utilizing a different topology protocol or multiple devices -which are not directly connected. +which are not directly connected. Use the protocol specific methods to dig deeper. @@ -2920,9 +2921,9 @@ sub c_platform { =item $info->c_cap(partial, topology_protocol_arrayref) -Returns reference to hash of arrays. Key: iid, Value: Array of capabilities +Returns reference to hash of arrays. Key: iid, Value: Array of capabilities supported by the device. See the specific protocol class for string values -which could be elements within the array. +which could be elements within the array. Note: Only CDP and LLDP support this method. @@ -2964,13 +2965,13 @@ Returns if failed, or the return value from SNMP::Session::set() (snmp_errno) =item $info->set_METHOD($value,$iid) -Table Methods. Set iid of method to value. +Table Methods. Set iid of method to value. Returns if failed, or the return value from SNMP::Session::set() (snmp_errno) # Disable a port administratively my %if_map = reverse %{$info->interfaces()} - $info->set_i_up_admin('down', $if_map{'FastEthernet0/0'}) + $info->set_i_up_admin('down', $if_map{'FastEthernet0/0'}) or die "Couldn't disable the port. ",$info->error(1); =back @@ -3033,7 +3034,7 @@ it to the developer that has claimed the ticket. =head2 Data Structures required in new Subclass -A class inheriting this class must implement these data structures : +A class inheriting this class must implement these data structures : =over @@ -3048,7 +3049,7 @@ $INIT = 0; =item %GLOBALS Contains a hash in the form ( method_name => SNMP MIB leaf name ) -These are scalar values such as name, uptime, etc. +These are scalar values such as name, uptime, etc. To resolve MIB leaf name conflicts between private MIBs, you may prefix the leaf name with the MIB replacing each - (dash) and : (colon) with @@ -3165,14 +3166,14 @@ ALTEON-TS-PHYSICAL-MIB::agPortCurCfgPortName. =item %MIBS -A list of each mib needed. +A list of each mib needed. ('MIB-NAME' => 'itemToTestForPresence') -The value for each entry should be a MIB object to check for to make sure -that the MIB is present and has loaded correctly. +The value for each entry should be a MIB object to check for to make sure +that the MIB is present and has loaded correctly. -$info->init() will throw an exception if a MIB does not load. +$info->init() will throw an exception if a MIB does not load. =cut @@ -3190,8 +3191,8 @@ $info->init() will throw an exception if a MIB does not load. =item %MUNGE A map between method calls (from %FUNCS or %GLOBALS) and subroutine methods. -The subroutine called will be passed the data as it gets it from SNMP and -it should return that same data in a more human friendly format. +The subroutine called will be passed the data as it gets it from SNMP and +it should return that same data in a more human friendly format. Sample %MUNGE: @@ -3291,7 +3292,7 @@ will inherit the Cisco Vlan module as an example. return 'Fire' if $power =~ /reallyhot/i; return 'Ice' if $power =~ /reallycold/i; - # Else + # Else return $power; } @@ -3311,7 +3312,7 @@ will inherit the Cisco Vlan module as an example. 1; # don't forget this line ----------------------- snip -------------------------------- -Be sure and send the debugged version to snmp-info-users@lists.sourceforge.net to be +Be sure and send the debugged version to snmp-info-users@lists.sourceforge.net to be included in the next version of SNMP::Info. =head1 SNMP::INFO INTERNALS @@ -3320,7 +3321,7 @@ included in the next version of SNMP::Info. Internal data is stored with bareword keys. For example $info->{debug} -SNMP Data is stored or marked cached with keys starting with an underscore. +SNMP Data is stored or marked cached with keys starting with an underscore. For example $info->{_name} is the cache for $info->name(). Cached Table data is stored in $info->store() and marked cached per above. @@ -3384,12 +3385,12 @@ Makes human friendly speed ratings using %SPEED_MAP '64000' => '64 kbps', '115000' => '115 kpbs', '1500000' => '1.5 Mbps', - '1536000' => 'T1', + '1536000' => 'T1', '1544000' => 'T1', '2000000' => '2.0 Mbps', '2048000' => '2.048 Mbps', '3072000' => 'Dual T1', - '3088000' => 'Dual T1', + '3088000' => 'Dual T1', '4000000' => '4.0 Mbps', '10000000' => '10 Mbps', '11000000' => '11 Mbps', @@ -3411,7 +3412,7 @@ Makes human friendly speed ratings using %SPEED_MAP '155519000' => 'OC-3', '155520000' => 'OC-3', '400000000' => '400 Mbps', - '599040000' => 'ATM on OC-12', + '599040000' => 'ATM on OC-12', '622000000' => 'OC-12', '622080000' => 'OC-12', '1000000000' => '1.0 Gbps', @@ -3419,9 +3420,9 @@ Makes human friendly speed ratings using %SPEED_MAP '2488000000' => 'OC-48', ) -Note: high speed interfaces (usually 1 Gbps or faster) have their link -speed in C. i_speed() automatically determines whether to use -C or C; if the latter is used, the value is munged by +Note: high speed interfaces (usually 1 Gbps or faster) have their link +speed in C. i_speed() automatically determines whether to use +C or C; if the latter is used, the value is munged by munge_highspeed(). SNMP::Info can return speeds up to terabit levels this way. =cut @@ -3503,7 +3504,7 @@ sub munge_highspeed { return sprintf( $fmt, $speed ); } -=item munge_ip() +=item munge_ip() Takes a binary IP and makes it dotted ASCII @@ -3644,7 +3645,7 @@ sub munge_i_up { =item munge_port_list Takes an octet string representing a set of ports and returns a reference -to an array of binary values each array element representing a port. +to an array of binary values each array element representing a port. If the element has a value of '1', then that port is included in the set of ports; the port is not included if it has a value of '0'. @@ -3705,7 +3706,7 @@ sub init { # Get MibDirs if provided my $mibdirs = $self->{mibdirs} || []; - + # SNMP::initMib and SNMP::addMibDirs both look for some initial MIBs # so if we are not using Net-SNMP configuration files we need to # specify where the MIBs are before those calls. @@ -3922,7 +3923,7 @@ sub _global { return $self->_munge($attr, $val); } else{ return $val; - } + } } if ( $self->{Offline} ) { @@ -4057,7 +4058,7 @@ sub _set { =item $info->_make_setter(val,iid) Used internally by AUTOLOAD to create dynamic methods from either %GLOBALS, -%FUNCS, or a valid mib leaf from a loaded MIB which runs an SNMP set command. +%FUNCS, or a valid mib leaf from a loaded MIB which runs an SNMP set command. When run clears the attribute cache. Example: $info->set_name('dog',3) dispatches to autoload to resolve to @@ -4078,7 +4079,7 @@ sub _make_setter { my $globals = $self->globals(); my $attr = $method; $attr =~ s/^set_//; - + # The only thing which may give us the iid in $oid should be # a %GLOBALS entry appended with a number. In that case strip it # from the OID and use it as $iid @@ -4206,7 +4207,7 @@ sub all { =item $info->_load_attr() -Used internally by AUTOLOAD to create dynamic methods from %FUNCS +Used internally by AUTOLOAD to create dynamic methods from %FUNCS or a MIB Leaf node name contained within a table of a loaded MIB. Supports partial table fetches and single instance table fetches. @@ -4255,9 +4256,9 @@ sub _load_attr { # conflicts. Example: ALTEON-TIGON-SWITCH-MIB::agSoftwareVersion # and ALTEON-CHEETAH-SWITCH-MIB::agSoftwareVersion # Third argument to translateObj specifies the Module prefix - + my $qual_leaf = SNMP::translateObj($oid,0,1) || ''; - + # We still want just the leaf since a SNMP get in the case of a # partial fetch may strip the Module portion upon return. We need # the match to make sure we didn't leave the table during getnext @@ -4447,7 +4448,7 @@ sub _show_attr { } } -=item $info->snmp_connect_ip(ip) +=item $info->snmp_connect_ip(ip) Returns true or false based upon snmp connectivity to an IP. @@ -4495,7 +4496,7 @@ sub snmp_connect_ip { =item modify_port_list(portlist,offset,replacement) Replaces the specified bit in a port_list array and -returns the packed bitmask +returns the packed bitmask =cut @@ -4580,7 +4581,7 @@ sub _munge { Used internally by AUTOLOAD to validate that a dynamic method should be created. Returns the OID of the MIB leaf node the method will get or set. -=over +=over =item 1. Returns unless method is listed in %FUNCS, %GLOBALS, or is MIB Leaf node name in a loaded MIB for given class. @@ -4739,13 +4740,13 @@ loaded MIBs are used by AUTOLOAD() to create dynamic methods. Generated methods are inserted into the symbol table so that subsequent calls can avoid AUTOLOAD() and dispatch directly. -=over +=over =item 1. Returns unless method is listed in %FUNCS, %GLOBALS, or is a MIB Leaf node name in a loaded MIB for given class. =item 2. If the method exists in %GLOBALS or is a single instance MIB Leaf -node name from a loaded MIB, _global() generates the method. +node name from a loaded MIB, _global() generates the method. =item 3. If a set_ prefix is present _make_setter() generates the method. @@ -4815,7 +4816,7 @@ Original Code is: Copyright (c) 2002-2003, Regents of the University of California All rights reserved. -Redistribution and use in source and binary forms, with or without +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, @@ -4823,13 +4824,13 @@ modification, are permitted provided that the following conditions are met: * 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 + * 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 +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 diff --git a/lib/SNMP/Info/Layer7/Arbor.pm b/lib/SNMP/Info/Layer7/Arbor.pm new file mode 100644 index 00000000..d6a32317 --- /dev/null +++ b/lib/SNMP/Info/Layer7/Arbor.pm @@ -0,0 +1,192 @@ +# SNMP::Info::Layer7::Arbor +# +# Copyright (c) 2017 Rob Woodward +# 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::Layer7::Arbor; + +use strict; +use Exporter; +use SNMP::Info::Layer7; + +@SNMP::Info::Layer7::Arbor::ISA = qw/SNMP::Info::Layer7 Exporter/; +@SNMP::Info::Layer7::Arbor::EXPORT_OK = qw//; + +use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %MUNGE/; + +$VERSION = '3.54'; + +%MIBS = ( + %SNMP::Info::Layer7::MIBS, +); + +%GLOBALS = ( + %SNMP::Info::Layer7::GLOBALS, +); + +%FUNCS = ( + %SNMP::Info::Layer7::FUNCS, + ); + +%MUNGE = ( + %SNMP::Info::Layer7::MUNGE, + ); + +sub vendor { + return 'arbor'; +} + +sub os { + return 'ArbOS'; +} + +sub serial { + my $Arbor = shift; + my $descr = $Arbor->description() || ''; + my $serial = undef; + + $serial = $1 if ( $descr =~ /Serial Number: ([\w\-]+)/i ); + $serial = $1 if ( $descr =~ /Serial: ([\w\-]+)/i ); + + return $serial; +} + +sub model { + my $Arbor = shift; + my $descr = $Arbor->description() || ''; + my $model = undef; + + $model = $1 if ( $descr =~ /Model: ([\w\-]+) /i ); + + return $model; +} + +sub os_ver { + my $Arbor = shift; + my $descr = $Arbor->description() || ''; + my $os_ver = undef; + + $os_ver = $1 if ( $descr =~ /Peakflow \w+ ([\.\d]+) /i ); + + return $os_ver; +} + + +1; +__END__ + +=head1 NAME + +SNMP::Info::Layer7::Arbor - SNMP Interface to Arbor appliances + +=head1 AUTHORS + +Rob Woodward + +=head1 SYNOPSIS + + # Let SNMP::Info determine the correct subclass for you. + my $Arbor = new SNMP::Info( + AutoSpecify => 1, + Debug => 1, + DestHost => 'myrouter', + Community => 'public', + Version => 2 + ) + or die "Can't connect to DestHost.\n"; + + my $class = $Arbor->class(); + print "SNMP::Info determined this device to fall under subclass : $class\n"; + +=head1 DESCRIPTION + +Subclass for Arbor appliances + +=head2 Inherited Classes + +=over + +=item SNMP::Info::Layer7 + +=back + +=head2 Required MIBs + +=over + +=item Inherited Classes' MIBs + +See L for its own MIB requirements. + +=back + +=head1 GLOBALS + +These are methods that return scalar value from SNMP + +=over + +=item $Arbor->vendor() + +Returns 'Arbor'. + +=item $Arbor->os() + +Returns 'arbos'. + +=item $Arbor->os_ver() + +Release extracted from C. + +=item $Arbor->model() + +Model extracted from C. + +=item $Arbor->serial() + +Returns serial number extracted from C. + +=back + +=head2 Globals imported from SNMP::Info::Layer7 + +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. + +=over + +=back + +=head2 Table Methods imported from SNMP::Info::Layer7 + +See documentation in L for details. + +=cut From 1fdc486cd50817dbab9c11246d6c270685cde590 Mon Sep 17 00:00:00 2001 From: "Eric A. Miller" Date: Mon, 16 Apr 2018 23:29:24 -0400 Subject: [PATCH 2/2] Add Layer7::Arbor test class POD updates --- Changes | 1 + MANIFEST | 1 + META.json | 8 +++ META.yml | 6 ++ README | 43 ++++++++---- lib/SNMP/Info.pm | 8 ++- lib/SNMP/Info/Layer7/Arbor.pm | 5 +- xt/lib/Test/SNMP/Info/Layer7/Arbor.pm | 95 +++++++++++++++++++++++++++ 8 files changed, 148 insertions(+), 19 deletions(-) create mode 100644 xt/lib/Test/SNMP/Info/Layer7/Arbor.pm diff --git a/Changes b/Changes index d8190fda..e28e73a8 100644 --- a/Changes +++ b/Changes @@ -1,6 +1,7 @@ Version 3.55 [NEW FEATURES] + * #258 Add support for Arbor devices (robwwd) * #253 Nexans switch support (paecker) * #142 Sixnet Switch Support diff --git a/MANIFEST b/MANIFEST index 1f64a8f1..a98e171d 100644 --- a/MANIFEST +++ b/MANIFEST @@ -257,6 +257,7 @@ xt/lib/Test/SNMP/Info/Layer3/VMware.pm xt/lib/Test/SNMP/Info/Layer3/VyOS.pm xt/lib/Test/SNMP/Info/Layer7.pm xt/lib/Test/SNMP/Info/Layer7/APC.pm +xt/lib/Test/SNMP/Info/Layer7/Arbor.pm xt/lib/Test/SNMP/Info/Layer7/CiscoIPS.pm xt/lib/Test/SNMP/Info/Layer7/Gigamon.pm xt/lib/Test/SNMP/Info/Layer7/Neoteris.pm diff --git a/META.json b/META.json index 8958cb4e..e95744b2 100644 --- a/META.json +++ b/META.json @@ -255,10 +255,18 @@ "file" : "lib/SNMP/Info/Layer2/Netgear.pm", "version" : "3.54" }, + "SNMP::Info::Layer2::Nexans" : { + "file" : "lib/SNMP/Info/Layer2/Nexans.pm", + "version" : "3.54" + }, "SNMP::Info::Layer2::Orinoco" : { "file" : "lib/SNMP/Info/Layer2/Orinoco.pm", "version" : "3.54" }, + "SNMP::Info::Layer2::Sixnet" : { + "file" : "lib/SNMP/Info/Layer2/Sixnet.pm", + "version" : "3.54" + }, "SNMP::Info::Layer2::Trapeze" : { "file" : "lib/SNMP/Info/Layer2/Trapeze.pm", "version" : "3.54" diff --git a/META.yml b/META.yml index 373f3588..1d544516 100644 --- a/META.yml +++ b/META.yml @@ -178,9 +178,15 @@ provides: SNMP::Info::Layer2::Netgear: file: lib/SNMP/Info/Layer2/Netgear.pm version: '3.54' + SNMP::Info::Layer2::Nexans: + file: lib/SNMP/Info/Layer2/Nexans.pm + version: '3.54' SNMP::Info::Layer2::Orinoco: file: lib/SNMP/Info/Layer2/Orinoco.pm version: '3.54' + SNMP::Info::Layer2::Sixnet: + file: lib/SNMP/Info/Layer2/Sixnet.pm + version: '3.54' SNMP::Info::Layer2::Trapeze: file: lib/SNMP/Info/Layer2/Trapeze.pm version: '3.54' diff --git a/README b/README index 6a9ccf67..dd6bc140 100644 --- a/README +++ b/README @@ -23,14 +23,14 @@ DEVICES SUPPORTED SYNOPSIS use SNMP::Info; - my $info = new SNMP::Info( + my $info = new SNMP::Info( # Auto Discover more specific Device Class AutoSpecify => 1, Debug => 1, # The rest is passed to SNMP::Session DestHost => 'router', Community => 'public', - Version => 2 + Version => 2 ) or die "Can't connect to device.\n"; my $err = $info->error(); @@ -61,7 +61,7 @@ SYNOPSIS # The CDP Table has table entries different than the interface tables. # So we use c_if to get the map from cdp table to interface table. - my %c_map = reverse %$c_if; + my %c_map = reverse %$c_if; my $c_key = $c_map{$iid}; unless (defined $c_key) { print "\n\n"; @@ -515,6 +515,11 @@ SUBCLASSES See documentation in SNMP::Info::Layer2::Netgear for details. + SNMP::Info::Layer2::Nexans + Subclass for Nexans switches + + See documetion in SNMP::Info::Layer2::Nexans for details. + SNMP::Info::Layer2::NWSS2300 SNMP Interface to Avaya (Trapeze) Wireless Controllers @@ -530,6 +535,11 @@ SUBCLASSES See documentation in SNMP::Info::Layer2::Trapeze for details. + SNMP::Info::Layer2::Sixnet + SNMP Interface to Sixnet industrial switches + + See documentation in SNMP::Info::Layer2::Sixnet for details. + SNMP::Info::Layer2::Ubiquiti SNMP Interface to Ubiquiti Access Points and other devices @@ -650,9 +660,9 @@ SUBCLASSES See documentation in SNMP::Info::Layer3::DLink for details. SNMP::Info::Layer3::Dell - Subclass for Dell PowerConnect switches. D-Link, the IBM - BladeCenter Gigabit Ethernet Switch Module and some Linksys - switches also use this module based upon MIB support. + Subclass for Dell PowerConnect switches. The IBM BladeCenter + Gigabit Ethernet Switch Module and some Linksys switches also + use this module based upon MIB support. See documentation in SNMP::Info::Layer3::Dell for details. @@ -820,6 +830,11 @@ SUBCLASSES See documentation in SNMP::Info::Layer7::APC for details. + SNMP::Info::Layer7::Arbor + Subclass for Arbor appliances + + See documentation in SNMP::Info::Layer7::Arbor for details. + SNMP::Info::Layer7::CiscoIPS Subclass for Cisco IPS devices @@ -1121,7 +1136,7 @@ USAGE This returns a binary encoded string where each digit represents a layer of the OSI model served by the device. - eg: 01000010 means layers 2 (physical) and 7 (Application) + eg: 01000010 means layers 2 (physical) and 7 (Application) are served. Note: This string is 8 digits long. @@ -1602,7 +1617,7 @@ SETTING DATA VIA SNMP # Disable a port administratively my %if_map = reverse %{$info->interfaces()} - $info->set_i_up_admin('down', $if_map{'FastEthernet0/0'}) + $info->set_i_up_admin('down', $if_map{'FastEthernet0/0'}) or die "Couldn't disable the port. ",$info->error(1); NOTE: You must be connected to your device with a "ReadWrite" community @@ -1784,7 +1799,7 @@ EXTENDING SNMP::INFO return 'Fire' if $power =~ /reallyhot/i; return 'Ice' if $power =~ /reallycold/i; - # Else + # Else return $power; } @@ -1848,12 +1863,12 @@ SNMP::INFO INTERNALS '64000' => '64 kbps', '115000' => '115 kpbs', '1500000' => '1.5 Mbps', - '1536000' => 'T1', + '1536000' => 'T1', '1544000' => 'T1', '2000000' => '2.0 Mbps', '2048000' => '2.048 Mbps', '3072000' => 'Dual T1', - '3088000' => 'Dual T1', + '3088000' => 'Dual T1', '4000000' => '4.0 Mbps', '10000000' => '10 Mbps', '11000000' => '11 Mbps', @@ -1875,7 +1890,7 @@ SNMP::INFO INTERNALS '155519000' => 'OC-3', '155520000' => 'OC-3', '400000000' => '400 Mbps', - '599040000' => 'ATM on OC-12', + '599040000' => 'ATM on OC-12', '622000000' => 'OC-12', '622080000' => 'OC-12', '1000000000' => '1.0 Gbps', @@ -2157,8 +2172,8 @@ COPYRIGHT AND LICENSE * 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 + * 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 diff --git a/lib/SNMP/Info.pm b/lib/SNMP/Info.pm index f9e29c92..35a48ef7 100644 --- a/lib/SNMP/Info.pm +++ b/lib/SNMP/Info.pm @@ -995,10 +995,16 @@ See documentation in L for details. =item SNMP::Info::Layer7::APC -Subclass for APC UPS devices +Subclass for APC UPS devices See documentation in L for details. +=item SNMP::Info::Layer7::Arbor + +Subclass for Arbor appliances + +See documentation in L for details. + =item SNMP::Info::Layer7::CiscoIPS Subclass for Cisco IPS devices diff --git a/lib/SNMP/Info/Layer7/Arbor.pm b/lib/SNMP/Info/Layer7/Arbor.pm index d6a32317..78e9cdec 100644 --- a/lib/SNMP/Info/Layer7/Arbor.pm +++ b/lib/SNMP/Info/Layer7/Arbor.pm @@ -97,6 +97,7 @@ sub os_ver { 1; + __END__ =head1 NAME @@ -181,10 +182,6 @@ See documentation in L for details. These are methods that return tables of information in the form of a reference to a hash. -=over - -=back - =head2 Table Methods imported from SNMP::Info::Layer7 See documentation in L for details. diff --git a/xt/lib/Test/SNMP/Info/Layer7/Arbor.pm b/xt/lib/Test/SNMP/Info/Layer7/Arbor.pm new file mode 100644 index 00000000..4a403056 --- /dev/null +++ b/xt/lib/Test/SNMP/Info/Layer7/Arbor.pm @@ -0,0 +1,95 @@ +# Test::SNMP::Info::Layer7::Arbor +# +# Copyright (c) 2018 Rob Woodward +# 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 Test::SNMP::Info::Layer7::Arbor; + +use Test::Class::Most parent => 'My::Test::Class'; + +use SNMP::Info::Layer7::Arbor; + +sub setup : Tests(setup) { + my $test = shift; + $test->SUPER::setup; + + # Start with a common cache that will serve most tests + my $cache_data = { + '_layers' => 72, + '_description' => 'Peakflow TMS 8.2 Model: TMS-2800-40G Serial: CT24227201ZQ', + '_id' => '.1.3.6.1.4.1.9694.1.4', + 'store' => {}, + }; + $test->{info}->cache($cache_data); +} + +sub os : Tests(2) { + my $test = shift; + + can_ok($test->{info}, 'os'); + is($test->{info}->os(), 'ArbOS', q(OS returns 'ArbOS')); +} + +sub os_ver : Tests(3) { + my $test = shift; + + can_ok($test->{info}, 'os_ver'); + is($test->{info}->os_ver(), '8.2', q(OS version has expected value)); + + $test->{info}->clear_cache(); + is($test->{info}->os_ver(), undef, + q(No description returns undef OS version)); +} + +sub serial : Tests(3) { + my $test = shift; + + can_ok($test->{info}, 'serial'); + is($test->{info}->serial(), 'CT24227201ZQ', q(Serial has expected value)); + + $test->{info}->clear_cache(); + is($test->{info}->serial(), undef, q(No data returns undef serial)); +} + +sub vendor : Tests(2) { + my $test = shift; + + can_ok($test->{info}, 'vendor'); + is($test->{info}->vendor(), 'arbor', q(Vendor returns 'arbor')); +} + +sub model : Tests(3) { + my $test = shift; + + can_ok($test->{info}, 'model'); + is($test->{info}->model(), 'TMS-2800-40G', q(Model has expected value)); + + $test->{info}->clear_cache(); + is($test->{info}->model(), undef, q(No description returns undef model)); +} + +1; \ No newline at end of file