Compare commits
	
		
			174 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 98e8e57747 | ||
|  | 1e5eda927c | ||
|  | c6eb73bc7b | ||
|  | c49d8ab921 | ||
|  | 27b310ee68 | ||
|  | f6d0fb1d7e | ||
|  | ddc5fd8c96 | ||
|  | 26b13fbcd4 | ||
|  | 91b98085f6 | ||
|  | 1c948d6e45 | ||
|  | 76cbb05f19 | ||
|  | e7fcd98107 | ||
|  | 090d94191b | ||
|  | 2c3a6a3c6e | ||
|  | 814083e2fa | ||
|  | 7621b30bc2 | ||
|  | 9e2e55dcb3 | ||
|  | f8a1d5bc7a | ||
|  | 1a65be101e | ||
|  | 4c5d0a5695 | ||
|  | f8b3381d16 | ||
|  | 8a41e5063a | ||
|  | 24a84cdc25 | ||
|  | 25354e1f3e | ||
|  | 2025044952 | ||
|  | d00dcdad85 | ||
|  | fc069c13f5 | ||
|  | 69430f4a21 | ||
|  | a83855157b | ||
|  | 5ce80ba4ee | ||
|  | 16e96d9fcf | ||
|  | ac753c5970 | ||
|  | 313e187399 | ||
|  | f5aaee6c89 | ||
|  | c8b4f8f4fd | ||
|  | 6113dd3b98 | ||
|  | e21f22bb3b | ||
|  | bb4578dea5 | ||
|  | e83ca6fbe3 | ||
|  | ae9963cf85 | ||
|  | 650aef9c2d | ||
|  | 397b14da22 | ||
|  | 0f00322e03 | ||
|  | e2b688077e | ||
|  | 4afbd37cbd | ||
|  | 40d3340ac5 | ||
|  | 9bb71d3df7 | ||
|  | 4860447b06 | ||
|  | 445b3f19a3 | ||
|  | 32efd26999 | ||
|  | f2f95150bd | ||
|  | f210bf8812 | ||
|  | c30e1a2446 | ||
|  | 10392fc08e | ||
|  | df10473fb5 | ||
|  | 6505e7e85f | ||
|  | ffd80722b8 | ||
|  | 6bd5bb3dda | ||
|  | 83dec3c1d6 | ||
|  | 82f2a83eec | ||
|  | 5194af9d91 | ||
|  | a4c76d2fb9 | ||
|  | 57a35075fa | ||
|  | fb69a60b45 | ||
|  | 2625381e5b | ||
|  | 1c048320a6 | ||
|  | c5c25cee7f | ||
|  | dee8177a67 | ||
|  | abbe040351 | ||
|  | 29a0f849f1 | ||
|  | 7e524f46c6 | ||
|  | 1146e99de2 | ||
|  | 6740929d41 | ||
|  | 831788c1c9 | ||
|  | 7e9d4520af | ||
|  | c4317e6e6b | ||
|  | e4e3debce0 | ||
|  | a5b7431070 | ||
|  | 054808f59d | ||
|  | 0b313d627e | ||
|  | 9813b9db90 | ||
|  | 9a4e024abb | ||
|  | 04a669157f | ||
|  | a364c1512d | ||
|  | 0451e6f0a6 | ||
|  | b7f87d9e82 | ||
|  | e2713fb57a | ||
|  | c8eff78d34 | ||
|  | 04ca5793fa | ||
|  | 83d00ee9c7 | ||
|  | bf56ed2540 | ||
|  | e75aba14b4 | ||
|  | 5d2d2d416f | ||
|  | 62799bfc9d | ||
|  | df8fbc3c03 | ||
|  | 604de81ab8 | ||
|  | ed14b09567 | ||
|  | 800758815c | ||
|  | 058b74bd63 | ||
|  | 02a52a4e09 | ||
|  | 74ddc93f7f | ||
|  | eb8af0c81b | ||
|  | bd49274808 | ||
|  | 8b1547c589 | ||
|  | c093f83848 | ||
|  | c0b28c38c5 | ||
|  | 4621a0898f | ||
|  | 6f02e1035f | ||
|  | d4ae9237a6 | ||
|  | 914eb05a60 | ||
|  | 4da17227c1 | ||
|  | 20014cab29 | ||
|  | 9d62361c8a | ||
|  | 260992b7bf | ||
|  | b9cd429551 | ||
|  | 2d18a75ad7 | ||
|  | 0cfc501f83 | ||
|  | 44b19153f1 | ||
|  | 433b87b9df | ||
|  | f9464bcd6c | ||
|  | f5c5ec202a | ||
|  | 4b64a70830 | ||
|  | 4c8f7e298e | ||
|  | 2d539be214 | ||
|  | c35d5814b4 | ||
|  | 7d19ad401b | ||
|  | 985577ce79 | ||
|  | 24e20101d5 | ||
|  | 76c884eb9f | ||
|  | 7041dbab27 | ||
|  | 661051fde4 | ||
|  | 36cba5ce18 | ||
|  | 4753f30c53 | ||
|  | d719e240d2 | ||
|  | e35faee278 | ||
|  | fd3417a09a | ||
|  | 1719709648 | ||
|  | d37aa3378e | ||
|  | f017d32860 | ||
|  | 7b23edcb29 | ||
|  | e48c4b4e84 | ||
|  | aeca44c7aa | ||
|  | af6ae8e419 | ||
|  | 5cf88ba3b7 | ||
|  | f901ba5591 | ||
|  | 7deea96bc3 | ||
|  | 48dfb9bd08 | ||
|  | 85372559fa | ||
|  | 98972b80ef | ||
|  | d950244232 | ||
|  | fd898829c3 | ||
|  | b0158628bb | ||
|  | 0f69a7b391 | ||
|  | 72773117e5 | ||
|  | 06806f5a6e | ||
|  | a01c785ec8 | ||
|  | 502e206371 | ||
|  | 8fba1bc6a9 | ||
|  | f43803d6d4 | ||
|  | 338cba6350 | ||
|  | 2a15066062 | ||
|  | add86bc566 | ||
|  | e9b4eaaeb9 | ||
|  | 07605051f5 | ||
|  | 998356484b | ||
|  | e97617ad60 | ||
|  | 9685c3afa8 | ||
|  | c209b9a72f | ||
|  | 4999b769ba | ||
|  | d8b5ba2161 | ||
|  | 6f4a4a91cf | ||
|  | 0049f0d72e | ||
|  | 4ea66fc0fd | ||
|  | 8426620572 | 
							
								
								
									
										31
									
								
								.github/issue_template.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								.github/issue_template.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,31 @@ | |||||||
|  | <!--- Provide a general summary of the issue in the Title above --> | ||||||
|  | <!--- https://guides.github.com/features/mastering-markdown/#examples --> | ||||||
|  |  | ||||||
|  | ## Expected Behavior | ||||||
|  | <!--- If you're describing a bug, tell us what should happen --> | ||||||
|  | <!--- If you're suggesting a change/improvement, tell us how it should work --> | ||||||
|  |  | ||||||
|  | ## Current Behavior | ||||||
|  | <!--- If describing a bug, tell us what happens instead of the expected behavior --> | ||||||
|  | <!--- If suggesting a change/improvement, explain the difference from current behavior --> | ||||||
|  |  | ||||||
|  | ## Possible Solution | ||||||
|  | <!--- Not obligatory, but suggest a fix/reason for the bug, --> | ||||||
|  | <!--- or ideas how to implement the addition or change --> | ||||||
|  |  | ||||||
|  | ## Steps to Reproduce (for bugs) | ||||||
|  | <!--- Provide a link to a live example, or an unambiguous set of steps to --> | ||||||
|  | <!--- reproduce this bug. Include code to reproduce, if relevant, or attach screenshots --> | ||||||
|  | 1.  | ||||||
|  | 2.  | ||||||
|  | 3.  | ||||||
|  | 4.  | ||||||
|  |  | ||||||
|  | ## Context | ||||||
|  | <!--- How has this issue affected you? What are you trying to accomplish? --> | ||||||
|  | <!--- Providing context helps us come up with a solution that is most useful in the real world --> | ||||||
|  |  | ||||||
|  | ## Your Environment | ||||||
|  | <!--- Include as many relevant details about the environment you experienced the bug in --> | ||||||
|  | * SNMP::Info version used:  | ||||||
|  | * Netdisco version (if used):  | ||||||
							
								
								
									
										19
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										19
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -1,9 +1,12 @@ | |||||||
| *.db | *.swp | ||||||
| SNMP | *.pid | ||||||
| *.komodo* | test.pl | ||||||
| blib/ |  | ||||||
| META.* |  | ||||||
| MYMETA.* | MYMETA.* | ||||||
| Makefile | *.tar.gz | ||||||
| Makefile.old | MANIFEST.* | ||||||
| pm_to_blib | *.komodo* | ||||||
|  | Makefile* | ||||||
|  | Build | ||||||
|  | _build | ||||||
|  | blib | ||||||
|  | cover_db | ||||||
|   | |||||||
							
								
								
									
										29
									
								
								.travis.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								.travis.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,29 @@ | |||||||
|  | language: perl | ||||||
|  | addons: | ||||||
|  |   apt: | ||||||
|  |     packages: | ||||||
|  |       - jq | ||||||
|  |       - libsnmp-dev | ||||||
|  | branches: | ||||||
|  |   only: | ||||||
|  |     - /^3\.\d{2}$/ | ||||||
|  |     - 'master' | ||||||
|  | before_install: | ||||||
|  |   - mkdir ~/netdisco-mibs | ||||||
|  |   - cd ~/netdisco-mibs | ||||||
|  | install: | ||||||
|  |   - curl -sL https://github.com/netdisco/netdisco-mibs/releases/download/4.004/netdisco-mibs.tar.gz | tar --strip-components=1 -zxf - | ||||||
|  |   - cpanm --quiet --notest PkgConfig Test::CChecker Alien::zlib::Static Alien::OpenSSL::Static Alien::SNMP::MAXTC | ||||||
|  | before_script: | ||||||
|  |   - 'cd ${TRAVIS_BUILD_DIR}' | ||||||
|  | script: | ||||||
|  |   - > | ||||||
|  |     perl Build.PL && | ||||||
|  |     PERL_MM_USE_DEFAULT=1 ./Build installdeps --cpan_client 'cpanm --quiet --notest' && | ||||||
|  |     ./Build test --test_files t/ --test_files xt/ | ||||||
|  | notifications: | ||||||
|  |   irc: | ||||||
|  |     on_success: change | ||||||
|  |     on_failure: always | ||||||
|  |     channels: | ||||||
|  |       - 'chat.freenode.net#netdisco' | ||||||
							
								
								
									
										49
									
								
								Build.PL
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										49
									
								
								Build.PL
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,49 @@ | |||||||
|  | use strict; | ||||||
|  | use warnings; | ||||||
|  | use Module::Build; | ||||||
|  |  | ||||||
|  | Module::Build->new( | ||||||
|  |   module_name => 'SNMP::Info', | ||||||
|  |   license     => 'bsd', | ||||||
|  |   dist_author => 'Eric A. Miller <emiller@cpan.org>', | ||||||
|  |   # dynamic_config => 1, | ||||||
|  |   create_readme => 1, | ||||||
|  |   configure_requires => { | ||||||
|  |     'Module::Build' => '0.42', | ||||||
|  |   }, | ||||||
|  |   # build_requires => { | ||||||
|  |   # }, | ||||||
|  |   requires => { | ||||||
|  |     'SNMP' => '0', | ||||||
|  |     'Math::BigInt' => '0', | ||||||
|  |   }, | ||||||
|  |   recommends => { | ||||||
|  |     'PPI' => '0', | ||||||
|  |     'Class::ISA' => '0', | ||||||
|  |     'Module::Info' => '0', | ||||||
|  |     'Module::Load' => '0', | ||||||
|  |     'File::Slurp' => '0', | ||||||
|  |   }, | ||||||
|  |   test_requires => { | ||||||
|  |     'Test::More' => '0.88', | ||||||
|  |     'Test::Distribution' => '0', | ||||||
|  |     'Test::Class::Most'  => '0', | ||||||
|  |     'Test::MockObject::Extends' => '0', | ||||||
|  |     'File::Find' => '0', | ||||||
|  |     'Path::Class' => '0', | ||||||
|  |     'File::Slurper' => '0', | ||||||
|  |     'Test::Exception' => '0.43', | ||||||
|  |   }, | ||||||
|  |   # script_files => [ | ||||||
|  |   # ], | ||||||
|  |   # share_dir => 'share', | ||||||
|  |   meta_merge => { | ||||||
|  |     resources => { | ||||||
|  |       homepage => 'http://netdisco.org/', | ||||||
|  |       bugtracker => 'https://github.com/netdisco/snmp-info/issues', | ||||||
|  |       repository => 'https://github.com/netdisco/snmp-info', | ||||||
|  |       MailingList => 'https://lists.sourceforge.net/lists/listinfo/snmp-info-users', | ||||||
|  |       IRC => 'irc://irc.freenode.org/#netdisco', | ||||||
|  |     }, | ||||||
|  |   }, | ||||||
|  | )->create_build_script; | ||||||
| @@ -1,4 +1,213 @@ | |||||||
| SNMP::Info - Friendly OO-style interface to Network devices using SNMP. | Version 3.53 (2018-03-22) | ||||||
|  | 
 | ||||||
|  |   [NEW FEATURES] | ||||||
|  | 
 | ||||||
|  |   * #12 add Cisco PortFast support via CiscoStpExtensions::i_faststart_enabled | ||||||
|  | 
 | ||||||
|  |   [ENHANCEMENTS] | ||||||
|  | 
 | ||||||
|  |   * Report serial/version on Netgear FSM (paecker) | ||||||
|  |   * Add test harness and expand developer test coverage | ||||||
|  |   * Add back the base (RFC) MIBs for when net-snmp does not have them builtin | ||||||
|  | 
 | ||||||
|  |   [BUG FIXES] | ||||||
|  | 
 | ||||||
|  |   *  Fix AUTOLOAD / can() bug that could result in DESTROY being redefined and | ||||||
|  |      dynamic methods not being added to the symbol table. | ||||||
|  | 
 | ||||||
|  | version 3.52 (2018-03-19) | ||||||
|  | 
 | ||||||
|  |   [ENHANCEMENTS] | ||||||
|  | 
 | ||||||
|  |   * set fallback for nonmatching interfaces in Cumulus class | ||||||
|  |   * better interface naming for Ubiquiti | ||||||
|  |   * modify mock utility to work under a perlbrew environment | ||||||
|  | 
 | ||||||
|  | version 3.50 (2018-03-14) | ||||||
|  | 
 | ||||||
|  |   [ENHANCEMENTS] | ||||||
|  | 
 | ||||||
|  |   * #198 Add Support for Gigamon devices | ||||||
|  | 
 | ||||||
|  |   [BUG FIXES] | ||||||
|  | 
 | ||||||
|  |   * #226 Avaya VSP devices - no ifAlias | ||||||
|  |   * #227 Remove bogus can() check in _set() | ||||||
|  |   * Fix SNMP::Info::IEEE802dot3ad when more than 1 LAG  | ||||||
|  | 
 | ||||||
|  | version 3.49 (2018-03-03) | ||||||
|  | 
 | ||||||
|  |   [ENHANCEMENTS] | ||||||
|  | 
 | ||||||
|  |   * Better Layer3::Cumulus interface naming | ||||||
|  | 
 | ||||||
|  |   [BUG FIXES] | ||||||
|  | 
 | ||||||
|  |   * Use GitHub for MIBs download for testing, instead of sf.net | ||||||
|  | 
 | ||||||
|  | version 3.48 (2018-03-03) | ||||||
|  | 
 | ||||||
|  |   [ENHANCEMENTS] | ||||||
|  | 
 | ||||||
|  |   * Add Layer3::Cumulus for Cumulus Networks devices | ||||||
|  | 
 | ||||||
|  | version 3.47 (2018-02-27) | ||||||
|  | 
 | ||||||
|  |   [ENHANCEMENTS] | ||||||
|  | 
 | ||||||
|  |   * Add LLDP-MIB::lldpXMedRemInventoryTable methods | ||||||
|  | 
 | ||||||
|  | version 3.46 (2018-02-17) | ||||||
|  | 
 | ||||||
|  |   [ENHANCEMENTS] | ||||||
|  | 
 | ||||||
|  |   * Add method to get err-disable cause for interfaces on Cisco | ||||||
|  | 
 | ||||||
|  | version 3.45 (2018-02-14) | ||||||
|  | 
 | ||||||
|  |   [ENHANCEMENTS] | ||||||
|  | 
 | ||||||
|  |   * Enable Layer3::Foundry for Brocade VDX platform | ||||||
|  | 
 | ||||||
|  |   [BUG FIXES] | ||||||
|  | 
 | ||||||
|  |   * #222 #238 #239 handle BayStack switches with port index 128 (zoeloe) | ||||||
|  | 
 | ||||||
|  | version 3.44 (2018-02-12) | ||||||
|  | 
 | ||||||
|  |   [ENHANCEMENTS] | ||||||
|  | 
 | ||||||
|  |   * Improve F10 OS version detection (laelly) | ||||||
|  |   * Better IPv6 prefix derivation | ||||||
|  | 
 | ||||||
|  | version 3.43 (2018-02-02) | ||||||
|  | 
 | ||||||
|  |   [BUG FIXES] | ||||||
|  | 
 | ||||||
|  |   * Fix identification of Brocade CES | ||||||
|  | 
 | ||||||
|  | version 3.42 (2018-02-02) | ||||||
|  | 
 | ||||||
|  |   [ENHANCEMENTS] | ||||||
|  | 
 | ||||||
|  |   * IPv6 Prefix Length support via IPv6::ipv6_addr_prefixlength | ||||||
|  | 
 | ||||||
|  |   [BUG FIXES] | ||||||
|  | 
 | ||||||
|  |   * Fix test for updated snmplabs.com data | ||||||
|  | 
 | ||||||
|  | version 3.41 (2018-02-01) | ||||||
|  | 
 | ||||||
|  |   [BUG FIXES] | ||||||
|  | 
 | ||||||
|  |   * Fixes to distriution metadata | ||||||
|  | 
 | ||||||
|  | version 3.40 (2018-01-28) | ||||||
|  | 
 | ||||||
|  |   [ENHANCEMENTS] | ||||||
|  | 
 | ||||||
|  |   * #240 Support for CheckPoint devies through SNMP | ||||||
|  |   * #240 Cisco SB switches fixup | ||||||
|  |   * #244 Add Adtran support | ||||||
|  |   * #241 Vyatta/VyOS support | ||||||
|  |   * #246 Nexus VRF support (works with Netdisco) | ||||||
|  |   * #244 Improve Juniper model reporting | ||||||
|  |   * #240 Improve H3C reporting | ||||||
|  | 
 | ||||||
|  |   [BUG FIXES] | ||||||
|  | 
 | ||||||
|  |   * #243 Nexus additional debug lines should be hidden | ||||||
|  | 
 | ||||||
|  | version 3.39 (2017-12-17) | ||||||
|  | 
 | ||||||
|  |   [ENHANCEMENTS] | ||||||
|  | 
 | ||||||
|  |   * #236 Enhanced Ubiquiti device support (L. Begnaud) | ||||||
|  |   * add HP J9774A model (H. Teulahti) | ||||||
|  | 
 | ||||||
|  |   [BUG FIXES] | ||||||
|  | 
 | ||||||
|  |   * fix scripts (F. Mass) | ||||||
|  |   * fix CiscoASA typos (laelly) | ||||||
|  | 
 | ||||||
|  | version 3.38 (2017-10-23) | ||||||
|  | 
 | ||||||
|  |   [ENHANCEMENTS] | ||||||
|  | 
 | ||||||
|  |   * Layer2::Airespace several newer 802.11 data rates added | ||||||
|  | 
 | ||||||
|  |   [BUG FIXES] | ||||||
|  | 
 | ||||||
|  |   * #232 Improve generic Info::Layer3 serial number detection | ||||||
|  | 
 | ||||||
|  | version 3.37 (2017-07-11) | ||||||
|  | 
 | ||||||
|  |   [ENHANCEMENTS] | ||||||
|  | 
 | ||||||
|  |   * Layer3::Juniper fixed to return os_ver for JUNOS 14.x and higher | ||||||
|  | 
 | ||||||
|  | version 3.36 (2017-06-28) | ||||||
|  | 
 | ||||||
|  |   [ENHANCEMENTS] | ||||||
|  | 
 | ||||||
|  |   * Migrate to Module::Build for distribution maintenance | ||||||
|  | 
 | ||||||
|  | version 3.35 (2017-06-28) | ||||||
|  | 
 | ||||||
|  |   [ENHANCEMENTS] | ||||||
|  | 
 | ||||||
|  |   * Include loading of LLDP-EXT-MED-MIB in LLDP.pm | ||||||
|  | 
 | ||||||
|  |   [BUG FIXES] | ||||||
|  | 
 | ||||||
|  |   * #180 support CiscoConfig on Nexus (sf.net:scratchfury) | ||||||
|  |   * #50 remove interface specific part from vrf interfaces on IOS (W. Vandersmissen) | ||||||
|  |   * #211 f5 class should respect UseEnums when faking i_type | ||||||
|  | 
 | ||||||
|  | version 3.34 (2016-11-20) | ||||||
|  | 
 | ||||||
|  |   [ENHANCEMENTS] | ||||||
|  | 
 | ||||||
|  |   * Support Cisco IPS Modules homed on the Cisco ASA (M. Kraus) | ||||||
|  | 
 | ||||||
|  |   [BUG FIXES] | ||||||
|  | 
 | ||||||
|  |   * Serial number on Nexus 9372 (genereic check for ID before using) (M. Caines) | ||||||
|  | 
 | ||||||
|  | version 3.33 (2016-04-27) | ||||||
|  | 
 | ||||||
|  |   [ENHANCEMENTS] | ||||||
|  | 
 | ||||||
|  |   * Move author-only tests to xt directory so they aren't run on installation | ||||||
|  |     by users | ||||||
|  | 
 | ||||||
|  |   [BUG FIXES] | ||||||
|  | 
 | ||||||
|  |   * Correct device serial number reporting for Cisco Nexus 5k switches with | ||||||
|  |     software version >= 7 | ||||||
|  | 
 | ||||||
|  | version 3.32 (2016-04-26) | ||||||
|  | 
 | ||||||
|  |   [ENHANCEMENTS] | ||||||
|  | 
 | ||||||
|  |   * Add 200 Mbps and 2.0 Gbps aliases to SPEED_MAP | ||||||
|  |   * Add Palo Alto support | ||||||
|  |   * Add VMware support | ||||||
|  |   * Support for propMultiplexor as ifType | ||||||
|  |   * Add device MAC to APC UPS | ||||||
|  |   * [#61] Report APC model for PDU products | ||||||
|  |   * Removed DeviceMatrix from the distribution | ||||||
|  | 
 | ||||||
|  |   [BUG FIXES] | ||||||
|  | 
 | ||||||
|  |   * Support undefined (noSuchInstance) values in Offline mode | ||||||
|  |   * Do not init table cache if Cache provided by user | ||||||
|  |   * Avoid deep recusion when AUTOLOAD and carp collide | ||||||
|  |   * Detect Cisco VG350s as L3 devices instead of APs | ||||||
|  |   * fix for 'Use of inherited AUTOLOAD for non-method SNMP::Info::Layer2::HP::agg_ports_ifstack() is deprecated' | ||||||
|  |   * Workaround in IPv6.pm to deal with possibly incorrect IPV6-MIB implementations | ||||||
|  |   * [#71] AUTOLOAD typo-catcher search for SNMP::Info no longer anchored | ||||||
|  |   * [#70] Respect version/comm/secname on passed Session obj | ||||||
| 
 | 
 | ||||||
| version 3.31 (2016-01-22) | version 3.31 (2016-01-22) | ||||||
| 
 | 
 | ||||||
| @@ -676,7 +885,7 @@ version 1.05 (11/25/07) - CVS only. No official release | |||||||
|     + Added support for Cisco (Airespace) wireless controllers as new class |     + Added support for Cisco (Airespace) wireless controllers as new class | ||||||
|       L2::Airespace |       L2::Airespace | ||||||
|     + Added support for Nortel Ethernet Routing Switch 2500 series and |     + Added support for Nortel Ethernet Routing Switch 2500 series and | ||||||
|       Business Ethernet Switches (David Siebörger) |       Business Ethernet Switches (David Siebörger) | ||||||
|     + Update of L3::Foundry to support all Foundry devices including newer |     + Update of L3::Foundry to support all Foundry devices including newer | ||||||
|       switches.  Depreciate L2::Foundry. |       switches.  Depreciate L2::Foundry. | ||||||
|     + Added generic device type detection using IANA assigned enterpise |     + Added generic device type detection using IANA assigned enterpise | ||||||
							
								
								
									
										1045
									
								
								DeviceMatrix.txt
									
									
									
									
									
								
							
							
						
						
									
										1045
									
								
								DeviceMatrix.txt
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,177 +0,0 @@ | |||||||
| # SNMP::Info::Layer2::Ubiquiti |  | ||||||
| # $Id$ |  | ||||||
| # |  | ||||||
|  |  | ||||||
| package SNMP::Info::Layer2::Ubiquiti; |  | ||||||
|  |  | ||||||
| use strict; |  | ||||||
| use Exporter; |  | ||||||
| use SNMP::Info::IEEE802dot11; |  | ||||||
| use SNMP::Info::Layer2; |  | ||||||
|  |  | ||||||
| @SNMP::Info::Layer2::Ubiquiti::ISA |  | ||||||
|     = qw/SNMP::Info::IEEE802dot11 SNMP::Info::Layer2 Exporter/; |  | ||||||
| @SNMP::Info::Layer2::Ubiquiti::EXPORT_OK = qw//; |  | ||||||
|  |  | ||||||
| use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; |  | ||||||
|  |  | ||||||
| $VERSION = '3.31'; |  | ||||||
|  |  | ||||||
| %MIBS = ( |  | ||||||
|     %SNMP::Info::Layer2::MIBS, |  | ||||||
|     %SNMP::Info::IEEE802dot11::MIBS, |  | ||||||
|  |  | ||||||
| ); |  | ||||||
|  |  | ||||||
| %GLOBALS |  | ||||||
|     = ( %SNMP::Info::Layer2::GLOBALS, %SNMP::Info::IEEE802dot11::GLOBALS, ); |  | ||||||
|  |  | ||||||
| %FUNCS = ( |  | ||||||
|     %SNMP::Info::Layer2::FUNCS, |  | ||||||
|     %SNMP::Info::IEEE802dot11::FUNCS, |  | ||||||
|  |  | ||||||
| ); |  | ||||||
|  |  | ||||||
| %MUNGE = ( %SNMP::Info::Layer2::MUNGE, %SNMP::Info::IEEE802dot11::MUNGE, ); |  | ||||||
|  |  | ||||||
| sub os { |  | ||||||
|     return 'Ubiquiti'; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| sub os_ver { |  | ||||||
|     my $dot11 = shift; |  | ||||||
|  |  | ||||||
|     my $versions = $dot11->dot11_prod_ver(); |  | ||||||
|  |  | ||||||
|     foreach my $iid ( keys %$versions ) { |  | ||||||
|         my $ver = $versions->{$iid}; |  | ||||||
|         next unless defined $ver; |  | ||||||
| 	return $ver; |  | ||||||
|         if ( $ver =~ /([\d\.]+)/ ) { |  | ||||||
|             return $1; |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     return; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| sub vendor { |  | ||||||
|     return 'Ubiquiti Networks, Inc.'; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| sub model { |  | ||||||
|     my $dot11 = shift; |  | ||||||
|  |  | ||||||
|     my $names = $dot11->dot11_prod_name(); |  | ||||||
|  |  | ||||||
|     foreach my $iid ( keys %$names ) { |  | ||||||
|         my $prod = $names->{$iid}; |  | ||||||
|         next unless defined $prod; |  | ||||||
|         return $prod; |  | ||||||
|     } |  | ||||||
|     return; |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 1; |  | ||||||
| __END__ |  | ||||||
|  |  | ||||||
| =head1 NAME |  | ||||||
|  |  | ||||||
| SNMP::Info::Layer2::Ubiquiti - SNMP Interface to Ubiquiti Access Points |  | ||||||
|  |  | ||||||
| =head1 AUTHOR |  | ||||||
|  |  | ||||||
| Max Kosmach |  | ||||||
|  |  | ||||||
| =head1 SYNOPSIS |  | ||||||
|  |  | ||||||
|  # Let SNMP::Info determine the correct subclass for you.  |  | ||||||
|  my $ubnt = new SNMP::Info( |  | ||||||
|                           AutoSpecify => 1, |  | ||||||
|                           Debug       => 1, |  | ||||||
|                           DestHost    => 'myswitch', |  | ||||||
|                           Community   => 'public', |  | ||||||
|                           Version     => 2 |  | ||||||
|                         )  |  | ||||||
|     or die "Can't connect to DestHost.\n"; |  | ||||||
|  |  | ||||||
|  my $class = $ubnt->class(); |  | ||||||
|  print "SNMP::Info determined this device to fall under subclass : $class\n"; |  | ||||||
|  |  | ||||||
| =head1 DESCRIPTION |  | ||||||
|  |  | ||||||
| Provides abstraction to the configuration information obtainable from |  | ||||||
| Ubiquiti Access Point through SNMP. |  | ||||||
|  |  | ||||||
| For speed or debugging purposes you can call the subclass directly, but not |  | ||||||
| after determining a more specific class using the method above.  |  | ||||||
|  |  | ||||||
|  my $ubnt = new SNMP::Info::Layer2::Ubiquiti(...); |  | ||||||
|  |  | ||||||
| =head2 Inherited Classes |  | ||||||
|  |  | ||||||
| =over |  | ||||||
|  |  | ||||||
| =item SNMP::Info::Layer2 |  | ||||||
|  |  | ||||||
| =item SNMP::Info::IEEE802dot11 |  | ||||||
|  |  | ||||||
| =back |  | ||||||
|  |  | ||||||
| =head2 Required MIBs |  | ||||||
|  |  | ||||||
| None. |  | ||||||
|  |  | ||||||
| =head2 Inherited MIBs |  | ||||||
|  |  | ||||||
| See L<SNMP::Info::Layer2/"Required MIBs"> for its MIB requirements. |  | ||||||
|  |  | ||||||
| See L<SNMP::Info::IEEE802dot11/"Required MIBs"> for its MIB requirements. |  | ||||||
|  |  | ||||||
| =head1 GLOBALS |  | ||||||
|  |  | ||||||
| These are methods that return scalar value from SNMP |  | ||||||
|  |  | ||||||
| =over |  | ||||||
|  |  | ||||||
| =item $ubnt->vendor() |  | ||||||
|  |  | ||||||
| Returns 'Ubiquiti Networks, Inc.' |  | ||||||
|  |  | ||||||
| =item $ubnt->model() |  | ||||||
|  |  | ||||||
| Returns the model extracted from C<dot11manufacturerProductName>. |  | ||||||
|  |  | ||||||
| =item $ubnt->os() |  | ||||||
|  |  | ||||||
| Returns 'Ubiquiti' |  | ||||||
|  |  | ||||||
| =item $ubnt->os_ver() |  | ||||||
|  |  | ||||||
| Returns the software version extracted from C<dot11manufacturerProductVersion>. |  | ||||||
|  |  | ||||||
| =back |  | ||||||
|  |  | ||||||
| =head2 Global Methods imported from SNMP::Info::Layer2 |  | ||||||
|  |  | ||||||
| See L<SNMP::Info::Layer2/"GLOBALS"> for details. |  | ||||||
|  |  | ||||||
| =head2 Global Methods imported from SNMP::Info::IEEE802dot11 |  | ||||||
|  |  | ||||||
| See L<SNMP::Info::IEEE802dot11/"GLOBALS"> for details. |  | ||||||
|  |  | ||||||
| =head1 TABLE METHODS |  | ||||||
|  |  | ||||||
| These are methods that return tables of information in the form of a reference |  | ||||||
| to a hash. |  | ||||||
|  |  | ||||||
| =head2 Table Methods imported from SNMP::Info::Layer2 |  | ||||||
|  |  | ||||||
| See L<SNMP::Info::Layer2/"TABLE METHODS"> for details. |  | ||||||
|  |  | ||||||
| =head2 Table Methods imported from SNMP::Info::IEEE802dot11 |  | ||||||
|  |  | ||||||
| See L<SNMP::Info::IEEE802dot11/"TABLE METHODS"> for details. |  | ||||||
|  |  | ||||||
| =cut |  | ||||||
| @@ -1,5 +1,5 @@ | |||||||
| All code from version 0.7 on | All code from version 0.7 on | ||||||
| Copyright (c) 2003-2009 Max Baker and SNMP::Info Developers | Copyright (c) 2003-2016 Max Baker and SNMP::Info Developers | ||||||
| All rights reserved. | All rights reserved. | ||||||
| 
 | 
 | ||||||
| Original Code | Original Code | ||||||
							
								
								
									
										270
									
								
								MANIFEST
									
									
									
									
									
								
							
							
						
						
									
										270
									
								
								MANIFEST
									
									
									
									
									
								
							| @@ -1,126 +1,148 @@ | |||||||
| ChangeLog | Build.PL | ||||||
| COPYRIGHT | Changes | ||||||
| DEVELOP | contrib/DEVELOP | ||||||
| DeviceMatrix.txt | contrib/util/docmunge | ||||||
| Info.pm | contrib/util/make_dev_matrix.pl | ||||||
| Info/AdslLine.pm | contrib/util/make_snmpdata.pl | ||||||
| Info/Aggregate.pm | contrib/util/push_ver | ||||||
| Info/Airespace.pm | contrib/util/run_test | ||||||
| Info/AMAP.pm | contrib/util/test_class.pl | ||||||
| Info/Bridge.pm | contrib/util/test_class_mocked.pl | ||||||
| Info/CDP.pm | lib/SNMP/Info.pm | ||||||
| Info/CiscoAgg.pm | lib/SNMP/Info/AdslLine.pm | ||||||
| Info/CiscoConfig.pm | lib/SNMP/Info/Aggregate.pm | ||||||
| Info/CiscoPortSecurity.pm | lib/SNMP/Info/Airespace.pm | ||||||
| Info/CiscoPower.pm | lib/SNMP/Info/AMAP.pm | ||||||
| Info/CiscoQOS.pm | lib/SNMP/Info/Bridge.pm | ||||||
| Info/CiscoRTT.pm | lib/SNMP/Info/CDP.pm | ||||||
| Info/CiscoStack.pm | lib/SNMP/Info/CiscoAgg.pm | ||||||
| Info/CiscoStats.pm | lib/SNMP/Info/CiscoConfig.pm | ||||||
| Info/CiscoStpExtensions.pm | lib/SNMP/Info/CiscoPortSecurity.pm | ||||||
| Info/CiscoVTP.pm | lib/SNMP/Info/CiscoPower.pm | ||||||
| Info/EDP.pm | lib/SNMP/Info/CiscoQOS.pm | ||||||
| Info/Entity.pm | lib/SNMP/Info/CiscoRTT.pm | ||||||
| Info/EtherLike.pm | lib/SNMP/Info/CiscoStack.pm | ||||||
| Info/FDP.pm | lib/SNMP/Info/CiscoStats.pm | ||||||
| Info/IEEE802dot11.pm | lib/SNMP/Info/CiscoStpExtensions.pm | ||||||
| Info/IEEE802dot3ad.pm | lib/SNMP/Info/CiscoVTP.pm | ||||||
| Info/IPv6.pm | lib/SNMP/Info/EDP.pm | ||||||
| Info/Layer1.pm | lib/SNMP/Info/Entity.pm | ||||||
| Info/Layer1/Allied.pm | lib/SNMP/Info/EtherLike.pm | ||||||
| Info/Layer1/Asante.pm | lib/SNMP/Info/FDP.pm | ||||||
| Info/Layer1/Bayhub.pm | lib/SNMP/Info/IEEE802dot11.pm | ||||||
| Info/Layer1/Cyclades.pm | lib/SNMP/Info/IEEE802dot3ad.pm | ||||||
| Info/Layer1/S3000.pm | lib/SNMP/Info/IPv6.pm | ||||||
| Info/Layer2.pm | lib/SNMP/Info/Layer1.pm | ||||||
| Info/Layer2/3Com.pm | lib/SNMP/Info/Layer1/Allied.pm | ||||||
| Info/Layer2/Airespace.pm | lib/SNMP/Info/Layer1/Asante.pm | ||||||
| Info/Layer2/Aironet.pm | lib/SNMP/Info/Layer1/Bayhub.pm | ||||||
| Info/Layer2/Allied.pm | lib/SNMP/Info/Layer1/Cyclades.pm | ||||||
| Info/Layer2/Baystack.pm | lib/SNMP/Info/Layer1/S3000.pm | ||||||
| Info/Layer2/C1900.pm | lib/SNMP/Info/Layer2.pm | ||||||
| Info/Layer2/C2900.pm | lib/SNMP/Info/Layer2/3Com.pm | ||||||
| Info/Layer2/Catalyst.pm | lib/SNMP/Info/Layer2/Adtran.pm | ||||||
| Info/Layer2/Centillion.pm | lib/SNMP/Info/Layer2/Airespace.pm | ||||||
| Info/Layer2/Cisco.pm | lib/SNMP/Info/Layer2/Aironet.pm | ||||||
| Info/Layer2/CiscoSB.pm | lib/SNMP/Info/Layer2/Allied.pm | ||||||
| Info/Layer2/HP.pm | lib/SNMP/Info/Layer2/Baystack.pm | ||||||
| Info/Layer2/HP4000.pm | lib/SNMP/Info/Layer2/C1900.pm | ||||||
| Info/Layer2/HPVC.pm | lib/SNMP/Info/Layer2/C2900.pm | ||||||
| Info/Layer2/Kentrox.pm | lib/SNMP/Info/Layer2/Catalyst.pm | ||||||
| Info/Layer2/N2270.pm | lib/SNMP/Info/Layer2/Centillion.pm | ||||||
| Info/Layer2/NAP222x.pm | lib/SNMP/Info/Layer2/Cisco.pm | ||||||
| Info/Layer2/Netgear.pm | lib/SNMP/Info/Layer2/CiscoSB.pm | ||||||
| Info/Layer2/NWSS2300.pm | lib/SNMP/Info/Layer2/HP.pm | ||||||
| Info/Layer2/Orinoco.pm | lib/SNMP/Info/Layer2/HP4000.pm | ||||||
| Info/Layer2/Trapeze.pm | lib/SNMP/Info/Layer2/HPVC.pm | ||||||
| Info/Layer2/Ubiquiti.pm | lib/SNMP/Info/Layer2/Kentrox.pm | ||||||
| Info/Layer2/ZyXEL_DSLAM.pm | lib/SNMP/Info/Layer2/N2270.pm | ||||||
| Info/Layer3.pm | lib/SNMP/Info/Layer2/NAP222x.pm | ||||||
| Info/Layer3/Aironet.pm | lib/SNMP/Info/Layer2/Netgear.pm | ||||||
| Info/Layer3/AlcatelLucent.pm | lib/SNMP/Info/Layer2/NWSS2300.pm | ||||||
| Info/Layer3/AlteonAD.pm | lib/SNMP/Info/Layer2/Orinoco.pm | ||||||
| Info/Layer3/Altiga.pm | lib/SNMP/Info/Layer2/Trapeze.pm | ||||||
| Info/Layer3/Arista.pm | lib/SNMP/Info/Layer2/Ubiquiti.pm | ||||||
| Info/Layer3/Aruba.pm | lib/SNMP/Info/Layer2/ZyXEL_DSLAM.pm | ||||||
| Info/Layer3/BayRS.pm | lib/SNMP/Info/Layer3.pm | ||||||
| Info/Layer3/BlueCoatSG.pm | lib/SNMP/Info/Layer3/Aironet.pm | ||||||
| Info/Layer3/C3550.pm | lib/SNMP/Info/Layer3/AlcatelLucent.pm | ||||||
| Info/Layer3/C4000.pm | lib/SNMP/Info/Layer3/AlteonAD.pm | ||||||
| Info/Layer3/C6500.pm | lib/SNMP/Info/Layer3/Altiga.pm | ||||||
| Info/Layer3/Cisco.pm | lib/SNMP/Info/Layer3/Arista.pm | ||||||
| Info/Layer3/CiscoASA.pm | lib/SNMP/Info/Layer3/Aruba.pm | ||||||
| Info/Layer3/CiscoFWSM.pm | lib/SNMP/Info/Layer3/BayRS.pm | ||||||
| Info/Layer3/CiscoSwitch.pm | lib/SNMP/Info/Layer3/BlueCoatSG.pm | ||||||
| Info/Layer3/Contivity.pm | lib/SNMP/Info/Layer3/C3550.pm | ||||||
| Info/Layer3/Dell.pm | lib/SNMP/Info/Layer3/C4000.pm | ||||||
| Info/Layer3/Enterasys.pm | lib/SNMP/Info/Layer3/C6500.pm | ||||||
| Info/Layer3/Extreme.pm | lib/SNMP/Info/Layer3/CheckPoint.pm | ||||||
| Info/Layer3/F5.pm | lib/SNMP/Info/Layer3/Cisco.pm | ||||||
| Info/Layer3/Force10.pm | lib/SNMP/Info/Layer3/CiscoASA.pm | ||||||
| Info/Layer3/Fortinet.pm | lib/SNMP/Info/Layer3/CiscoFWSM.pm | ||||||
| Info/Layer3/Foundry.pm | lib/SNMP/Info/Layer3/CiscoSwitch.pm | ||||||
| Info/Layer3/H3C.pm | lib/SNMP/Info/Layer3/Contivity.pm | ||||||
| Info/Layer3/HP9300.pm | lib/SNMP/Info/Layer3/Cumulus.pm | ||||||
| Info/Layer3/Huawei.pm | lib/SNMP/Info/Layer3/Dell.pm | ||||||
| Info/Layer3/IBMGbTor.pm | lib/SNMP/Info/Layer3/DLink.pm | ||||||
| Info/Layer3/Juniper.pm | lib/SNMP/Info/Layer3/Enterasys.pm | ||||||
| Info/Layer3/Lantronix.pm | lib/SNMP/Info/Layer3/Extreme.pm | ||||||
| Info/Layer3/Microsoft.pm | lib/SNMP/Info/Layer3/F5.pm | ||||||
| Info/Layer3/Mikrotik.pm | lib/SNMP/Info/Layer3/Force10.pm | ||||||
| Info/Layer3/N1600.pm | lib/SNMP/Info/Layer3/Fortinet.pm | ||||||
| Info/Layer3/Netscreen.pm | lib/SNMP/Info/Layer3/Foundry.pm | ||||||
| Info/Layer3/NetSNMP.pm | lib/SNMP/Info/Layer3/H3C.pm | ||||||
| Info/Layer3/Nexus.pm | lib/SNMP/Info/Layer3/HP9300.pm | ||||||
| Info/Layer3/PacketFront.pm | lib/SNMP/Info/Layer3/Huawei.pm | ||||||
| Info/Layer3/Passport.pm | lib/SNMP/Info/Layer3/IBMGbTor.pm | ||||||
| Info/Layer3/Pf.pm | lib/SNMP/Info/Layer3/Juniper.pm | ||||||
| Info/Layer3/Pica8.pm | lib/SNMP/Info/Layer3/Lantronix.pm | ||||||
| Info/Layer3/SonicWALL.pm | lib/SNMP/Info/Layer3/Microsoft.pm | ||||||
| Info/Layer3/Steelhead.pm | lib/SNMP/Info/Layer3/Mikrotik.pm | ||||||
| Info/Layer3/Sun.pm | lib/SNMP/Info/Layer3/N1600.pm | ||||||
| Info/Layer3/Tasman.pm | lib/SNMP/Info/Layer3/Netscreen.pm | ||||||
| Info/Layer3/Timetra.pm | lib/SNMP/Info/Layer3/NetSNMP.pm | ||||||
| Info/Layer7.pm | lib/SNMP/Info/Layer3/Nexus.pm | ||||||
| Info/Layer7/APC.pm | lib/SNMP/Info/Layer3/PacketFront.pm | ||||||
| Info/Layer7/Neoteris.pm | lib/SNMP/Info/Layer3/PaloAlto.pm | ||||||
| Info/Layer7/Netscaler.pm | lib/SNMP/Info/Layer3/Passport.pm | ||||||
| Info/LLDP.pm | lib/SNMP/Info/Layer3/Pf.pm | ||||||
| Info/MAU.pm | lib/SNMP/Info/Layer3/Pica8.pm | ||||||
| Info/MRO.pm | lib/SNMP/Info/Layer3/SonicWALL.pm | ||||||
| Info/NortelStack.pm | lib/SNMP/Info/Layer3/Steelhead.pm | ||||||
| Info/PowerEthernet.pm | lib/SNMP/Info/Layer3/Sun.pm | ||||||
| Info/RapidCity.pm | lib/SNMP/Info/Layer3/Tasman.pm | ||||||
| Info/SONMP.pm | lib/SNMP/Info/Layer3/Timetra.pm | ||||||
| Makefile.PL | 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/CiscoIPS.pm | ||||||
|  | lib/SNMP/Info/Layer7/Gigamon.pm | ||||||
|  | lib/SNMP/Info/Layer7/Neoteris.pm | ||||||
|  | lib/SNMP/Info/Layer7/Netscaler.pm | ||||||
|  | lib/SNMP/Info/LLDP.pm | ||||||
|  | lib/SNMP/Info/MAU.pm | ||||||
|  | lib/SNMP/Info/MRO.pm | ||||||
|  | lib/SNMP/Info/NortelStack.pm | ||||||
|  | lib/SNMP/Info/PowerEthernet.pm | ||||||
|  | lib/SNMP/Info/RapidCity.pm | ||||||
|  | lib/SNMP/Info/SONMP.pm | ||||||
|  | LICENSE | ||||||
| MANIFEST			This list of files | MANIFEST			This list of files | ||||||
|  | META.json | ||||||
|  | META.yml | ||||||
| README | README | ||||||
| t/00-load.t | t/00_load.t | ||||||
| t/docmunge | xt/.perltidyrc | ||||||
| t/make_dev_matrix.pl | xt/00_local_distribution.t | ||||||
| t/prereq.t | xt/00_local_docininfo.t | ||||||
| t/push_ver | xt/00_local_perlcritic.t | ||||||
| t/run_test | xt/00_local_pod-coverage.t | ||||||
| t/test_class.pl | xt/00_local_pod.t | ||||||
| t/util/make_snmpdata.pl | xt/00_local_prereq.t | ||||||
| t/util/test_class_mocked.pl | xt/00_local_spelling.t | ||||||
|  | xt/00_local_versionsync.t | ||||||
|  | xt/10_remote_snmplabs.t | ||||||
|  | xt/20_run.t | ||||||
|  | xt/lib/My/Test/Class.pm | ||||||
|  | xt/lib/SNMP/Info/Test.pm | ||||||
|   | |||||||
| @@ -1,28 +1,70 @@ | |||||||
| # Version control files and dirs. | \.bak$ | ||||||
|  | \.pid$ | ||||||
|  | \.swp$ | ||||||
|  |  | ||||||
|  | ^SNMP-Info- | ||||||
|  |  | ||||||
|  | ^MANIFEST\. | ||||||
|  |  | ||||||
|  | # Avoid version control files. | ||||||
| \bRCS\b | \bRCS\b | ||||||
| \bCVS\b | \bCVS\b | ||||||
|  | \bSCCS\b | ||||||
| ,v$ | ,v$ | ||||||
| \B\.svn\b | \B\.svn\b | ||||||
| \B\.git\b | \B\.git\b | ||||||
| .gitignore | \B\.gitignore\b | ||||||
|  | \b_darcs\b | ||||||
|  | \B\.cvsignore$ | ||||||
|  |  | ||||||
| # Makemaker generated files and dirs. | # Avoid VMS specific MakeMaker generated files | ||||||
| ^MANIFEST\. | \bDescrip.MMS$ | ||||||
| ^Makefile$ | \bDESCRIP.MMS$ | ||||||
| ^blib/ | \bdescrip.mms$ | ||||||
| ^MakeMaker-\d |  | ||||||
| pm_to_blib |  | ||||||
| MYMETA.* |  | ||||||
|  |  | ||||||
| # Temp, old and emacs backup files. | # Avoid Makemaker generated and utility files. | ||||||
|  | \bMANIFEST\.bak | ||||||
|  | \bMakefile$ | ||||||
|  | \bblib/ | ||||||
|  | \bMakeMaker-\d | ||||||
|  | \bpm_to_blib\.ts$ | ||||||
|  | \bpm_to_blib$ | ||||||
|  | \bblibdirs\.ts$         # 6.18 through 6.25 generated this | ||||||
|  |  | ||||||
|  | # Avoid Module::Build generated and utility files. | ||||||
|  | \bBuild$ | ||||||
|  | \b_build/ | ||||||
|  | \bBuild.bat$ | ||||||
|  | \bBuild.COM$ | ||||||
|  | \bBUILD.COM$ | ||||||
|  | \bbuild.com$ | ||||||
|  |  | ||||||
|  | # Avoid temp and backup files. | ||||||
| ~$ | ~$ | ||||||
| \.old$ | \.old$ | ||||||
| ^#.*#$ | \#$ | ||||||
| ^\.# | \b\.# | ||||||
|  | \.bak$ | ||||||
|  | \.tmp$ | ||||||
|  | \.# | ||||||
|  | \.rej$ | ||||||
|  |  | ||||||
| # Private Regression Tests | # Avoid OS-specific files/dirs | ||||||
| \d+_local_ | # Mac OSX metadata | ||||||
| \.?perl\w+\.?rc$ | \B\.DS_Store | ||||||
|  | # Mac OSX SMB mount metadata files | ||||||
|  | \B\._ | ||||||
|  |  | ||||||
| # Komodo project file | # Avoid Devel::Cover and Devel::CoverX::Covered files. | ||||||
| \.kpf$ | \bcover_db\b | ||||||
|  | \bcovered\b | ||||||
|  |   | ||||||
|  | # Avoid MYMETA files | ||||||
|  | ^MYMETA\. | ||||||
|  |  | ||||||
|  | .github | ||||||
|  | .travis | ||||||
|  | README.md | ||||||
|  |  | ||||||
|  | # Avoid Komodo project file | ||||||
|  | \.komodoproject$ | ||||||
|   | |||||||
							
								
								
									
										543
									
								
								META.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										543
									
								
								META.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,543 @@ | |||||||
|  | { | ||||||
|  |    "abstract" : "OO Interface to Network devices and MIBs through SNMP", | ||||||
|  |    "author" : [ | ||||||
|  |       "Eric A. Miller <emiller@cpan.org>" | ||||||
|  |    ], | ||||||
|  |    "dynamic_config" : 1, | ||||||
|  |    "generated_by" : "Module::Build version 0.4224", | ||||||
|  |    "license" : [ | ||||||
|  |       "bsd" | ||||||
|  |    ], | ||||||
|  |    "meta-spec" : { | ||||||
|  |       "url" : "http://search.cpan.org/perldoc?CPAN::Meta::Spec", | ||||||
|  |       "version" : 2 | ||||||
|  |    }, | ||||||
|  |    "name" : "SNMP-Info", | ||||||
|  |    "prereqs" : { | ||||||
|  |       "configure" : { | ||||||
|  |          "requires" : { | ||||||
|  |             "Module::Build" : "0.42" | ||||||
|  |          } | ||||||
|  |       }, | ||||||
|  |       "runtime" : { | ||||||
|  |          "recommends" : { | ||||||
|  |             "Class::ISA" : "0", | ||||||
|  |             "File::Slurp" : "0", | ||||||
|  |             "Module::Info" : "0", | ||||||
|  |             "Module::Load" : "0", | ||||||
|  |             "PPI" : "0" | ||||||
|  |          }, | ||||||
|  |          "requires" : { | ||||||
|  |             "Math::BigInt" : "0", | ||||||
|  |             "SNMP" : "0" | ||||||
|  |          } | ||||||
|  |       }, | ||||||
|  |       "test" : { | ||||||
|  |          "requires" : { | ||||||
|  |             "File::Find" : "0", | ||||||
|  |             "File::Slurper" : "0", | ||||||
|  |             "Path::Class" : "0", | ||||||
|  |             "Test::Class::Most" : "0", | ||||||
|  |             "Test::Distribution" : "0", | ||||||
|  |             "Test::Exception" : "0.43", | ||||||
|  |             "Test::MockObject::Extends" : "0", | ||||||
|  |             "Test::More" : "0.88" | ||||||
|  |          } | ||||||
|  |       } | ||||||
|  |    }, | ||||||
|  |    "provides" : { | ||||||
|  |       "SNMP::Info" : { | ||||||
|  |          "file" : "lib/SNMP/Info.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::AMAP" : { | ||||||
|  |          "file" : "lib/SNMP/Info/AMAP.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::AdslLine" : { | ||||||
|  |          "file" : "lib/SNMP/Info/AdslLine.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Aggregate" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Aggregate.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Airespace" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Airespace.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Bridge" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Bridge.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::CDP" : { | ||||||
|  |          "file" : "lib/SNMP/Info/CDP.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::CiscoAgg" : { | ||||||
|  |          "file" : "lib/SNMP/Info/CiscoAgg.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::CiscoConfig" : { | ||||||
|  |          "file" : "lib/SNMP/Info/CiscoConfig.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::CiscoPortSecurity" : { | ||||||
|  |          "file" : "lib/SNMP/Info/CiscoPortSecurity.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::CiscoPower" : { | ||||||
|  |          "file" : "lib/SNMP/Info/CiscoPower.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::CiscoQOS" : { | ||||||
|  |          "file" : "lib/SNMP/Info/CiscoQOS.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::CiscoRTT" : { | ||||||
|  |          "file" : "lib/SNMP/Info/CiscoRTT.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::CiscoStack" : { | ||||||
|  |          "file" : "lib/SNMP/Info/CiscoStack.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::CiscoStats" : { | ||||||
|  |          "file" : "lib/SNMP/Info/CiscoStats.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::CiscoStpExtensions" : { | ||||||
|  |          "file" : "lib/SNMP/Info/CiscoStpExtensions.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::CiscoVTP" : { | ||||||
|  |          "file" : "lib/SNMP/Info/CiscoVTP.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::EDP" : { | ||||||
|  |          "file" : "lib/SNMP/Info/EDP.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Entity" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Entity.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::EtherLike" : { | ||||||
|  |          "file" : "lib/SNMP/Info/EtherLike.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::FDP" : { | ||||||
|  |          "file" : "lib/SNMP/Info/FDP.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::IEEE802dot11" : { | ||||||
|  |          "file" : "lib/SNMP/Info/IEEE802dot11.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::IEEE802dot3ad" : { | ||||||
|  |          "file" : "lib/SNMP/Info/IEEE802dot3ad.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::IPv6" : { | ||||||
|  |          "file" : "lib/SNMP/Info/IPv6.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::LLDP" : { | ||||||
|  |          "file" : "lib/SNMP/Info/LLDP.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer1" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer1.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer1::Allied" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer1/Allied.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer1::Asante" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer1/Asante.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer1::Bayhub" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer1/Bayhub.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer1::Cyclades" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer1/Cyclades.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer1::S3000" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer1/S3000.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer2" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer2.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer2::3Com" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer2/3Com.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer2::Adtran" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer2/Adtran.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer2::Airespace" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer2/Airespace.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer2::Aironet" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer2/Aironet.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer2::Allied" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer2/Allied.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer2::Baystack" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer2/Baystack.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer2::C1900" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer2/C1900.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer2::C2900" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer2/C2900.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer2::Catalyst" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer2/Catalyst.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer2::Centillion" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer2/Centillion.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer2::Cisco" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer2/Cisco.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer2::CiscoSB" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer2/CiscoSB.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer2::HP" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer2/HP.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer2::HP4000" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer2/HP4000.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer2::HPVC" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer2/HPVC.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer2::Kentrox" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer2/Kentrox.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer2::N2270" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer2/N2270.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer2::NAP222x" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer2/NAP222x.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer2::NWSS2300" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer2/NWSS2300.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer2::Netgear" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer2/Netgear.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer2::Orinoco" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer2/Orinoco.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer2::Trapeze" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer2/Trapeze.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer2::Ubiquiti" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer2/Ubiquiti.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer2::ZyXEL_DSLAM" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer2/ZyXEL_DSLAM.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::Aironet" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/Aironet.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::AlcatelLucent" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/AlcatelLucent.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::AlteonAD" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/AlteonAD.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::Altiga" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/Altiga.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::Arista" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/Arista.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::Aruba" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/Aruba.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::BayRS" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/BayRS.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::BlueCoatSG" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/BlueCoatSG.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::C3550" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/C3550.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::C4000" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/C4000.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::C6500" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/C6500.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::CheckPoint" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/CheckPoint.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::Cisco" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/Cisco.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::CiscoASA" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/CiscoASA.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::CiscoFWSM" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/CiscoFWSM.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::CiscoSwitch" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/CiscoSwitch.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::Contivity" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/Contivity.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::Cumulus" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/Cumulus.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::DLink" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/DLink.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::Dell" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/Dell.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::Enterasys" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/Enterasys.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::Extreme" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/Extreme.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::F5" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/F5.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::Force10" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/Force10.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::Fortinet" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/Fortinet.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::Foundry" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/Foundry.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::H3C" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/H3C.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::HP9300" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/HP9300.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::Huawei" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/Huawei.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::IBMGbTor" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/IBMGbTor.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::Juniper" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/Juniper.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::Lantronix" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/Lantronix.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::Microsoft" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/Microsoft.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::Mikrotik" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/Mikrotik.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::N1600" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/N1600.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::NetSNMP" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/NetSNMP.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::Netscreen" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/Netscreen.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::Nexus" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/Nexus.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::PacketFront" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/PacketFront.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::PaloAlto" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/PaloAlto.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::Passport" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/Passport.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::Pf" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/Pf.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::Pica8" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/Pica8.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::SonicWALL" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/SonicWALL.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::Steelhead" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/Steelhead.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::Sun" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/Sun.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::Tasman" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/Tasman.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::Timetra" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/Timetra.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::VMware" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/VMware.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer3::VyOS" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer3/VyOS.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer7" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer7.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer7::APC" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer7/APC.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer7::CiscoIPS" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer7/CiscoIPS.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer7::Gigamon" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer7/Gigamon.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer7::Neoteris" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer7/Neoteris.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::Layer7::Netscaler" : { | ||||||
|  |          "file" : "lib/SNMP/Info/Layer7/Netscaler.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::MAU" : { | ||||||
|  |          "file" : "lib/SNMP/Info/MAU.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::MRO" : { | ||||||
|  |          "file" : "lib/SNMP/Info/MRO.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::NortelStack" : { | ||||||
|  |          "file" : "lib/SNMP/Info/NortelStack.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::PowerEthernet" : { | ||||||
|  |          "file" : "lib/SNMP/Info/PowerEthernet.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::RapidCity" : { | ||||||
|  |          "file" : "lib/SNMP/Info/RapidCity.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       }, | ||||||
|  |       "SNMP::Info::SONMP" : { | ||||||
|  |          "file" : "lib/SNMP/Info/SONMP.pm", | ||||||
|  |          "version" : "3.53" | ||||||
|  |       } | ||||||
|  |    }, | ||||||
|  |    "release_status" : "stable", | ||||||
|  |    "resources" : { | ||||||
|  |       "bugtracker" : { | ||||||
|  |          "web" : "https://github.com/netdisco/snmp-info/issues" | ||||||
|  |       }, | ||||||
|  |       "homepage" : "http://netdisco.org/", | ||||||
|  |       "license" : [ | ||||||
|  |          "http://opensource.org/licenses/BSD-3-Clause" | ||||||
|  |       ], | ||||||
|  |       "repository" : { | ||||||
|  |          "url" : "https://github.com/netdisco/snmp-info" | ||||||
|  |       }, | ||||||
|  |       "x_IRC" : "irc://irc.freenode.org/#netdisco", | ||||||
|  |       "x_MailingList" : "https://lists.sourceforge.net/lists/listinfo/snmp-info-users" | ||||||
|  |    }, | ||||||
|  |    "version" : "3.53", | ||||||
|  |    "x_serialization_backend" : "JSON::PP version 2.94" | ||||||
|  | } | ||||||
							
								
								
									
										398
									
								
								META.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										398
									
								
								META.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,398 @@ | |||||||
|  | --- | ||||||
|  | abstract: 'OO Interface to Network devices and MIBs through SNMP' | ||||||
|  | author: | ||||||
|  |   - 'Eric A. Miller <emiller@cpan.org>' | ||||||
|  | build_requires: | ||||||
|  |   File::Find: '0' | ||||||
|  |   File::Slurper: '0' | ||||||
|  |   Path::Class: '0' | ||||||
|  |   Test::Class::Most: '0' | ||||||
|  |   Test::Distribution: '0' | ||||||
|  |   Test::Exception: '0.43' | ||||||
|  |   Test::MockObject::Extends: '0' | ||||||
|  |   Test::More: '0.88' | ||||||
|  | configure_requires: | ||||||
|  |   Module::Build: '0.42' | ||||||
|  | dynamic_config: 1 | ||||||
|  | generated_by: 'Module::Build version 0.4224, CPAN::Meta::Converter version 2.150010' | ||||||
|  | license: bsd | ||||||
|  | meta-spec: | ||||||
|  |   url: http://module-build.sourceforge.net/META-spec-v1.4.html | ||||||
|  |   version: '1.4' | ||||||
|  | name: SNMP-Info | ||||||
|  | provides: | ||||||
|  |   SNMP::Info: | ||||||
|  |     file: lib/SNMP/Info.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::AMAP: | ||||||
|  |     file: lib/SNMP/Info/AMAP.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::AdslLine: | ||||||
|  |     file: lib/SNMP/Info/AdslLine.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Aggregate: | ||||||
|  |     file: lib/SNMP/Info/Aggregate.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Airespace: | ||||||
|  |     file: lib/SNMP/Info/Airespace.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Bridge: | ||||||
|  |     file: lib/SNMP/Info/Bridge.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::CDP: | ||||||
|  |     file: lib/SNMP/Info/CDP.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::CiscoAgg: | ||||||
|  |     file: lib/SNMP/Info/CiscoAgg.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::CiscoConfig: | ||||||
|  |     file: lib/SNMP/Info/CiscoConfig.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::CiscoPortSecurity: | ||||||
|  |     file: lib/SNMP/Info/CiscoPortSecurity.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::CiscoPower: | ||||||
|  |     file: lib/SNMP/Info/CiscoPower.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::CiscoQOS: | ||||||
|  |     file: lib/SNMP/Info/CiscoQOS.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::CiscoRTT: | ||||||
|  |     file: lib/SNMP/Info/CiscoRTT.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::CiscoStack: | ||||||
|  |     file: lib/SNMP/Info/CiscoStack.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::CiscoStats: | ||||||
|  |     file: lib/SNMP/Info/CiscoStats.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::CiscoStpExtensions: | ||||||
|  |     file: lib/SNMP/Info/CiscoStpExtensions.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::CiscoVTP: | ||||||
|  |     file: lib/SNMP/Info/CiscoVTP.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::EDP: | ||||||
|  |     file: lib/SNMP/Info/EDP.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Entity: | ||||||
|  |     file: lib/SNMP/Info/Entity.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::EtherLike: | ||||||
|  |     file: lib/SNMP/Info/EtherLike.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::FDP: | ||||||
|  |     file: lib/SNMP/Info/FDP.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::IEEE802dot11: | ||||||
|  |     file: lib/SNMP/Info/IEEE802dot11.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::IEEE802dot3ad: | ||||||
|  |     file: lib/SNMP/Info/IEEE802dot3ad.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::IPv6: | ||||||
|  |     file: lib/SNMP/Info/IPv6.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::LLDP: | ||||||
|  |     file: lib/SNMP/Info/LLDP.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer1: | ||||||
|  |     file: lib/SNMP/Info/Layer1.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer1::Allied: | ||||||
|  |     file: lib/SNMP/Info/Layer1/Allied.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer1::Asante: | ||||||
|  |     file: lib/SNMP/Info/Layer1/Asante.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer1::Bayhub: | ||||||
|  |     file: lib/SNMP/Info/Layer1/Bayhub.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer1::Cyclades: | ||||||
|  |     file: lib/SNMP/Info/Layer1/Cyclades.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer1::S3000: | ||||||
|  |     file: lib/SNMP/Info/Layer1/S3000.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer2: | ||||||
|  |     file: lib/SNMP/Info/Layer2.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer2::3Com: | ||||||
|  |     file: lib/SNMP/Info/Layer2/3Com.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer2::Adtran: | ||||||
|  |     file: lib/SNMP/Info/Layer2/Adtran.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer2::Airespace: | ||||||
|  |     file: lib/SNMP/Info/Layer2/Airespace.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer2::Aironet: | ||||||
|  |     file: lib/SNMP/Info/Layer2/Aironet.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer2::Allied: | ||||||
|  |     file: lib/SNMP/Info/Layer2/Allied.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer2::Baystack: | ||||||
|  |     file: lib/SNMP/Info/Layer2/Baystack.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer2::C1900: | ||||||
|  |     file: lib/SNMP/Info/Layer2/C1900.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer2::C2900: | ||||||
|  |     file: lib/SNMP/Info/Layer2/C2900.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer2::Catalyst: | ||||||
|  |     file: lib/SNMP/Info/Layer2/Catalyst.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer2::Centillion: | ||||||
|  |     file: lib/SNMP/Info/Layer2/Centillion.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer2::Cisco: | ||||||
|  |     file: lib/SNMP/Info/Layer2/Cisco.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer2::CiscoSB: | ||||||
|  |     file: lib/SNMP/Info/Layer2/CiscoSB.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer2::HP: | ||||||
|  |     file: lib/SNMP/Info/Layer2/HP.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer2::HP4000: | ||||||
|  |     file: lib/SNMP/Info/Layer2/HP4000.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer2::HPVC: | ||||||
|  |     file: lib/SNMP/Info/Layer2/HPVC.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer2::Kentrox: | ||||||
|  |     file: lib/SNMP/Info/Layer2/Kentrox.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer2::N2270: | ||||||
|  |     file: lib/SNMP/Info/Layer2/N2270.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer2::NAP222x: | ||||||
|  |     file: lib/SNMP/Info/Layer2/NAP222x.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer2::NWSS2300: | ||||||
|  |     file: lib/SNMP/Info/Layer2/NWSS2300.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer2::Netgear: | ||||||
|  |     file: lib/SNMP/Info/Layer2/Netgear.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer2::Orinoco: | ||||||
|  |     file: lib/SNMP/Info/Layer2/Orinoco.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer2::Trapeze: | ||||||
|  |     file: lib/SNMP/Info/Layer2/Trapeze.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer2::Ubiquiti: | ||||||
|  |     file: lib/SNMP/Info/Layer2/Ubiquiti.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer2::ZyXEL_DSLAM: | ||||||
|  |     file: lib/SNMP/Info/Layer2/ZyXEL_DSLAM.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3: | ||||||
|  |     file: lib/SNMP/Info/Layer3.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::Aironet: | ||||||
|  |     file: lib/SNMP/Info/Layer3/Aironet.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::AlcatelLucent: | ||||||
|  |     file: lib/SNMP/Info/Layer3/AlcatelLucent.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::AlteonAD: | ||||||
|  |     file: lib/SNMP/Info/Layer3/AlteonAD.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::Altiga: | ||||||
|  |     file: lib/SNMP/Info/Layer3/Altiga.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::Arista: | ||||||
|  |     file: lib/SNMP/Info/Layer3/Arista.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::Aruba: | ||||||
|  |     file: lib/SNMP/Info/Layer3/Aruba.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::BayRS: | ||||||
|  |     file: lib/SNMP/Info/Layer3/BayRS.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::BlueCoatSG: | ||||||
|  |     file: lib/SNMP/Info/Layer3/BlueCoatSG.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::C3550: | ||||||
|  |     file: lib/SNMP/Info/Layer3/C3550.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::C4000: | ||||||
|  |     file: lib/SNMP/Info/Layer3/C4000.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::C6500: | ||||||
|  |     file: lib/SNMP/Info/Layer3/C6500.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::CheckPoint: | ||||||
|  |     file: lib/SNMP/Info/Layer3/CheckPoint.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::Cisco: | ||||||
|  |     file: lib/SNMP/Info/Layer3/Cisco.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::CiscoASA: | ||||||
|  |     file: lib/SNMP/Info/Layer3/CiscoASA.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::CiscoFWSM: | ||||||
|  |     file: lib/SNMP/Info/Layer3/CiscoFWSM.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::CiscoSwitch: | ||||||
|  |     file: lib/SNMP/Info/Layer3/CiscoSwitch.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::Contivity: | ||||||
|  |     file: lib/SNMP/Info/Layer3/Contivity.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::Cumulus: | ||||||
|  |     file: lib/SNMP/Info/Layer3/Cumulus.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::DLink: | ||||||
|  |     file: lib/SNMP/Info/Layer3/DLink.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::Dell: | ||||||
|  |     file: lib/SNMP/Info/Layer3/Dell.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::Enterasys: | ||||||
|  |     file: lib/SNMP/Info/Layer3/Enterasys.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::Extreme: | ||||||
|  |     file: lib/SNMP/Info/Layer3/Extreme.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::F5: | ||||||
|  |     file: lib/SNMP/Info/Layer3/F5.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::Force10: | ||||||
|  |     file: lib/SNMP/Info/Layer3/Force10.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::Fortinet: | ||||||
|  |     file: lib/SNMP/Info/Layer3/Fortinet.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::Foundry: | ||||||
|  |     file: lib/SNMP/Info/Layer3/Foundry.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::H3C: | ||||||
|  |     file: lib/SNMP/Info/Layer3/H3C.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::HP9300: | ||||||
|  |     file: lib/SNMP/Info/Layer3/HP9300.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::Huawei: | ||||||
|  |     file: lib/SNMP/Info/Layer3/Huawei.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::IBMGbTor: | ||||||
|  |     file: lib/SNMP/Info/Layer3/IBMGbTor.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::Juniper: | ||||||
|  |     file: lib/SNMP/Info/Layer3/Juniper.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::Lantronix: | ||||||
|  |     file: lib/SNMP/Info/Layer3/Lantronix.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::Microsoft: | ||||||
|  |     file: lib/SNMP/Info/Layer3/Microsoft.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::Mikrotik: | ||||||
|  |     file: lib/SNMP/Info/Layer3/Mikrotik.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::N1600: | ||||||
|  |     file: lib/SNMP/Info/Layer3/N1600.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::NetSNMP: | ||||||
|  |     file: lib/SNMP/Info/Layer3/NetSNMP.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::Netscreen: | ||||||
|  |     file: lib/SNMP/Info/Layer3/Netscreen.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::Nexus: | ||||||
|  |     file: lib/SNMP/Info/Layer3/Nexus.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::PacketFront: | ||||||
|  |     file: lib/SNMP/Info/Layer3/PacketFront.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::PaloAlto: | ||||||
|  |     file: lib/SNMP/Info/Layer3/PaloAlto.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::Passport: | ||||||
|  |     file: lib/SNMP/Info/Layer3/Passport.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::Pf: | ||||||
|  |     file: lib/SNMP/Info/Layer3/Pf.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::Pica8: | ||||||
|  |     file: lib/SNMP/Info/Layer3/Pica8.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::SonicWALL: | ||||||
|  |     file: lib/SNMP/Info/Layer3/SonicWALL.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::Steelhead: | ||||||
|  |     file: lib/SNMP/Info/Layer3/Steelhead.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::Sun: | ||||||
|  |     file: lib/SNMP/Info/Layer3/Sun.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::Tasman: | ||||||
|  |     file: lib/SNMP/Info/Layer3/Tasman.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::Timetra: | ||||||
|  |     file: lib/SNMP/Info/Layer3/Timetra.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::VMware: | ||||||
|  |     file: lib/SNMP/Info/Layer3/VMware.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer3::VyOS: | ||||||
|  |     file: lib/SNMP/Info/Layer3/VyOS.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer7: | ||||||
|  |     file: lib/SNMP/Info/Layer7.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer7::APC: | ||||||
|  |     file: lib/SNMP/Info/Layer7/APC.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer7::CiscoIPS: | ||||||
|  |     file: lib/SNMP/Info/Layer7/CiscoIPS.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer7::Gigamon: | ||||||
|  |     file: lib/SNMP/Info/Layer7/Gigamon.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer7::Neoteris: | ||||||
|  |     file: lib/SNMP/Info/Layer7/Neoteris.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::Layer7::Netscaler: | ||||||
|  |     file: lib/SNMP/Info/Layer7/Netscaler.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::MAU: | ||||||
|  |     file: lib/SNMP/Info/MAU.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::MRO: | ||||||
|  |     file: lib/SNMP/Info/MRO.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::NortelStack: | ||||||
|  |     file: lib/SNMP/Info/NortelStack.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::PowerEthernet: | ||||||
|  |     file: lib/SNMP/Info/PowerEthernet.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::RapidCity: | ||||||
|  |     file: lib/SNMP/Info/RapidCity.pm | ||||||
|  |     version: '3.53' | ||||||
|  |   SNMP::Info::SONMP: | ||||||
|  |     file: lib/SNMP/Info/SONMP.pm | ||||||
|  |     version: '3.53' | ||||||
|  | recommends: | ||||||
|  |   Class::ISA: '0' | ||||||
|  |   File::Slurp: '0' | ||||||
|  |   Module::Info: '0' | ||||||
|  |   Module::Load: '0' | ||||||
|  |   PPI: '0' | ||||||
|  | requires: | ||||||
|  |   Math::BigInt: '0' | ||||||
|  |   SNMP: '0' | ||||||
|  | resources: | ||||||
|  |   IRC: irc://irc.freenode.org/#netdisco | ||||||
|  |   MailingList: https://lists.sourceforge.net/lists/listinfo/snmp-info-users | ||||||
|  |   bugtracker: https://github.com/netdisco/snmp-info/issues | ||||||
|  |   homepage: http://netdisco.org/ | ||||||
|  |   license: http://opensource.org/licenses/BSD-3-Clause | ||||||
|  |   repository: https://github.com/netdisco/snmp-info | ||||||
|  | version: '3.53' | ||||||
|  | x_serialization_backend: 'CPAN::Meta::YAML version 0.018' | ||||||
							
								
								
									
										39
									
								
								Makefile.PL
									
									
									
									
									
								
							
							
						
						
									
										39
									
								
								Makefile.PL
									
									
									
									
									
								
							| @@ -1,39 +0,0 @@ | |||||||
| # Module makefile for SNMP::Info (using ExtUtils::MakeMaker) |  | ||||||
| # $Id$ |  | ||||||
|  |  | ||||||
| require 5.006; |  | ||||||
|  |  | ||||||
| use strict; |  | ||||||
| use warnings; |  | ||||||
| use ExtUtils::MakeMaker; |  | ||||||
|  |  | ||||||
| WriteMakefile( |  | ||||||
|     NAME          => 'SNMP::Info', |  | ||||||
|     AUTHOR        => 'Eric A. Miller <emiller@cpan.org>', |  | ||||||
|     VERSION_FROM  => 'Info.pm', |  | ||||||
|     ABSTRACT_FROM => 'Info.pm', |  | ||||||
|     PREREQ_PM     => { |  | ||||||
|         'Test::More'   => 0, |  | ||||||
|         'Math::BigInt' => 0, |  | ||||||
|         'SNMP'         => 0, |  | ||||||
|     }, |  | ||||||
|     PMLIBDIRS => [ 'Info', '$(BASEEXT)' ], |  | ||||||
|     dist      => { COMPRESS => 'gzip -9f', SUFFIX => 'gz', }, |  | ||||||
|     clean     => { FILES    => 'SNMP-Info-*' }, |  | ||||||
|     realclean => { FILES    => 'Makefile.old' }, |  | ||||||
|     (     ( ExtUtils::MakeMaker->VERSION() lt '6.25' ) ? ( 'PL_FILES' => {} ) |  | ||||||
|         : () |  | ||||||
|     ), |  | ||||||
|     (   ( ExtUtils::MakeMaker->VERSION() gt '6.30' ) ? ( 'LICENSE' => 'bsd' ) |  | ||||||
|         : () |  | ||||||
|     ), |  | ||||||
|  |  | ||||||
| ); |  | ||||||
|  |  | ||||||
| sub MY::postamble { |  | ||||||
|     " |  | ||||||
| .PHONY: readme |  | ||||||
| readme: README |  | ||||||
| README: Info.pm |  | ||||||
| 	pod2text -l Info.pm > README"; |  | ||||||
| } |  | ||||||
| @@ -4,7 +4,6 @@ Coding Guidelines: | |||||||
|     - tab-width of 4, no tab characters |     - tab-width of 4, no tab characters | ||||||
|     - keep POD documentation up-to-date |     - keep POD documentation up-to-date | ||||||
|     - always update ChangeLog before committing |     - always update ChangeLog before committing | ||||||
|     - always update DeviceMatrix.txt before committing |  | ||||||
|     - check-in required mibs to netdisco-mibs and release new package if needed |     - check-in required mibs to netdisco-mibs and release new package if needed | ||||||
| 
 | 
 | ||||||
| Release and Testing Instructions:  | Release and Testing Instructions:  | ||||||
| @@ -3,9 +3,9 @@ | |||||||
| 
 | 
 | ||||||
| use File::Glob qw/bsd_glob/; | use File::Glob qw/bsd_glob/; | ||||||
| 
 | 
 | ||||||
| my @pms = glob_rec("../Info"); | my @pms = glob_rec("./lib"); | ||||||
| 
 | 
 | ||||||
| $new_version = shift @ARGV || '3.01'; | $new_version = shift @ARGV || die "missing new version\n"; | ||||||
| 
 | 
 | ||||||
| foreach my $p (@pms) { | foreach my $p (@pms) { | ||||||
|     print "$p\n"; |     print "$p\n"; | ||||||
| @@ -16,6 +16,7 @@ foreach my $p (@pms) { | |||||||
| 
 | 
 | ||||||
|     while (<O>) { |     while (<O>) { | ||||||
|         s/^\s*\$VERSION\s+=\s*'[^']+'\s*;/\$VERSION = '$new_version';/; |         s/^\s*\$VERSION\s+=\s*'[^']+'\s*;/\$VERSION = '$new_version';/; | ||||||
|  |         s/^SNMP::Info - Version [\d.]+$/SNMP::Info - Version $new_version/; | ||||||
|         print P; |         print P; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| @@ -1,4 +1,4 @@ | |||||||
| #!/usr/bin/perl | #!/usr/bin/env perl | ||||||
| # | # | ||||||
| # test_class_mocked.pl | # test_class_mocked.pl | ||||||
| # | # | ||||||
| @@ -33,7 +33,7 @@ use strict; | |||||||
| use warnings; | use warnings; | ||||||
| use Carp; | use Carp; | ||||||
| use FindBin; | use FindBin; | ||||||
| use lib "$FindBin::Bin/../../.."; | use lib "$FindBin::Bin/../../lib"; | ||||||
| use File::Slurp qw(slurp); | use File::Slurp qw(slurp); | ||||||
| use Getopt::Long; | use Getopt::Long; | ||||||
| use Pod::Usage; | use Pod::Usage; | ||||||
| @@ -24,7 +24,7 @@ use vars | |||||||
|     qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE $AUTOLOAD $INIT $DEBUG %SPEED_MAP |     qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE $AUTOLOAD $INIT $DEBUG %SPEED_MAP | ||||||
|     $NOSUCH $BIGINT $REPEATERS/; |     $NOSUCH $BIGINT $REPEATERS/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| =head1 NAME | =head1 NAME | ||||||
| 
 | 
 | ||||||
| @@ -32,7 +32,7 @@ SNMP::Info - OO Interface to Network devices and MIBs through SNMP | |||||||
| 
 | 
 | ||||||
| =head1 VERSION | =head1 VERSION | ||||||
| 
 | 
 | ||||||
| SNMP::Info - Version 3.31 | SNMP::Info - Version 3.53 | ||||||
| 
 | 
 | ||||||
| =head1 AUTHOR | =head1 AUTHOR | ||||||
| 
 | 
 | ||||||
| @@ -47,7 +47,9 @@ by Max Baker. | |||||||
| 
 | 
 | ||||||
| =head1 DEVICES SUPPORTED | =head1 DEVICES SUPPORTED | ||||||
| 
 | 
 | ||||||
| See L<http://netdisco.org/doc/DeviceMatrix.html> or L<DeviceMatrix.txt> for more details. | There are now generic classes for most types of device and so the authors | ||||||
|  | recommend loading SNMP::Info with AutoSpecify, and then reporting to the mail | ||||||
|  | list any missing functionality (such as neighbor discovery tables). | ||||||
| 
 | 
 | ||||||
| =head1 SYNOPSIS | =head1 SYNOPSIS | ||||||
| 
 | 
 | ||||||
| @@ -437,7 +439,7 @@ interface to data obtainable from network devices. | |||||||
| All the required MIB files are included in the netdisco-mib package. | All the required MIB files are included in the netdisco-mib package. | ||||||
| (See Above). | (See Above). | ||||||
| 
 | 
 | ||||||
| =over | =over 4 | ||||||
| 
 | 
 | ||||||
| =item SNMP::Info::Layer1 | =item SNMP::Info::Layer1 | ||||||
| 
 | 
 | ||||||
| @@ -445,7 +447,7 @@ Generic Layer1 Device subclass. | |||||||
| 
 | 
 | ||||||
| See documentation in L<SNMP::Info::Layer1> for details. | See documentation in L<SNMP::Info::Layer1> for details. | ||||||
| 
 | 
 | ||||||
| =over  | =over 4 | ||||||
| 
 | 
 | ||||||
| =item SNMP::Info::Layer1::Allied | =item SNMP::Info::Layer1::Allied | ||||||
| 
 | 
 | ||||||
| @@ -499,6 +501,12 @@ SNMP::Info::Layer2::3Com - SNMP Interface to L2 3Com Switches | |||||||
| 
 | 
 | ||||||
| See documentation in L<SNMP::Info::Layer2::3Com> for details. | See documentation in L<SNMP::Info::Layer2::3Com> for details. | ||||||
| 
 | 
 | ||||||
|  | =item SNMP::Info::Layer2::Adtran | ||||||
|  | 
 | ||||||
|  | Subclass for Adtran devices. | ||||||
|  | 
 | ||||||
|  | See documentation in L<SNMP::Info::Layer2::Adtran> for details. | ||||||
|  | 
 | ||||||
| =item SNMP::Info::Layer2::Airespace | =item SNMP::Info::Layer2::Airespace | ||||||
| 
 | 
 | ||||||
| Subclass for Cisco (Airespace) wireless controllers. | Subclass for Cisco (Airespace) wireless controllers. | ||||||
| @@ -632,7 +640,7 @@ See documentation in L<SNMP::Info::Layer2::Trapeze> for details. | |||||||
| 
 | 
 | ||||||
| =item SNMP::Info::Layer2::Ubiquiti | =item SNMP::Info::Layer2::Ubiquiti | ||||||
| 
 | 
 | ||||||
| SNMP Interface to Ubiquiti Access Points | SNMP Interface to Ubiquiti Access Points and other devices | ||||||
| 
 | 
 | ||||||
| See documentation in L<SNMP::Info::Layer2::Ubiquiti> for details. | See documentation in L<SNMP::Info::Layer2::Ubiquiti> for details. | ||||||
| 
 | 
 | ||||||
| @@ -722,6 +730,12 @@ This class covers Catalyst 6500s in native mode, hybrid mode.  Catalyst | |||||||
| 
 | 
 | ||||||
| See documentation in L<SNMP::Info::Layer3::C6500> for details. | See documentation in L<SNMP::Info::Layer3::C6500> for details. | ||||||
| 
 | 
 | ||||||
|  | =item SNMP::Info::Layer3::CheckPoint | ||||||
|  | 
 | ||||||
|  | Subclass for CheckPoint devices | ||||||
|  | 
 | ||||||
|  | See documentation in L<SNMP::Info::Layer3::CheckPoint> for details. | ||||||
|  | 
 | ||||||
| =item SNMP::Info::Layer3::Cisco | =item SNMP::Info::Layer3::Cisco | ||||||
| 
 | 
 | ||||||
| This is a simple wrapper around layer 3 for IOS devices and the base layer 3 | This is a simple wrapper around layer 3 for IOS devices and the base layer 3 | ||||||
| @@ -752,6 +766,18 @@ Subclass for Avaya/Nortel Contivity/VPN Routers. | |||||||
| 
 | 
 | ||||||
| See documentation in L<SNMP::Info::Layer3::Contivity> for details. | See documentation in L<SNMP::Info::Layer3::Contivity> for details. | ||||||
| 
 | 
 | ||||||
|  | =item SNMP::Info::Layer3::Cumulus | ||||||
|  | 
 | ||||||
|  | Subclass for Cumulus Networks Routers.   | ||||||
|  | 
 | ||||||
|  | See documentation in L<SNMP::Info::Layer3::Cumulus> for details. | ||||||
|  | 
 | ||||||
|  | =item SNMP::Info::Layer3::DLink | ||||||
|  | 
 | ||||||
|  | Subclass for DLink devices.   | ||||||
|  | 
 | ||||||
|  | See documentation in L<SNMP::Info::Layer3::DLink> for details. | ||||||
|  | 
 | ||||||
| =item SNMP::Info::Layer3::Dell | =item SNMP::Info::Layer3::Dell | ||||||
| 
 | 
 | ||||||
| Subclass for Dell PowerConnect switches. D-Link, the IBM BladeCenter | Subclass for Dell PowerConnect switches. D-Link, the IBM BladeCenter | ||||||
| @@ -876,6 +902,12 @@ Subclass for PacketFront DRG series CPE. | |||||||
| 
 | 
 | ||||||
| See documentation in L<SNMP::Info::Layer3::PacketFront> for details. | See documentation in L<SNMP::Info::Layer3::PacketFront> for details. | ||||||
| 
 | 
 | ||||||
|  | =item SNMP::Info::Layer3::PaloAlto | ||||||
|  | 
 | ||||||
|  | Subclass for Palo Alto firewalls. | ||||||
|  | 
 | ||||||
|  | See documentation in L<SNMP::Info::Layer3::PaloAlto> for details. | ||||||
|  | 
 | ||||||
| =item SNMP::Info::Layer3::Passport | =item SNMP::Info::Layer3::Passport | ||||||
| 
 | 
 | ||||||
| Subclass for Avaya/Nortel Ethernet Routing Switch/Passport 8000 series, | Subclass for Avaya/Nortel Ethernet Routing Switch/Passport 8000 series, | ||||||
| @@ -923,6 +955,18 @@ Alcatel-Lucent SR Class. | |||||||
| 
 | 
 | ||||||
| See documentation in L<SNMP::Info::Layer3::Timetra> for details. | See documentation in L<SNMP::Info::Layer3::Timetra> for details. | ||||||
| 
 | 
 | ||||||
|  | =item SNMP::Info::Layer3::VyOS | ||||||
|  | 
 | ||||||
|  | Subclass for VyOS routers. | ||||||
|  | 
 | ||||||
|  | See documentation in L<SNMP::Info::Layer3::VyOS> for details. | ||||||
|  | 
 | ||||||
|  | =item SNMP::Info::Layer3::VMware | ||||||
|  | 
 | ||||||
|  | Subclass for VMware ESXi hosts. | ||||||
|  | 
 | ||||||
|  | See documentation in L<SNMP::Info::Layer3::VMware> for details. | ||||||
|  | 
 | ||||||
| =back | =back | ||||||
| 
 | 
 | ||||||
| =back | =back | ||||||
| @@ -939,19 +983,31 @@ See documentation in L<SNMP::Info::Layer7> for details. | |||||||
| 
 | 
 | ||||||
| =item SNMP::Info::Layer7::APC | =item SNMP::Info::Layer7::APC | ||||||
| 
 | 
 | ||||||
| SNMP Interface to APC UPS devices | Subclass for  APC UPS devices | ||||||
| 
 | 
 | ||||||
| See documentation in L<SNMP::Info::Layer7::APC> for details. | See documentation in L<SNMP::Info::Layer7::APC> for details. | ||||||
| 
 | 
 | ||||||
|  | =item SNMP::Info::Layer7::CiscoIPS | ||||||
|  | 
 | ||||||
|  | Subclass for Cisco IPS devices | ||||||
|  | 
 | ||||||
|  | See documentation in L<SNMP::Info::Layer7::Cisco IPS> for details. | ||||||
|  | 
 | ||||||
|  | =item SNMP::Info::Layer7::Gigamon | ||||||
|  | 
 | ||||||
|  | Subclass for Gigamon devices | ||||||
|  | 
 | ||||||
|  | See documentation in L<SNMP::Info::Layer7::Gigamon> for details. | ||||||
|  | 
 | ||||||
| =item SNMP::Info::Layer7::Netscaler | =item SNMP::Info::Layer7::Netscaler | ||||||
| 
 | 
 | ||||||
| SNMP Interface to Citrix Netscaler appliances | Subclass for Citrix Netscaler appliances | ||||||
| 
 | 
 | ||||||
| See documentation in L<SNMP::Info::Layer7::Netscaler> for details. | See documentation in L<SNMP::Info::Layer7::Netscaler> for details. | ||||||
| 
 | 
 | ||||||
| =item SNMP::Info::Layer7::Neoteris | =item SNMP::Info::Layer7::Neoteris | ||||||
| 
 | 
 | ||||||
| SNMP Interface to Juniper SSL VPN appliances | Subclass for Juniper SSL VPN appliances | ||||||
| 
 | 
 | ||||||
| See documentation in L<SNMP::Info::Layer7::Neoteris> for details. | See documentation in L<SNMP::Info::Layer7::Neoteris> for details. | ||||||
| 
 | 
 | ||||||
| @@ -1221,7 +1277,7 @@ sub new { | |||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     # Connects to device unless open session is provided. |     # Connects to device unless open session is provided. | ||||||
|     $sess = new SNMP::Session( |     $sess = SNMP::Session->new( | ||||||
|         'UseEnums' => 1, |         'UseEnums' => 1, | ||||||
|         %sess_args, 'RetryNoSuch' => $new_obj->{nosuch} |         %sess_args, 'RetryNoSuch' => $new_obj->{nosuch} | ||||||
|     ) unless defined $sess; |     ) unless defined $sess; | ||||||
| @@ -1240,16 +1296,13 @@ sub new { | |||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     # Table function store |  | ||||||
|     my $store = {}; |  | ||||||
| 
 |  | ||||||
|     # Save Args for later |     # Save Args for later | ||||||
|     $new_obj->{store}     = $store; |     $new_obj->{store}     ||= {}; | ||||||
|     $new_obj->{sess}      = $sess; |     $new_obj->{sess}      = $sess; | ||||||
|     $new_obj->{args}      = \%args; |     $new_obj->{args}      = \%args; | ||||||
|     $new_obj->{snmp_ver}  = $args{Version} || 2; |     $new_obj->{snmp_ver}  = $sess->{Version}   || $args{Version}   || 2; | ||||||
|     $new_obj->{snmp_comm} = $args{Community} || 'public'; |     $new_obj->{snmp_comm} = $sess->{Community} || $args{Community} || 'public'; | ||||||
|     $new_obj->{snmp_user} = $args{SecName} || 'initial'; |     $new_obj->{snmp_user} = $sess->{SecName}   || $args{SecName}   || 'initial'; | ||||||
| 
 | 
 | ||||||
|     return $auto_specific ? $new_obj->specify() : $new_obj; |     return $auto_specific ? $new_obj->specify() : $new_obj; | ||||||
| } | } | ||||||
| @@ -1286,7 +1339,7 @@ sub update { | |||||||
|     delete $sess_args{BigInt}; |     delete $sess_args{BigInt}; | ||||||
|     delete $sess_args{MibDirs}; |     delete $sess_args{MibDirs}; | ||||||
| 
 | 
 | ||||||
|     my $sess = new SNMP::Session( |     my $sess = SNMP::Session->new( | ||||||
|         'UseEnums' => 1, |         'UseEnums' => 1, | ||||||
|         %sess_args, 'RetryNoSuch' => $obj->{nosuch} |         %sess_args, 'RetryNoSuch' => $obj->{nosuch} | ||||||
|     ); |     ); | ||||||
| @@ -1313,7 +1366,7 @@ sub update { | |||||||
| =head2 Data is Cached | =head2 Data is Cached | ||||||
| 
 | 
 | ||||||
| Methods and subroutines requesting data from a device will only load the data | Methods and subroutines requesting data from a device will only load the data | ||||||
| once, and then return cached versions of that data.  | once, and then return cached versions of that data. | ||||||
| 
 | 
 | ||||||
| Run $info->load_METHOD() where method is something like 'i_name' to reload | Run $info->load_METHOD() where method is something like 'i_name' to reload | ||||||
| data from a method. | data from a method. | ||||||
| @@ -1321,7 +1374,7 @@ data from a method. | |||||||
| Run $info->clear_cache() to clear the cache to allow reload of both globals | Run $info->clear_cache() to clear the cache to allow reload of both globals | ||||||
| and table methods. | and table methods. | ||||||
| 
 | 
 | ||||||
| The cache can be retreved or set using the $info->cache() method. This works | The cache can be retrieved or set using the $info->cache() method. This works | ||||||
| together with the C<Offline> option. | together with the C<Offline> option. | ||||||
| 
 | 
 | ||||||
| =head2 Object Scalar Methods | =head2 Object Scalar Methods | ||||||
| @@ -1466,9 +1519,6 @@ SNMP::Info::Layer3 subclasses. | |||||||
| If the device still can be connected to via SNMP::Info, then  | If the device still can be connected to via SNMP::Info, then  | ||||||
| SNMP::Info is returned.   | SNMP::Info is returned.   | ||||||
| 
 | 
 | ||||||
| See L<http://netdisco.org/doc/DeviceMatrix.html> or L<DeviceMatrix.txt> for more details |  | ||||||
| about device support, or view C<device_type()> in F<Info.pm>. |  | ||||||
| 
 |  | ||||||
| =cut | =cut | ||||||
| 
 | 
 | ||||||
| sub device_type { | sub device_type { | ||||||
| @@ -1504,16 +1554,19 @@ sub device_type { | |||||||
|         42   => 'SNMP::Info::Layer3::Sun', |         42   => 'SNMP::Info::Layer3::Sun', | ||||||
|         43   => 'SNMP::Info::Layer2::3Com', |         43   => 'SNMP::Info::Layer2::3Com', | ||||||
|         45   => 'SNMP::Info::Layer2::Baystack', |         45   => 'SNMP::Info::Layer2::Baystack', | ||||||
|         171  => 'SNMP::Info::Layer3::Dell', |         171  => 'SNMP::Info::Layer3::DLink', | ||||||
|         244  => 'SNMP::Info::Layer3::Lantronix', |         244  => 'SNMP::Info::Layer3::Lantronix', | ||||||
|         311  => 'SNMP::Info::Layer3::Microsoft', |         311  => 'SNMP::Info::Layer3::Microsoft', | ||||||
|  |         664   => 'SNMP::Info::Layer2::Adtran', | ||||||
|         674  => 'SNMP::Info::Layer3::Dell', |         674  => 'SNMP::Info::Layer3::Dell', | ||||||
|  |         1588 => 'SNMP::Info::Layer3::Foundry', | ||||||
|         1872 => 'SNMP::Info::Layer3::AlteonAD', |         1872 => 'SNMP::Info::Layer3::AlteonAD', | ||||||
|         1916 => 'SNMP::Info::Layer3::Extreme', |         1916 => 'SNMP::Info::Layer3::Extreme', | ||||||
|         1991 => 'SNMP::Info::Layer3::Foundry', |         1991 => 'SNMP::Info::Layer3::Foundry', | ||||||
|         2011 => 'SNMP::Info::Layer3::Huawei', |         2011 => 'SNMP::Info::Layer3::Huawei', | ||||||
|         2021 => 'SNMP::Info::Layer3::NetSNMP', |         2021 => 'SNMP::Info::Layer3::NetSNMP', | ||||||
|         2272 => 'SNMP::Info::Layer3::Passport', |         2272 => 'SNMP::Info::Layer3::Passport', | ||||||
|  |         2620 => 'SNMP::Info::Layer3::CheckPoint', | ||||||
|         2636 => 'SNMP::Info::Layer3::Juniper', |         2636 => 'SNMP::Info::Layer3::Juniper', | ||||||
|         2925 => 'SNMP::Info::Layer1::Cyclades', |         2925 => 'SNMP::Info::Layer1::Cyclades', | ||||||
|         3076 => 'SNMP::Info::Layer3::Altiga', |         3076 => 'SNMP::Info::Layer3::Altiga', | ||||||
| @@ -1525,6 +1578,7 @@ sub device_type { | |||||||
|         6027 => 'SNMP::Info::Layer3::Force10', |         6027 => 'SNMP::Info::Layer3::Force10', | ||||||
|         6486 => 'SNMP::Info::Layer3::AlcatelLucent', |         6486 => 'SNMP::Info::Layer3::AlcatelLucent', | ||||||
|         6527 => 'SNMP::Info::Layer3::Timetra', |         6527 => 'SNMP::Info::Layer3::Timetra', | ||||||
|  |         6876 => 'SNMP::Info::Layer3::VMware', | ||||||
|         8072 => 'SNMP::Info::Layer3::NetSNMP', |         8072 => 'SNMP::Info::Layer3::NetSNMP', | ||||||
|         9303 => 'SNMP::Info::Layer3::PacketFront', |         9303 => 'SNMP::Info::Layer3::PacketFront', | ||||||
|         10002 => 'SNMP::Info::Layer2::Ubiquiti', |         10002 => 'SNMP::Info::Layer2::Ubiquiti', | ||||||
| @@ -1536,10 +1590,14 @@ sub device_type { | |||||||
|         14988 => 'SNMP::Info::Layer3::Mikrotik', |         14988 => 'SNMP::Info::Layer3::Mikrotik', | ||||||
|         17163 => 'SNMP::Info::Layer3::Steelhead', |         17163 => 'SNMP::Info::Layer3::Steelhead', | ||||||
|         25506 => 'SNMP::Info::Layer3::H3C', |         25506 => 'SNMP::Info::Layer3::H3C', | ||||||
|  |         25461 => 'SNMP::Info::Layer3::PaloAlto', | ||||||
|         26543 => 'SNMP::Info::Layer3::IBMGbTor', |         26543 => 'SNMP::Info::Layer3::IBMGbTor', | ||||||
|         30065 => 'SNMP::Info::Layer3::Arista', |         30065 => 'SNMP::Info::Layer3::Arista', | ||||||
|         35098 => 'SNMP::Info::Layer3::Pica8', |         35098 => 'SNMP::Info::Layer3::Pica8', | ||||||
|         41112 => 'SNMP::Info::Layer2::Ubiquiti', |         41112 => 'SNMP::Info::Layer2::Ubiquiti', | ||||||
|  |         4413 => 'SNMP::Info::Layer2::Ubiquiti', | ||||||
|  |         30803 => 'SNMP::Info::Layer3::VyOS', | ||||||
|  |         40310 => 'SNMP::Info::Layer3::Cumulus', | ||||||
|     ); |     ); | ||||||
| 
 | 
 | ||||||
|     my %l2sysoidmap = ( |     my %l2sysoidmap = ( | ||||||
| @@ -1547,8 +1605,9 @@ sub device_type { | |||||||
|         11    => 'SNMP::Info::Layer2::HP', |         11    => 'SNMP::Info::Layer2::HP', | ||||||
|         43    => 'SNMP::Info::Layer2::3Com', |         43    => 'SNMP::Info::Layer2::3Com', | ||||||
|         45    => 'SNMP::Info::Layer2::Baystack', |         45    => 'SNMP::Info::Layer2::Baystack', | ||||||
|         171   => 'SNMP::Info::Layer3::Dell', |         171   => 'SNMP::Info::Layer3::DLink', | ||||||
|         207   => 'SNMP::Info::Layer2::Allied', |         207   => 'SNMP::Info::Layer2::Allied', | ||||||
|  |         664   => 'SNMP::Info::Layer2::Adtran', | ||||||
|         674   => 'SNMP::Info::Layer3::Dell', |         674   => 'SNMP::Info::Layer3::Dell', | ||||||
|         1872  => 'SNMP::Info::Layer3::AlteonAD', |         1872  => 'SNMP::Info::Layer3::AlteonAD', | ||||||
|         1916  => 'SNMP::Info::Layer3::Extreme', |         1916  => 'SNMP::Info::Layer3::Extreme', | ||||||
| @@ -1579,6 +1638,7 @@ sub device_type { | |||||||
|         5951  => 'SNMP::Info::Layer7::Netscaler', |         5951  => 'SNMP::Info::Layer7::Netscaler', | ||||||
|         14525 => 'SNMP::Info::Layer2::Trapeze', |         14525 => 'SNMP::Info::Layer2::Trapeze', | ||||||
|         12532 => 'SNMP::Info::Layer7::Neoteris', |         12532 => 'SNMP::Info::Layer7::Neoteris', | ||||||
|  |         26866 => 'SNMP::Info::Layer7::Gigamon', | ||||||
|     ); |     ); | ||||||
| 
 | 
 | ||||||
|     # Get just the enterprise number for generic mapping |     # Get just the enterprise number for generic mapping | ||||||
| @@ -1609,6 +1669,9 @@ sub device_type { | |||||||
|         $objtype = 'SNMP::Info::Layer3::Aironet' |         $objtype = 'SNMP::Info::Layer3::Aironet' | ||||||
|             if ( $desc =~ /Aironet/ and $desc =~ /\D(AP4800)\D/ ); |             if ( $desc =~ /Aironet/ and $desc =~ /\D(AP4800)\D/ ); | ||||||
| 
 | 
 | ||||||
|  | 	# Override voice gateway device (VG350) showing up as Aironet | ||||||
|  |         $objtype = 'SNMP::Info::Layer3::Cisco' if $desc =~ /VG350/; | ||||||
|  | 
 | ||||||
|         # Cat6k with older SUPs (hybrid CatOS/IOS?) |         # Cat6k with older SUPs (hybrid CatOS/IOS?) | ||||||
|         $objtype = 'SNMP::Info::Layer3::C6500' if $desc =~ /(c6sup2|c6sup1)/; |         $objtype = 'SNMP::Info::Layer3::C6500' if $desc =~ /(c6sup2|c6sup1)/; | ||||||
| 
 | 
 | ||||||
| @@ -1658,7 +1721,9 @@ sub device_type { | |||||||
|             =~ /^(BayStack|Ethernet\s+Routing\s+Switch)\s[2345](\d){2,3}/i ); |             =~ /^(BayStack|Ethernet\s+Routing\s+Switch)\s[2345](\d){2,3}/i ); | ||||||
| 
 | 
 | ||||||
|         # Nortel Contivity |         # Nortel Contivity | ||||||
|         $objtype = 'SNMP::Info::Layer3::Contivity' if $desc =~ /(\bCES\b|\bNVR\sV\d)/; |         $objtype = 'SNMP::Info::Layer3::Contivity' | ||||||
|  |           if $desc =~ /(\bCES\b|\bNVR\sV\d)/ | ||||||
|  |               and (!defined $id or !defined $l3sysoidmap{$id}); | ||||||
| 
 | 
 | ||||||
|         # SonicWALL |         # SonicWALL | ||||||
|         $objtype = 'SNMP::Info::Layer3::SonicWALL' if $desc =~ /SonicWALL/i; |         $objtype = 'SNMP::Info::Layer3::SonicWALL' if $desc =~ /SonicWALL/i; | ||||||
| @@ -1676,6 +1741,11 @@ sub device_type { | |||||||
|         $objtype = 'SNMP::Info::Layer3::CiscoFWSM' |         $objtype = 'SNMP::Info::Layer3::CiscoFWSM' | ||||||
|             if ( $desc =~ /Cisco Firewall Services Module/i ); |             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' | ||||||
|  |             if ( $soid =~ /^\.?1\.3\.6\.1\.4\.1\.9\.6\.1/ ); | ||||||
|  | 
 | ||||||
|         # Avaya Secure Router |         # Avaya Secure Router | ||||||
|         $objtype = 'SNMP::Info::Layer3::Tasman' |         $objtype = 'SNMP::Info::Layer3::Tasman' | ||||||
|             if ( $desc =~ /^(avaya|nortel)\s+(SR|secure\srouter)\s+\d{4}/i ); |             if ( $desc =~ /^(avaya|nortel)\s+(SR|secure\srouter)\s+\d{4}/i ); | ||||||
| @@ -1899,6 +1969,10 @@ sub device_type { | |||||||
|         $objtype = 'SNMP::Info::Layer2::NWSS2300'     |         $objtype = 'SNMP::Info::Layer2::NWSS2300'     | ||||||
|             if ( |             if ( | ||||||
|             $desc =~ /^(Nortel\s)??Wireless\sSecurity\sSwitch\s23[568][012]\b/); |             $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 ); | ||||||
| 
 | 
 | ||||||
|         # Generic device classification based upon sysObjectID |         # Generic device classification based upon sysObjectID | ||||||
|         if ( defined($id) and $objtype eq 'SNMP::Info') { |         if ( defined($id) and $objtype eq 'SNMP::Info') { | ||||||
| @@ -2647,7 +2721,7 @@ sub _get_topo_data { | |||||||
|     my $self     = shift; |     my $self     = shift; | ||||||
|     my $partial  = shift; |     my $partial  = shift; | ||||||
|     my $topo_cap = shift; |     my $topo_cap = shift; | ||||||
|     my $method   = shift; |     my $method   = shift || ''; | ||||||
| 
 | 
 | ||||||
|     return unless $method =~ /(ip|if|port|id|platform|cap)/; |     return unless $method =~ /(ip|if|port|id|platform|cap)/; | ||||||
| 
 | 
 | ||||||
| @@ -2923,7 +2997,7 @@ allows all developers to have visibility into the request.  Please include | |||||||
| pointers to the applicable platform MIBs.  For development we will need an | pointers to the applicable platform MIBs.  For development we will need an | ||||||
| C<snmpwalk> of the device.  There is a tool now included in the SNMP::Info | C<snmpwalk> of the device.  There is a tool now included in the SNMP::Info | ||||||
| distribution to help with this task, although you'll most likely need to | distribution to help with this task, although you'll most likely need to | ||||||
| download the distribution from CPAN as it's included in the "C<t/util>" | download the distribution from CPAN as it's included in the "C<contrib/util>" | ||||||
| directory. | directory. | ||||||
| 
 | 
 | ||||||
| The utility is named C<make_snmpdata.pl>. Run it with a command line like: | The utility is named C<make_snmpdata.pl>. Run it with a command line like: | ||||||
| @@ -2982,7 +3056,9 @@ the SNMP::Info methods. | |||||||
|     'name'         => 'sysName', |     'name'         => 'sysName', | ||||||
|     'location'     => 'sysLocation', |     'location'     => 'sysLocation', | ||||||
|     'layers'       => 'sysServices', |     'layers'       => 'sysServices', | ||||||
|  |     # IF-MIB | ||||||
|     'ports'        => 'ifNumber', |     'ports'        => 'ifNumber', | ||||||
|  |     # IP-MIB | ||||||
|     'ipforwarding' => 'ipForwarding', |     'ipforwarding' => 'ipForwarding', | ||||||
| ); | ); | ||||||
| 
 | 
 | ||||||
| @@ -3000,7 +3076,9 @@ ALTEON-TS-PHYSICAL-MIB::agPortCurCfgPortName. | |||||||
| =cut | =cut | ||||||
| 
 | 
 | ||||||
| %FUNCS = ( | %FUNCS = ( | ||||||
|  |     # IF-MIB::IfEntry | ||||||
|     'interfaces' => 'ifIndex', |     'interfaces' => 'ifIndex', | ||||||
|  |     # IF-MIB::IfEntry | ||||||
|     'i_name'     => 'ifName', |     'i_name'     => 'ifName', | ||||||
| 
 | 
 | ||||||
|     # IF-MIB::IfEntry |     # IF-MIB::IfEntry | ||||||
| @@ -3030,13 +3108,13 @@ ALTEON-TS-PHYSICAL-MIB::agPortCurCfgPortName. | |||||||
|     # IF-MIB::IfStackTable |     # IF-MIB::IfStackTable | ||||||
|     'i_stack_status'    => 'ifStackStatus', |     'i_stack_status'    => 'ifStackStatus', | ||||||
| 
 | 
 | ||||||
|     # IP Address Table |     # IP::MIB::ipAddrTable (deprecated IPv4 address table) | ||||||
|     'ip_index'     => 'ipAdEntIfIndex', |     'ip_index'     => 'ipAdEntIfIndex', | ||||||
|     'ip_table'     => 'ipAdEntAddr', |     'ip_table'     => 'ipAdEntAddr', | ||||||
|     'ip_netmask'   => 'ipAdEntNetMask', |     'ip_netmask'   => 'ipAdEntNetMask', | ||||||
|     'ip_broadcast' => 'ipAdEntBcastAddr', |     'ip_broadcast' => 'ipAdEntBcastAddr', | ||||||
| 
 | 
 | ||||||
|     # ifXTable - Extension Table |     # IF-MIB::ifXTable - Extension Table | ||||||
|     'i_speed_high'       => 'ifHighSpeed', |     'i_speed_high'       => 'ifHighSpeed', | ||||||
|     'i_pkts_multi_in'    => 'ifInMulticastPkts', |     'i_pkts_multi_in'    => 'ifInMulticastPkts', | ||||||
|     'i_pkts_multi_out'   => 'ifOutMulticastPkts', |     'i_pkts_multi_out'   => 'ifOutMulticastPkts', | ||||||
| @@ -3052,7 +3130,7 @@ ALTEON-TS-PHYSICAL-MIB::agPortCurCfgPortName. | |||||||
|     'i_pkts_bcast_out64' => 'ifHCOutBroadcastPkts', |     'i_pkts_bcast_out64' => 'ifHCOutBroadcastPkts', | ||||||
|     'i_alias'            => 'ifAlias', |     'i_alias'            => 'ifAlias', | ||||||
| 
 | 
 | ||||||
|     # IP Routing Table |     # RFC-1213::ipRoute (deprecated Table IP Routing Table) | ||||||
|     'ipr_route' => 'ipRouteDest', |     'ipr_route' => 'ipRouteDest', | ||||||
|     'ipr_if'    => 'ipRouteIfIndex', |     'ipr_if'    => 'ipRouteIfIndex', | ||||||
|     'ipr_1'     => 'ipRouteMetric1', |     'ipr_1'     => 'ipRouteMetric1', | ||||||
| @@ -3083,7 +3161,13 @@ $info->init() will throw an exception if a MIB does not load. | |||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
| 
 | 
 | ||||||
|     # The "main" MIBs are automagically loaded in Net-SNMP now. |     # Include these here for cases where the Net-SNMP default MIB list has | ||||||
|  |     # been overridden during the compliation of the local Net-SNMP library. | ||||||
|  |     # These cover the globals and funcs defined in this file. | ||||||
|  |     'SNMPv2-MIB'  => 'sysObjectID', | ||||||
|  |     'RFC1213-MIB' => 'ipRouteIfIndex', | ||||||
|  |     'IP-MIB'      => 'ipAdEntAddr', | ||||||
|  |     'IF-MIB'      => 'ifIndex', | ||||||
| ); | ); | ||||||
| 
 | 
 | ||||||
| =item %MUNGE | =item %MUNGE | ||||||
| @@ -3304,6 +3388,7 @@ Makes human friendly speed ratings using %SPEED_MAP | |||||||
|                 '54000000'   => '54 Mbps', |                 '54000000'   => '54 Mbps', | ||||||
|                 '64000000'   => '64 Mbps', |                 '64000000'   => '64 Mbps', | ||||||
|                 '100000000'  => '100 Mbps', |                 '100000000'  => '100 Mbps', | ||||||
|  |                 '200000000'  => '200 Mbps', | ||||||
|                 '149760000'  => 'ATM on OC-3', |                 '149760000'  => 'ATM on OC-3', | ||||||
|                 '155000000'  => 'OC-3', |                 '155000000'  => 'OC-3', | ||||||
|                 '155519000'  => 'OC-3', |                 '155519000'  => 'OC-3', | ||||||
| @@ -3313,6 +3398,7 @@ Makes human friendly speed ratings using %SPEED_MAP | |||||||
|                 '622000000'  => 'OC-12', |                 '622000000'  => 'OC-12', | ||||||
|                 '622080000'  => 'OC-12', |                 '622080000'  => 'OC-12', | ||||||
|                 '1000000000' => '1.0 Gbps', |                 '1000000000' => '1.0 Gbps', | ||||||
|  |                 '2000000000' => '2.0 Gbps', | ||||||
|                 '2488000000' => 'OC-48', |                 '2488000000' => 'OC-48', | ||||||
|              ) |              ) | ||||||
| 
 | 
 | ||||||
| @@ -3349,6 +3435,7 @@ munge_highspeed(). SNMP::Info can return speeds up to terabit levels this way. | |||||||
|     '54000000'   => '54 Mbps', |     '54000000'   => '54 Mbps', | ||||||
|     '64000000'   => '64 Mbps', |     '64000000'   => '64 Mbps', | ||||||
|     '100000000'  => '100 Mbps', |     '100000000'  => '100 Mbps', | ||||||
|  |     '200000000'  => '200 Mbps', | ||||||
|     '149760000'  => 'ATM on OC-3', |     '149760000'  => 'ATM on OC-3', | ||||||
|     '155000000'  => 'OC-3', |     '155000000'  => 'OC-3', | ||||||
|     '155519000'  => 'OC-3', |     '155519000'  => 'OC-3', | ||||||
| @@ -3358,6 +3445,7 @@ munge_highspeed(). SNMP::Info can return speeds up to terabit levels this way. | |||||||
|     '622000000'  => 'OC-12', |     '622000000'  => 'OC-12', | ||||||
|     '622080000'  => 'OC-12', |     '622080000'  => 'OC-12', | ||||||
|     '1000000000' => '1.0 Gbps', |     '1000000000' => '1.0 Gbps', | ||||||
|  |     '2000000000' => '2.0 Gbps', | ||||||
|     '2488000000' => 'OC-48', |     '2488000000' => 'OC-48', | ||||||
| ); | ); | ||||||
| 
 | 
 | ||||||
| @@ -3793,6 +3881,7 @@ These methods return data as a scalar. | |||||||
| sub _global { | sub _global { | ||||||
|     my $method = shift; |     my $method = shift; | ||||||
|     my $oid    = shift; |     my $oid    = shift; | ||||||
|  |     return sub {} if $method eq 'CARP_TRACE'; | ||||||
| 
 | 
 | ||||||
|     return sub { |     return sub { | ||||||
|         my $self = shift; |         my $self = shift; | ||||||
| @@ -3810,7 +3899,7 @@ sub _global { | |||||||
|         # Return cached data unless loading |         # Return cached data unless loading | ||||||
|         # We now store in raw format so munge before returning |         # We now store in raw format so munge before returning | ||||||
|         # unless expecting raw data |         # unless expecting raw data | ||||||
|         if ( defined $self->{"_$attr"} && !$load ) { |         if ( exists $self->{"_$attr"} && !$load ) { | ||||||
|             my $val = $self->{"_$attr"}; |             my $val = $self->{"_$attr"}; | ||||||
| 
 | 
 | ||||||
|             if ( !$raw ) { |             if ( !$raw ) { | ||||||
| @@ -3911,16 +4000,6 @@ sub _set { | |||||||
|         # Instance is 0 for scalars without a supplied instance |         # Instance is 0 for scalars without a supplied instance | ||||||
|         $var_list->[1] = $list_iid = defined $list_iid ? $list_iid : '0'; |         $var_list->[1] = $list_iid = defined $list_iid ? $list_iid : '0'; | ||||||
| 
 | 
 | ||||||
|         # Check if this method is from a sub or from the tables. |  | ||||||
|         if ( $self->can($list_attr) ) { |  | ||||||
|             $self->error_throw( |  | ||||||
|                 "SNMP::Info::_set($list_attr,$list_val) - Failed. $list_attr is generated in a sub(). set_$list_attr sub required." |  | ||||||
|             ); |  | ||||||
| 
 |  | ||||||
|             # if sub set_attr() existed, we wouldn't have gotten this far. |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         # Lookup oid |         # Lookup oid | ||||||
|         my $oid = undef; |         my $oid = undef; | ||||||
|         $oid = $list_attr             if SNMP::translateObj($list_attr); |         $oid = $list_attr             if SNMP::translateObj($list_attr); | ||||||
| @@ -4168,7 +4247,7 @@ sub _load_attr { | |||||||
|         # partial fetch may strip the Module portion upon return.  We need |         # partial fetch may strip the Module portion upon return.  We need | ||||||
|         # the match to make sure we didn't leave the table during getnext |         # the match to make sure we didn't leave the table during getnext | ||||||
|         # requests |         # requests | ||||||
|          | 
 | ||||||
|         my ($leaf) = $qual_leaf =~ /::(\w+)$/; |         my ($leaf) = $qual_leaf =~ /::(\w+)$/; | ||||||
| 
 | 
 | ||||||
|         $self->debug() |         $self->debug() | ||||||
| @@ -4176,7 +4255,7 @@ sub _load_attr { | |||||||
|             defined $partial ? "($partial)" : '', " : $oid" , |             defined $partial ? "($partial)" : '', " : $oid" , | ||||||
|             defined $partial ? ".$partial" : '', "\n"; |             defined $partial ? ".$partial" : '', "\n"; | ||||||
| 
 | 
 | ||||||
|         my $var = new SNMP::Varbind( [$qual_leaf, $partial] ); |         my $var = SNMP::Varbind->new( [$qual_leaf, $partial] ); | ||||||
| 
 | 
 | ||||||
|         # So devices speaking SNMP v.1 are not supposed to give out |         # So devices speaking SNMP v.1 are not supposed to give out | ||||||
|         # data from SNMP2, but most do.  Net-SNMP, being very precise |         # data from SNMP2, but most do.  Net-SNMP, being very precise | ||||||
| @@ -4369,7 +4448,7 @@ sub snmp_connect_ip { | |||||||
|     return if ( $ip eq '0.0.0.0' ) or ( $ip =~ /^127\./ ); |     return if ( $ip eq '0.0.0.0' ) or ( $ip =~ /^127\./ ); | ||||||
| 
 | 
 | ||||||
|     # Create session object |     # Create session object | ||||||
|     my $snmp_test = new SNMP::Session( |     my $snmp_test = SNMP::Session->new( | ||||||
|         'DestHost'  => $ip, |         'DestHost'  => $ip, | ||||||
|         'Community' => $comm, |         'Community' => $comm, | ||||||
|         'Version'   => $ver |         'Version'   => $ver | ||||||
| @@ -4520,6 +4599,11 @@ sub _validate_autoload_method { | |||||||
|         $leaf_name =~ s/_/-/g; |         $leaf_name =~ s/_/-/g; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     # skip if offline | ||||||
|  |     if ( $self->{Offline} ) { | ||||||
|  |         return [1,(exists $self->{store}->{$method} ? 1: 0)]; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     # Translate MIB leaf node name to OID |     # Translate MIB leaf node name to OID | ||||||
|     my $oid = SNMP::translateObj($leaf_name); |     my $oid = SNMP::translateObj($leaf_name); | ||||||
| 
 | 
 | ||||||
| @@ -4606,21 +4690,27 @@ sub can { | |||||||
|     my $funcs = $self->funcs(); |     my $funcs = $self->funcs(); | ||||||
| 
 | 
 | ||||||
|     # We need to resolve funcs with a prefix or suffix |     # We need to resolve funcs with a prefix or suffix | ||||||
|     my $f_method = $method; |     my $base_method = $method; | ||||||
|     $f_method =~ s/^(load|orig)_//; |     $base_method =~ s/^(load|orig)_//; | ||||||
|     $f_method =~ s/_raw$//; |     $base_method =~ s/_raw$//; | ||||||
| 
 | 
 | ||||||
|     no strict 'refs';    ## no critic (ProhibitNoStrict ) |     no strict 'refs';    ## no critic (ProhibitNoStrict ) | ||||||
| 
 | 
 | ||||||
|  |     # We could add load_/orig_/_raw alternatives to symbol table here on | ||||||
|  |     # first call of any type for a global or func since they all use the same | ||||||
|  |     # destination code, but they aren't used heavily in main code base so | ||||||
|  |     # we’ll just create if/when they are called rather than pollute the | ||||||
|  |     # symbol table with entries that never get called. | ||||||
|  | 
 | ||||||
|     # Check for set_ ing. |     # Check for set_ ing. | ||||||
|     if ( $method =~ /^set_/ ) { |     if ( $method =~ /^set_/ ) { | ||||||
|         return *{$AUTOLOAD} = _make_setter( $method, $oid, @_ ); |         return *{$method} = _make_setter( $method, $oid, @_ ); | ||||||
|     } |     } | ||||||
|     elsif ( defined $funcs->{$f_method} || $table ) { |     elsif ( defined $funcs->{$base_method} || $table ) { | ||||||
|         return *{$AUTOLOAD} = _load_attr( $method, $oid, @_ ); |         return *{$method} = _load_attr( $method, $oid, @_ ); | ||||||
|     } |     } | ||||||
|     else { |     else { | ||||||
|         return *{$AUTOLOAD} = _global( $method, $oid ); |         return *{$method} = _global( $method, $oid ); | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @@ -4660,16 +4750,16 @@ subclass. | |||||||
| 
 | 
 | ||||||
| =cut | =cut | ||||||
| 
 | 
 | ||||||
|  | our $AUTOLOAD; | ||||||
|  | 
 | ||||||
| sub AUTOLOAD { | sub AUTOLOAD { | ||||||
|     my $self = shift; |     my $self = shift; | ||||||
|     my ($sub_name) = $AUTOLOAD =~ /::(\w+)$/; |     my ($sub_name) = $AUTOLOAD =~ /::(\w+)$/; | ||||||
| 
 | 
 | ||||||
|     return if $sub_name =~ /DESTROY$/; |  | ||||||
| 
 |  | ||||||
|     # Typos in function calls in SNMP::Info subclasses turn into |     # Typos in function calls in SNMP::Info subclasses turn into | ||||||
|     # AUTOLOAD requests for non-methods.  While this is deprecated, |     # AUTOLOAD requests for non-methods.  While this is deprecated, | ||||||
|     # we'll still get called, so report a less confusing error. |     # we'll still get called, so report a less confusing error. | ||||||
|     if ( ref($self) !~ /^SNMP::Info/ ) { |     if ( ref($self) !~ /SNMP::Info/ ) { | ||||||
| 
 | 
 | ||||||
|         # croak reports one level too high.  die reports here. |         # croak reports one level too high.  die reports here. | ||||||
|         # I would really like to get the place that's likely to |         # I would really like to get the place that's likely to | ||||||
| @@ -4692,6 +4782,9 @@ sub AUTOLOAD { | |||||||
| 
 | 
 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | # Skip AUTOLOAD() | ||||||
|  | sub DESTROY {} | ||||||
|  | 
 | ||||||
| 1; | 1; | ||||||
| 
 | 
 | ||||||
| =head1 COPYRIGHT AND LICENSE | =head1 COPYRIGHT AND LICENSE | ||||||
| @@ -38,7 +38,7 @@ use SNMP::Info; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS | %MIBS | ||||||
|     = ( 'ALCATEL-IND1-INTERSWITCH-PROTOCOL-MIB' => 'aipAMAPRemDeviceType', ); |     = ( 'ALCATEL-IND1-INTERSWITCH-PROTOCOL-MIB' => 'aipAMAPRemDeviceType', ); | ||||||
| @@ -38,7 +38,7 @@ use SNMP::Info; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %MIBS %FUNCS %GLOBALS %MUNGE/; | use vars qw/$VERSION %MIBS %FUNCS %GLOBALS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( 'ADSL-LINE-MIB' => 'adslLineType' ); | %MIBS = ( 'ADSL-LINE-MIB' => 'adslLineType' ); | ||||||
| 
 | 
 | ||||||
| @@ -38,7 +38,7 @@ use SNMP::Info; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %MIBS %FUNCS %GLOBALS %MUNGE/; | use vars qw/$VERSION %MIBS %FUNCS %GLOBALS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = (); # IF-MIB | %MIBS = (); # IF-MIB | ||||||
| 
 | 
 | ||||||
| @@ -61,7 +61,7 @@ sub agg_ports_ifstack { | |||||||
|   foreach my $idx ( keys %$ifStack ) { |   foreach my $idx ( keys %$ifStack ) { | ||||||
|       my ( $higher, $lower ) = split /\./, $idx; |       my ( $higher, $lower ) = split /\./, $idx; | ||||||
|       next if ( $higher == 0 or $lower == 0 ); |       next if ( $higher == 0 or $lower == 0 ); | ||||||
|       if ( $ifType->{ $higher } eq 'ieee8023adLag' ) { |       if ( $ifType->{ $higher } eq 'ieee8023adLag'  or $ifType->{ $higher } eq 'propMultiplexor') { | ||||||
|           $ret->{ $lower } = $higher; |           $ret->{ $lower } = $higher; | ||||||
|       } |       } | ||||||
|   } |   } | ||||||
| @@ -39,7 +39,7 @@ use SNMP::Info; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
|     %SNMP::Info::MIBS, |     %SNMP::Info::MIBS, | ||||||
| @@ -42,11 +42,12 @@ use SNMP::Info; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION $DEBUG %MIBS %FUNCS %GLOBALS %MUNGE $INIT/; | use vars qw/$VERSION $DEBUG %MIBS %FUNCS %GLOBALS %MUNGE $INIT/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
|     'BRIDGE-MIB'   => 'dot1dBaseBridgeAddress', |     'BRIDGE-MIB'   => 'dot1dBaseBridgeAddress', | ||||||
|     'Q-BRIDGE-MIB' => 'dot1qPvid', |     'Q-BRIDGE-MIB' => 'dot1qPvid', | ||||||
|  |     'RSTP-MIB'     => 'dot1dStpPortOperEdgePort', | ||||||
| ); | ); | ||||||
| 
 | 
 | ||||||
| %GLOBALS = ( | %GLOBALS = ( | ||||||
| @@ -104,6 +105,10 @@ $VERSION = '3.31'; | |||||||
|     'stp_p_bridge'   => 'dot1dStpPortDesignatedBridge', |     'stp_p_bridge'   => 'dot1dStpPortDesignatedBridge', | ||||||
|     'stp_p_port'     => 'dot1dStpPortDesignatedPort', |     'stp_p_port'     => 'dot1dStpPortDesignatedPort', | ||||||
| 
 | 
 | ||||||
|  |     # Rapid Spanning Tree Protocol Table : dot1dStpExtPortEntry | ||||||
|  |     'is_edgeport_admin' => 'dot1dStpPortAdminEdgePort', | ||||||
|  |     'is_edgeport_oper'  => 'dot1dStpPortOperEdgePort', | ||||||
|  | 
 | ||||||
|     # Q-BRIDGE-MIB : dot1qPortVlanTable |     # Q-BRIDGE-MIB : dot1qPortVlanTable | ||||||
|     'qb_i_vlan'        => 'dot1qPvid', |     'qb_i_vlan'        => 'dot1qPvid', | ||||||
|     'qb_i_vlan_type'   => 'dot1qPortAcceptableFrameTypes', |     'qb_i_vlan_type'   => 'dot1qPortAcceptableFrameTypes', | ||||||
| @@ -43,7 +43,7 @@ use SNMP::Info; | |||||||
| use vars | use vars | ||||||
|     qw/$VERSION $DEBUG %FUNCS %GLOBALS %MIBS %MUNGE $INIT %CDP_CAPABILITIES/; |     qw/$VERSION $DEBUG %FUNCS %GLOBALS %MIBS %MUNGE $INIT %CDP_CAPABILITIES/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| # Five data structures required by SNMP::Info | # Five data structures required by SNMP::Info | ||||||
| %MIBS = ( 'CISCO-CDP-MIB' => 'cdpGlobalRun' ); | %MIBS = ( 'CISCO-CDP-MIB' => 'cdpGlobalRun' ); | ||||||
| @@ -1,6 +1,6 @@ | |||||||
| # SNMP::Info::CiscoAgg | # SNMP::Info::CiscoAgg | ||||||
| # | # | ||||||
| # Copyright (c) 2014 SNMP::Info Developers | # Copyright (c) 2018 SNMP::Info Developers | ||||||
| # All rights reserved. | # 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 | ||||||
| @@ -43,7 +43,7 @@ use SNMP::Info::IEEE802dot3ad 'agg_ports_lag'; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %MIBS %FUNCS %GLOBALS %MUNGE/; | use vars qw/$VERSION %MIBS %FUNCS %GLOBALS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
|   %SNMP::Info::IEEE802dot3ad::MIBS, |   %SNMP::Info::IEEE802dot3ad::MIBS, | ||||||
| @@ -52,9 +52,13 @@ $VERSION = '3.31'; | |||||||
| 
 | 
 | ||||||
| %GLOBALS = (); | %GLOBALS = (); | ||||||
| 
 | 
 | ||||||
| %FUNCS = (); | %FUNCS = ( | ||||||
|  |   %SNMP::Info::IEEE802dot3ad::FUNCS, | ||||||
|  | ); | ||||||
| 
 | 
 | ||||||
| %MUNGE = (); | %MUNGE = ( | ||||||
|  |   %SNMP::Info::IEEE802dot3ad::MUNGE, | ||||||
|  | ); | ||||||
| 
 | 
 | ||||||
| sub agg_ports_pagp { | sub agg_ports_pagp { | ||||||
|   my $dev = shift; |   my $dev = shift; | ||||||
| @@ -147,4 +151,8 @@ automatically. | |||||||
| 
 | 
 | ||||||
| =back | =back | ||||||
| 
 | 
 | ||||||
|  | =head2 Table Methods imported from SNMP::Info::IEEE802dot3ad | ||||||
|  | 
 | ||||||
|  | See documentation in L<SNMP::Info::IEEE802dot3ad> for details. | ||||||
|  | 
 | ||||||
| =cut | =cut | ||||||
| @@ -39,7 +39,7 @@ use SNMP::Info; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %MIBS %FUNCS %GLOBALS %MUNGE/; | use vars qw/$VERSION %MIBS %FUNCS %GLOBALS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
|     'CISCO-CONFIG-COPY-MIB' => 'ccCopyTable', |     'CISCO-CONFIG-COPY-MIB' => 'ccCopyTable', | ||||||
| @@ -97,6 +97,10 @@ sub copy_run_tftp { | |||||||
|         print "Using new method, row iid: $rand\n" if $ciscoconfig->debug(); |         print "Using new method, row iid: $rand\n" if $ciscoconfig->debug(); | ||||||
| 
 | 
 | ||||||
|         #Check each set, delete created row if any fail |         #Check each set, delete created row if any fail | ||||||
|  |         unless ( $ciscoconfig->set_config_row_status( 5, $rand ) ) { | ||||||
|  |             $ciscoconfig->error_throw("Initializing config copy instruction failed"); | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|         unless ( $ciscoconfig->set_config_source_type( 4, $rand ) ) { |         unless ( $ciscoconfig->set_config_source_type( 4, $rand ) ) { | ||||||
|             $ciscoconfig->error_throw("Setting source type failed"); |             $ciscoconfig->error_throw("Setting source type failed"); | ||||||
|             unless ( $ciscoconfig->set_config_row_status( 6, $rand ) ) { |             unless ( $ciscoconfig->set_config_row_status( 6, $rand ) ) { | ||||||
| @@ -38,12 +38,13 @@ use Exporter; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %MIBS %FUNCS %GLOBALS %MUNGE %PAECAPABILITIES/; | use vars qw/$VERSION %MIBS %FUNCS %GLOBALS %MUNGE %PAECAPABILITIES/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
|     'CISCO-PORT-SECURITY-MIB' => 'ciscoPortSecurityMIB', |     'CISCO-PORT-SECURITY-MIB' => 'ciscoPortSecurityMIB', | ||||||
|     'CISCO-PAE-MIB'           => 'ciscoPaeMIB', |     'CISCO-PAE-MIB'           => 'ciscoPaeMIB', | ||||||
|     'IEEE8021-PAE-MIB'        => 'dot1xAuthLastEapolFrameSource', |     'IEEE8021-PAE-MIB'        => 'dot1xAuthLastEapolFrameSource', | ||||||
|  |     'CISCO-ERR-DISABLE-MIB'   => 'ciscoErrDisableMIB', | ||||||
| ); | ); | ||||||
| 
 | 
 | ||||||
| %GLOBALS = ( | %GLOBALS = ( | ||||||
| @@ -99,6 +100,9 @@ $VERSION = '3.31'; | |||||||
|     # IEEE8021-PAE-MIB::dot1xPaePortEntry |     # IEEE8021-PAE-MIB::dot1xPaePortEntry | ||||||
|     'pae_i_capabilities'            => 'dot1xPaePortCapabilities', |     'pae_i_capabilities'            => 'dot1xPaePortCapabilities', | ||||||
|     'pae_i_last_eapol_frame_source' => 'dot1xAuthLastEapolFrameSource', |     'pae_i_last_eapol_frame_source' => 'dot1xAuthLastEapolFrameSource', | ||||||
|  | 
 | ||||||
|  |     # CISCO-ERR-DISABLE-MIB::cErrDisableIfStatusEntry | ||||||
|  |     'cerr_i_cause' => 'cErrDisableIfStatusCause', | ||||||
| ); | ); | ||||||
| 
 | 
 | ||||||
| %MUNGE = ( | %MUNGE = ( | ||||||
| @@ -123,13 +127,29 @@ sub munge_pae_capabilities { | |||||||
|     return join( ' ', @vals ); |     return join( ' ', @vals ); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | # Define a generic method to show the cause for a port to be err-disabled. | ||||||
|  | # Cisco indexes cErrDisableIfStatusCause by {ifindex,vlan}, but for a more | ||||||
|  | # generic method, using ifIndex only makes it easier to implement across | ||||||
|  | # device classes. Besides, several (most?) err-disable features will disable | ||||||
|  | # the whole interface anyway, and not just a vlan on the interface. | ||||||
|  | sub i_err_disable_cause { | ||||||
|  |     my $cps = shift; | ||||||
|  |     my $ret; | ||||||
|  |     my $causes = $cps->cerr_i_cause() || {}; | ||||||
|  |     foreach my $interfacevlan (keys %$causes) { | ||||||
|  |         my ($iid, $vid) = split(/\./, $interfacevlan); | ||||||
|  |         $ret->{$iid} = $causes->{$interfacevlan}; | ||||||
|  |     } | ||||||
|  |     return $ret; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| 1; | 1; | ||||||
| __END__ | __END__ | ||||||
| 
 | 
 | ||||||
| =head1 NAME | =head1 NAME | ||||||
| 
 | 
 | ||||||
| SNMP::Info::CiscoPortSecurity - SNMP Interface to data from | SNMP::Info::CiscoPortSecurity - SNMP Interface to data from | ||||||
| F<CISCO-PORT-SECURITY-MIB> and F<CISCO-PAE-MIB> | F<CISCO-PORT-SECURITY-MIB>, F<CISCO-PAE-MIB> and F<CISCO-ERR-DISABLE-MIB>. | ||||||
| 
 | 
 | ||||||
| =head1 AUTHOR | =head1 AUTHOR | ||||||
| 
 | 
 | ||||||
| @@ -153,8 +173,9 @@ Eric Miller | |||||||
| =head1 DESCRIPTION | =head1 DESCRIPTION | ||||||
| 
 | 
 | ||||||
| SNMP::Info::CiscoPortSecurity is a subclass of SNMP::Info that provides | SNMP::Info::CiscoPortSecurity is a subclass of SNMP::Info that provides | ||||||
| an interface to the F<CISCO-PORT-SECURITY-MIB> and F<CISCO-PAE-MIB>.  These | an interface to the F<CISCO-PORT-SECURITY-MIB>, F<CISCO-PAE-MIB> and | ||||||
| MIBs are used across the Catalyst family under CatOS and IOS. | F<CISCO-ERR-DISABLE-MIB>. These MIBs are used across the Catalyst | ||||||
|  | family under CatOS and IOS. | ||||||
| 
 | 
 | ||||||
| Use or create in a subclass of SNMP::Info.  Do not use directly. | Use or create in a subclass of SNMP::Info.  Do not use directly. | ||||||
| 
 | 
 | ||||||
| @@ -172,6 +193,8 @@ None. | |||||||
| 
 | 
 | ||||||
| =item F<IEEE8021-PAE-MIB> | =item F<IEEE8021-PAE-MIB> | ||||||
| 
 | 
 | ||||||
|  | =item F<CISCO-ERR-DISABLE-MIB> | ||||||
|  | 
 | ||||||
| =back | =back | ||||||
| 
 | 
 | ||||||
| =head1 GLOBALS | =head1 GLOBALS | ||||||
| @@ -374,6 +397,31 @@ The source MAC address carried in the most recently received EAPOL frame. | |||||||
| 
 | 
 | ||||||
| =back | =back | ||||||
| 
 | 
 | ||||||
|  | =head2 C<CISCO-ERR-DISABLE-MIB::cErrDisableIfStatusEntry> | ||||||
|  | 
 | ||||||
|  | =over | ||||||
|  | 
 | ||||||
|  | =item $cps->cerr_i_cause() | ||||||
|  | 
 | ||||||
|  | C<cErrDisableIfStatusCause> | ||||||
|  | 
 | ||||||
|  | Indicates the feature/event that caused the {interface, vlan} (or the entire | ||||||
|  | interface) to be error-disabled. | ||||||
|  | 
 | ||||||
|  | =back | ||||||
|  | 
 | ||||||
|  | =head1 METHODS | ||||||
|  | 
 | ||||||
|  | =over | ||||||
|  | 
 | ||||||
|  | =item C<i_err_disable_cause> | ||||||
|  | 
 | ||||||
|  | Returns a HASH reference mapping ifIndex to err-disabled cause. The returned | ||||||
|  | data is sparse, so if the ifIndex is not present in the return value, the port | ||||||
|  | is not err-disabled. | ||||||
|  | 
 | ||||||
|  | =back | ||||||
|  | 
 | ||||||
| =head1 Data Munging Callback Subroutines | =head1 Data Munging Callback Subroutines | ||||||
| 
 | 
 | ||||||
| =over | =over | ||||||
| @@ -39,7 +39,7 @@ use SNMP::Info; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %MIBS %FUNCS %GLOBALS %MUNGE/; | use vars qw/$VERSION %MIBS %FUNCS %GLOBALS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( 'CISCO-POWER-ETHERNET-EXT-MIB' => 'cpeExtPsePortEntPhyIndex', | %MIBS = ( 'CISCO-POWER-ETHERNET-EXT-MIB' => 'cpeExtPsePortEntPhyIndex', | ||||||
|           'CISCO-CDP-MIB' => 'cdpCachePowerConsumption' ); |           'CISCO-CDP-MIB' => 'cdpCachePowerConsumption' ); | ||||||
| @@ -39,7 +39,7 @@ use SNMP::Info; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %MIBS %FUNCS %GLOBALS %MUNGE/; | use vars qw/$VERSION %MIBS %FUNCS %GLOBALS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( 'CISCO-CLASS-BASED-QOS-MIB' => 'cbQosIfIndex', ); | %MIBS = ( 'CISCO-CLASS-BASED-QOS-MIB' => 'cbQosIfIndex', ); | ||||||
| 
 | 
 | ||||||
| @@ -39,7 +39,7 @@ use SNMP::Info; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %MIBS %FUNCS %GLOBALS %MUNGE/; | use vars qw/$VERSION %MIBS %FUNCS %GLOBALS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( 'CISCO-RTTMON-MIB' => 'rttMonCtrlAdminOwner', ); | %MIBS = ( 'CISCO-RTTMON-MIB' => 'rttMonCtrlAdminOwner', ); | ||||||
| 
 | 
 | ||||||
| @@ -38,7 +38,7 @@ use Exporter; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %MIBS %FUNCS %GLOBALS %MUNGE %PORTSTAT/; | use vars qw/$VERSION %MIBS %FUNCS %GLOBALS %MUNGE %PORTSTAT/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( 'CISCO-STACK-MIB' => 'ciscoStackMIB', ); | %MIBS = ( 'CISCO-STACK-MIB' => 'ciscoStackMIB', ); | ||||||
| 
 | 
 | ||||||
| @@ -42,7 +42,7 @@ use SNMP::Info; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %MIBS %FUNCS %GLOBALS %MUNGE/; | use vars qw/$VERSION %MIBS %FUNCS %GLOBALS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
|     'SNMPv2-MIB'            => 'sysDescr', |     'SNMPv2-MIB'            => 'sysDescr', | ||||||
| @@ -36,7 +36,7 @@ use SNMP::Info::Bridge; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION $DEBUG %MIBS %FUNCS %GLOBALS %MUNGE %PORTSTAT $INIT/; | use vars qw/$VERSION $DEBUG %MIBS %FUNCS %GLOBALS %MUNGE %PORTSTAT $INIT/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| @SNMP::Info::CiscoStpExtensions::ISA = qw/SNMP::Info::Bridge SNMP::Info Exporter/; | @SNMP::Info::CiscoStpExtensions::ISA = qw/SNMP::Info::Bridge SNMP::Info Exporter/; | ||||||
| @SNMP::Info::CiscoStpExtensions::EXPORT_OK = qw//; | @SNMP::Info::CiscoStpExtensions::EXPORT_OK = qw//; | ||||||
| @@ -54,12 +54,15 @@ $VERSION = '3.31'; | |||||||
|             'stpx_stp_type'          => 'stpxSpanningTreeType', |             'stpx_stp_type'          => 'stpxSpanningTreeType', | ||||||
|             'stpx_bpduguard_enable'  => 'stpxFastStartBpduGuardEnable', |             'stpx_bpduguard_enable'  => 'stpxFastStartBpduGuardEnable', | ||||||
|             'stpx_bpdufilter_enable' => 'stpxFastStartBpduFilterEnable', |             'stpx_bpdufilter_enable' => 'stpxFastStartBpduFilterEnable', | ||||||
|  |             'stpx_faststart_default' => 'stpxFastStartGlobalDefaultMode', | ||||||
|            ); |            ); | ||||||
| 
 | 
 | ||||||
| %FUNCS   = ( | %FUNCS   = ( | ||||||
|             %SNMP::Info::Bridge::FUNCS, |             %SNMP::Info::Bridge::FUNCS, | ||||||
|             'stpx_rootguard_enabled'      => 'stpxRootGuardConfigEnabled', |             'stpx_rootguard_enabled'      => 'stpxRootGuardConfigEnabled', | ||||||
|             'stpx_loopguard_enabled'      => 'stpxLoopGuardConfigEnabled', |             'stpx_loopguard_enabled'      => 'stpxLoopGuardConfigEnabled', | ||||||
|  |             'stpx_faststart_enabled'      => 'stpxFastStartPortEnable', | ||||||
|  |             'stpx_faststart_operational'  => 'stpxFastStartPortMode', | ||||||
|             'stpx_port_bpduguard_mode'    => 'stpxFastStartPortBpduGuardMode', |             'stpx_port_bpduguard_mode'    => 'stpxFastStartPortBpduGuardMode', | ||||||
|             'stpx_port_bpdufilter_mode'   => 'stpxFastStartPortBpduFilterMode', |             'stpx_port_bpdufilter_mode'   => 'stpxFastStartPortBpduFilterMode', | ||||||
|             'stpx_smst_root'              => 'stpxSMSTInstanceCISTRegionalRoot', |             'stpx_smst_root'              => 'stpxSMSTInstanceCISTRegionalRoot', | ||||||
| @@ -69,7 +72,7 @@ $VERSION = '3.31'; | |||||||
| 
 | 
 | ||||||
| %MUNGE   = ( | %MUNGE   = ( | ||||||
|             %SNMP::Info::Bridge::MUNGE, |             %SNMP::Info::Bridge::MUNGE, | ||||||
|            'stpx_mst_config_digest'     => \&SNMP::Info::CiscoStpExtensions::oct2str, |            'stpx_mst_config_digest'      => \&SNMP::Info::CiscoStpExtensions::oct2str, | ||||||
|            ); |            ); | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @@ -225,6 +228,36 @@ sub i_bpdufilter_enabled { | |||||||
|     return \%res; |     return \%res; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | sub i_faststart_enabled { | ||||||
|  |     my $self    = shift; | ||||||
|  |     my $partial = shift; | ||||||
|  | 
 | ||||||
|  |     my $faststart_default = $self->stpx_faststart_default(); | ||||||
|  |     my $bp_index          = $self->bp_index($partial); | ||||||
|  |     my $faststart         = $self->stpx_faststart_enabled(); | ||||||
|  |     my $faststart_oper    = $self->stpx_faststart_operational(); | ||||||
|  | 
 | ||||||
|  |     my %res; | ||||||
|  |     # stpxFastStartPortEnable is deprecated in favour of stpxFastStartPortMode | ||||||
|  |     # see https://github.com/netdisco/netdisco/issues/12 | ||||||
|  |     foreach my $index ( keys %$faststart, keys %$faststart_oper ){ | ||||||
|  |         my $mode = $faststart_oper->{$index} || $faststart->{$index}; | ||||||
|  |         my $iid  = $bp_index->{$index}; | ||||||
|  |         next unless defined $iid; | ||||||
|  |         next unless defined $mode; | ||||||
|  |         if ( $mode eq 'default' ){ | ||||||
|  |             $res{$iid} =  $faststart_default; | ||||||
|  |         }else{ | ||||||
|  |             $res{$iid} = $mode; | ||||||
|  |         } | ||||||
|  |         $res{$iid} = 'enable'  if $res{$iid} eq 'true'; | ||||||
|  |         $res{$iid} = 'disable' if $res{$iid} eq 'false'; | ||||||
|  |         $res{$iid} = 1 if $res{$iid} =~ m/enable/i; # enableForTrunk | ||||||
|  |         $res{$iid} = 0 if $res{$iid} eq 'disable'; | ||||||
|  |     } | ||||||
|  |     return \%res; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
| sub oct2str { | sub oct2str { | ||||||
|     my ($v) = @_; |     my ($v) = @_; | ||||||
| @@ -340,6 +373,13 @@ Format is a hash reference with key = C<ifIndex>, value = [1|0] | |||||||
| 
 | 
 | ||||||
| (C<stpxFastStartBpduFilterEnable>) | (C<stpxFastStartBpduFilterEnable>) | ||||||
| 
 | 
 | ||||||
|  | =item $stpx->i_faststart_enabled() | ||||||
|  | 
 | ||||||
|  | Returns 1 or 0 depending on whether FastStart (aka PortFast) is enabled on a | ||||||
|  | given port.  Format is a hash reference with key = C<ifIndex>, value = [1|0] | ||||||
|  | 
 | ||||||
|  | (C<stpxFastStartPortEnable> and C<stpxFastStartPortMode>) | ||||||
|  | 
 | ||||||
| =back | =back | ||||||
| 
 | 
 | ||||||
| =head1 MUNGES | =head1 MUNGES | ||||||
| @@ -41,7 +41,7 @@ use SNMP::Info; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %MIBS %FUNCS %GLOBALS %MUNGE/; | use vars qw/$VERSION %MIBS %FUNCS %GLOBALS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
|     'CISCO-VTP-MIB'                       => 'vtpVlanName', |     'CISCO-VTP-MIB'                       => 'vtpVlanName', | ||||||
| @@ -39,7 +39,7 @@ use SNMP::Info; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
|     'EXTREME-EDP-MIB'   => 'extremeEdpPortIfIndex', |     'EXTREME-EDP-MIB'   => 'extremeEdpPortIfIndex', | ||||||
| @@ -41,7 +41,7 @@ use SNMP::Info; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %MIBS %FUNCS %GLOBALS %MUNGE/; | use vars qw/$VERSION %MIBS %FUNCS %GLOBALS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( 'ENTITY-MIB' => 'entPhysicalSerialNum' ); | %MIBS = ( 'ENTITY-MIB' => 'entPhysicalSerialNum' ); | ||||||
| 
 | 
 | ||||||
| @@ -41,7 +41,7 @@ use SNMP::Info; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %MIBS %FUNCS %GLOBALS %MUNGE/; | use vars qw/$VERSION %MIBS %FUNCS %GLOBALS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( 'EtherLike-MIB' => 'etherMIB' ); | %MIBS = ( 'EtherLike-MIB' => 'etherMIB' ); | ||||||
| 
 | 
 | ||||||
| @@ -42,7 +42,7 @@ use SNMP::Info; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( 'FOUNDRY-SN-SWITCH-GROUP-MIB' => 'snFdpGlobalRun' ); | %MIBS = ( 'FOUNDRY-SN-SWITCH-GROUP-MIB' => 'snFdpGlobalRun' ); | ||||||
| 
 | 
 | ||||||
| @@ -50,7 +50,7 @@ $VERSION = '3.31'; | |||||||
|     'fdp_run'      => 'snFdpGlobalRun', |     'fdp_run'      => 'snFdpGlobalRun', | ||||||
|     'fdp_interval' => 'snFdpGlobalMessageInterval', |     'fdp_interval' => 'snFdpGlobalMessageInterval', | ||||||
|     'fdp_holdtime' => 'snFdpGlobalHoldTime', |     'fdp_holdtime' => 'snFdpGlobalHoldTime', | ||||||
|     'fdp_id'       => 'snFdpGlobalDeviceId', |     'fdp_gid'      => 'snFdpGlobalDeviceId', | ||||||
| ); | ); | ||||||
| 
 | 
 | ||||||
| %FUNCS = ( | %FUNCS = ( | ||||||
| @@ -231,7 +231,7 @@ Time in seconds that FDP messages are kept. | |||||||
| 
 | 
 | ||||||
| (C<fdpGlobalHoldTime>) | (C<fdpGlobalHoldTime>) | ||||||
| 
 | 
 | ||||||
| =item  $fdp->fdp_id()  | =item  $fdp->fdp_gid() | ||||||
| 
 | 
 | ||||||
| Returns FDP device ID.   | Returns FDP device ID.   | ||||||
| 
 | 
 | ||||||
| @@ -38,7 +38,7 @@ use Exporter; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( 'IEEE802dot11-MIB' => 'dot11DesiredSSID', ); | %MIBS = ( 'IEEE802dot11-MIB' => 'dot11DesiredSSID', ); | ||||||
| 
 | 
 | ||||||
| @@ -1,6 +1,6 @@ | |||||||
| # SNMP::Info::IEEE802dot3ad | # SNMP::Info::IEEE802dot3ad | ||||||
| # | # | ||||||
| # Copyright (c) 2014 SNMP::Info Developers | # Copyright (c) 2018 SNMP::Info Developers | ||||||
| # All rights reserved. | # 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 | ||||||
| @@ -43,7 +43,7 @@ use SNMP::Info::Aggregate; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %MIBS %FUNCS %GLOBALS %MUNGE/; | use vars qw/$VERSION %MIBS %FUNCS %GLOBALS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
|   %SNMP::Info::Aggregate::MIBS, |   %SNMP::Info::Aggregate::MIBS, | ||||||
| @@ -52,29 +52,30 @@ $VERSION = '3.31'; | |||||||
| 
 | 
 | ||||||
| %GLOBALS = (); | %GLOBALS = (); | ||||||
| 
 | 
 | ||||||
| %FUNCS = (); | %FUNCS = ( | ||||||
|  |   'ad_lag_ports'    => 'dot3adAggPortListPorts', | ||||||
|  |  ); | ||||||
| 
 | 
 | ||||||
| %MUNGE = (); | %MUNGE = ( | ||||||
|  |   'ad_lag_ports' => \&SNMP::Info::munge_port_list, | ||||||
|  |  ); | ||||||
| 
 | 
 | ||||||
| sub agg_ports_lag { | sub agg_ports_lag { | ||||||
|   my $dev = shift; |   my $dev = shift; | ||||||
| 
 | 
 | ||||||
|   # TODO: implement partial |   # TODO: implement partial | ||||||
|   my $masters = $dev->dot3adAggActorOperKey; |   my $ports  = $dev->ad_lag_ports; | ||||||
|   my $slaves  = $dev->dot3adAggPortActorOperKey; |  | ||||||
| 
 | 
 | ||||||
|   return {} unless |   return {} unless ref {} eq ref $ports and scalar keys %$ports; | ||||||
|     ref {} eq ref $masters and scalar keys %$masters |  | ||||||
|     and ref {} eq ref $slaves and scalar keys %$slaves; |  | ||||||
| 
 | 
 | ||||||
|   my $ret = {}; |   my $ret = {}; | ||||||
|   foreach my $s (keys %$slaves) { |   foreach my $m ( keys %$ports ) { | ||||||
|       next if $slaves->{$s} == 0; |     my $idx = $m; | ||||||
|       foreach my $m (keys %$masters) { |     my $portlist = $ports->{$m}; | ||||||
|           next unless $masters->{$m} == $slaves->{$s}; |     next unless $portlist; | ||||||
|           $ret->{$s} = $m; |     for ( my $i = 0; $i <= scalar(@$portlist); $i++ ) { | ||||||
|           last; |       $ret->{$i+1} = $idx if ( @$portlist[$i] ); | ||||||
|       } |     } | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   return $ret; |   return $ret; | ||||||
| @@ -44,7 +44,7 @@ use constant { | |||||||
|     IPV6MIB => 3, |     IPV6MIB => 3, | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @@ -72,15 +72,18 @@ $VERSION = '3.31'; | |||||||
|     'ip_pfx_origin'     => 'ipAddressPrefixOrigin',         # IP-MIB |     'ip_pfx_origin'     => 'ipAddressPrefixOrigin',         # IP-MIB | ||||||
|     'c_pfx_origin'      => 'cIpAddressPfxOrigin',           # CISCO-IETF-IP-MIB  |     'c_pfx_origin'      => 'cIpAddressPfxOrigin',           # CISCO-IETF-IP-MIB  | ||||||
| 
 | 
 | ||||||
|     'ip_addr6_pfx'      => 'ipAddressPrefix',              # IP-MIB  |     'ip_addr6_pfx'      => 'ipAddressPrefix',               # IP-MIB | ||||||
|     'c_addr6_pfx'       => 'cIpAddressPrefix',              # CISCO-IETF-IP-MIB  |     'c_addr6_pfx'       => 'cIpAddressPrefix',              # CISCO-IETF-IP-MIB  | ||||||
| 
 | 
 | ||||||
|     'ip_addr6_index'    => 'ipAddressIfIndex',              # IP-MIBw |     'ip_addr6_pfxlen'   => 'ipAddressPrefixLength',         # IP-MIB | ||||||
|  |     'c_addr6_pfxlen'    => 'cIpAddressPfxLength',           # CISCO-IETF-IP-MIB | ||||||
|  |     'i6_addr_pfxlen'    => 'ipv6AddrPfxLength',             # IPV6-MIB | ||||||
|  | 
 | ||||||
|  |     'ip_addr6_index'    => 'ipAddressIfIndex',              # IP-MIB | ||||||
|     'c_addr6_index'     => 'cIpAddressIfIndex',             # CISCO-IETF-IP-MIB  |     'c_addr6_index'     => 'cIpAddressIfIndex',             # CISCO-IETF-IP-MIB  | ||||||
| 
 | 
 | ||||||
|     'ip_addr6_type'     => 'ipAddressType',                 # IP-MIB |     'ip_addr6_type'     => 'ipAddressType',                 # IP-MIB | ||||||
|     'c_addr6_type'      => 'cIpAddressType',                # CISCO-IETF-IP-MIB |     'c_addr6_type'      => 'cIpAddressType',                # CISCO-IETF-IP-MIB | ||||||
|      |  | ||||||
| ); | ); | ||||||
| 
 | 
 | ||||||
| %MUNGE = ( | %MUNGE = ( | ||||||
| @@ -142,6 +145,12 @@ sub ipv6_n2p_addr { | |||||||
|                     # so what we've collected in that variable is actually the first byte of the address. |                     # so what we've collected in that variable is actually the first byte of the address. | ||||||
|                     $v6_packed = pack('C', $addrsize) . $v6_packed; |                     $v6_packed = pack('C', $addrsize) . $v6_packed; | ||||||
|                 } |                 } | ||||||
|  |                 if (length($v6_packed) == 17) { | ||||||
|  |                     # Workaround for IPV6-MIB on Windows 2012: if the address is one byte too long, the SNMP agent probably has an incorrect | ||||||
|  |                     # implementation where a length field precedes the actual IPv6 address. | ||||||
|  |                     # In that case, the first character should be chr(16), ie 0x10; strip it if that's the case. | ||||||
|  |                     $v6_packed =~ s/^\x10//; | ||||||
|  |                 } | ||||||
|                 if (length($v6_packed) == 16) { |                 if (length($v6_packed) == 16) { | ||||||
|                     $v6addr = join(':', map { sprintf("%04x", $_) } unpack("n*", $v6_packed) ); |                     $v6addr = join(':', map { sprintf("%04x", $_) } unpack("n*", $v6_packed) ); | ||||||
|                     $return->{$row} = $v6addr; |                     $return->{$row} = $v6addr; | ||||||
| @@ -307,7 +316,9 @@ sub ipv6_addr_prefix { | |||||||
|     foreach my $row (keys %$ipv6_addr_prefix){ |     foreach my $row (keys %$ipv6_addr_prefix){ | ||||||
|         if ($row =~ /^(\d+)\.[\d\.]+$/) { |         if ($row =~ /^(\d+)\.[\d\.]+$/) { | ||||||
|             my $type = $1; |             my $type = $1; | ||||||
|             if ($type == 2) { # IPv6 | 	    if (($type == 2) or ($type == 4)) { # IPv6 | ||||||
|  | 		# Remove interface specific part from vrf interfaces | ||||||
|  | 		if ($row =~ /^((\d+\.){17}\d+)/) { $row = $1 } | ||||||
| 		# Remove the OID part from the value | 		# Remove the OID part from the value | ||||||
| 		my $val = $ipv6_addr_prefix->{$row}; | 		my $val = $ipv6_addr_prefix->{$row}; | ||||||
| 		if ( $val =~ /^.+?((?:\d+\.){19}\d+)$/ ){ | 		if ( $val =~ /^.+?((?:\d+\.){19}\d+)$/ ){ | ||||||
| @@ -321,6 +332,33 @@ sub ipv6_addr_prefix { | |||||||
|     return $return; |     return $return; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | sub ipv6_addr_prefixlength { | ||||||
|  |     my $info = shift; | ||||||
|  |     my $return; | ||||||
|  |     my $ipv6_addr_prefix = &_test_methods( $info, { | ||||||
|  |         ip_addr6_pfx  => IPMIB, | ||||||
|  |         c_addr6_pfx   => CISCO, | ||||||
|  |     }); | ||||||
|  |     return unless defined $ipv6_addr_prefix; | ||||||
|  |     foreach my $row (keys %$ipv6_addr_prefix) { | ||||||
|  |         if ($row =~ /^(\d+)\.[\d\.]+$/) { | ||||||
|  |             my $type = $1; | ||||||
|  |             if (($type == 2) or ($type == 4)) { # IPv6 | ||||||
|  |                 # Remove interface specific part from vrf interfaces | ||||||
|  |                 if ($row =~ /^((\d+\.){17}\d+)/) { $row = $1 } | ||||||
|  |                 # Remove the OID part from the value | ||||||
|  |                 my $val = $ipv6_addr_prefix->{$row}; | ||||||
|  |                 if ( $val =~ /^.+?((?:\d+\.){19}(\d+))$/ ) { | ||||||
|  |                     $val = $2; | ||||||
|  |                     $return->{$row} = $val; | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |     printf("%s: data comes from %s.\n", &_my_sub_name, $info->_method_used() ) if $info->debug(); | ||||||
|  |     return $return; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| sub ipv6_addr { | sub ipv6_addr { | ||||||
|     my $info = shift; |     my $info = shift; | ||||||
|     my $return; |     my $return; | ||||||
| @@ -347,6 +385,7 @@ sub ipv6_addr { | |||||||
| sub _method_used { | sub _method_used { | ||||||
|     my $info = shift; |     my $info = shift; | ||||||
|     my $return = 'none of the MIBs'; |     my $return = 'none of the MIBs'; | ||||||
|  |     # FIXME ugh! a global. makes order of calls important for debug. | ||||||
|     if (defined $info::METHOD) { |     if (defined $info::METHOD) { | ||||||
|         if ($info::METHOD eq IPMIB) { |         if ($info::METHOD eq IPMIB) { | ||||||
|             $return = 'IP-MIB'; |             $return = 'IP-MIB'; | ||||||
| @@ -366,6 +405,7 @@ sub _test_methods { | |||||||
|     foreach my $method (sort {$test->{$a} <=> $test->{$b}} keys %$test) { |     foreach my $method (sort {$test->{$a} <=> $test->{$b}} keys %$test) { | ||||||
|         $return = $info->$method || {}; |         $return = $info->$method || {}; | ||||||
|         if (scalar keys %$return) { |         if (scalar keys %$return) { | ||||||
|  |             # FIXME ugh! a global. makes order of calls important for debug. | ||||||
|             $info::METHOD = $test->{$method}; |             $info::METHOD = $test->{$method}; | ||||||
|             last; |             last; | ||||||
|         } |         } | ||||||
| @@ -482,6 +522,10 @@ Maps an IPv6 prefix with its origin (manual, well-known, dhcp, etc.) | |||||||
| 
 | 
 | ||||||
| Maps IPv6 addresses with their prefixes | Maps IPv6 addresses with their prefixes | ||||||
| 
 | 
 | ||||||
|  | =item $info->ipv6_addr_prefixlength() | ||||||
|  | 
 | ||||||
|  | Maps IPv6 addresses with their prefix length | ||||||
|  | 
 | ||||||
| =item $info->ipv6_addr() | =item $info->ipv6_addr() | ||||||
| 
 | 
 | ||||||
| Maps a table instance to an IPv6 address | Maps a table instance to an IPv6 address | ||||||
| @@ -39,10 +39,11 @@ use SNMP::Info; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
|     'LLDP-MIB'          => 'lldpLocSysCapEnabled', |     'LLDP-MIB'          => 'lldpLocSysCapEnabled', | ||||||
|  |     'LLDP-EXT-MED-MIB'  => 'lldpXMedMIB', | ||||||
|     'LLDP-EXT-DOT1-MIB' => 'lldpXdot1MIB', |     'LLDP-EXT-DOT1-MIB' => 'lldpXdot1MIB', | ||||||
|     'LLDP-EXT-DOT3-MIB' => 'lldpXdot3MIB', |     'LLDP-EXT-DOT3-MIB' => 'lldpXdot3MIB', | ||||||
| ); | ); | ||||||
| @@ -69,6 +70,18 @@ $VERSION = '3.31'; | |||||||
|     'lldp_rem_sys_cap'  => 'lldpRemSysCapEnabled', |     'lldp_rem_sys_cap'  => 'lldpRemSysCapEnabled', | ||||||
|     'lldp_rem_cap_spt'  => 'lldpRemSysCapSupported', |     'lldp_rem_cap_spt'  => 'lldpRemSysCapSupported', | ||||||
| 
 | 
 | ||||||
|  |     # LLDP-MIB::lldpXMedRemInventoryTable | ||||||
|  |     'lldp_rem_hw_rev' => 'lldpXMedRemHardwareRev', | ||||||
|  |     'lldp_rem_fw_rev' => 'lldpXMedRemFirmwareRev', | ||||||
|  |     'lldp_rem_sw_rev' => 'lldpXMedRemSoftwareRev', | ||||||
|  |     'lldp_rem_serial' => 'lldpXMedRemSerialNum', | ||||||
|  |     'lldp_rem_vendor' => 'lldpXMedRemMfgName', | ||||||
|  |     'lldp_rem_model'  => 'lldpXMedRemModelName', | ||||||
|  |     'lldp_rem_asset'  => 'lldpXMedRemAssetID', | ||||||
|  | 
 | ||||||
|  |     'lldp_rem_media_cap'     => 'lldpXMedRemCapCurrent', | ||||||
|  |     'lldp_rem_media_cap_spt' => 'lldpXMedRemCapSupported', | ||||||
|  | 
 | ||||||
|     # LLDP-MIB::lldpRemManAddrTable |     # LLDP-MIB::lldpRemManAddrTable | ||||||
|     'lldp_rman_addr' => 'lldpRemManAddrIfSubtype', |     'lldp_rman_addr' => 'lldpRemManAddrIfSubtype', | ||||||
| ); | ); | ||||||
| @@ -82,6 +95,17 @@ $VERSION = '3.31'; | |||||||
|     'lldp_sys_cap'       => \&SNMP::Info::munge_bits, |     'lldp_sys_cap'       => \&SNMP::Info::munge_bits, | ||||||
|     'lldp_rem_sys_cap'   => \&SNMP::Info::munge_bits, |     'lldp_rem_sys_cap'   => \&SNMP::Info::munge_bits, | ||||||
|     'lldp_rem_cap_spt'   => \&SNMP::Info::munge_bits, |     'lldp_rem_cap_spt'   => \&SNMP::Info::munge_bits, | ||||||
|  | 
 | ||||||
|  |     'lldp_rem_hw_rev' => \&SNMP::Info::munge_null, | ||||||
|  |     'lldp_rem_fw_rev' => \&SNMP::Info::munge_null, | ||||||
|  |     'lldp_rem_sw_rev' => \&SNMP::Info::munge_null, | ||||||
|  |     'lldp_rem_serial' => \&SNMP::Info::munge_null, | ||||||
|  |     'lldp_rem_vendor' => \&SNMP::Info::munge_null, | ||||||
|  |     'lldp_rem_model'  => \&SNMP::Info::munge_null, | ||||||
|  |     'lldp_rem_asset'  => \&SNMP::Info::munge_null, | ||||||
|  | 
 | ||||||
|  |     'lldp_rem_media_cap'     => \&SNMP::Info::munge_bits, | ||||||
|  |     'lldp_rem_media_cap_spt' => \&SNMP::Info::munge_bits, | ||||||
| ); | ); | ||||||
| 
 | 
 | ||||||
| sub hasLLDP { | sub hasLLDP { | ||||||
| @@ -323,6 +347,39 @@ sub lldp_cap { | |||||||
|     return \%lldp_cap; |     return \%lldp_cap; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | sub lldp_media_cap { | ||||||
|  |     my $lldp    = shift; | ||||||
|  |     my $partial = shift; | ||||||
|  | 
 | ||||||
|  |     my $lldp_caps = $lldp->lldp_rem_media_cap_spt($partial) || {}; | ||||||
|  | 
 | ||||||
|  |     # Encoded as BITS which Perl Net-SNMP implementation doesn't seem to | ||||||
|  |     # be able to enumerate for us, so we have to get it from the MIB | ||||||
|  |     # and enumerate ourselves | ||||||
|  |     my $oid = SNMP::translateObj( 'lldpXMedRemCapCurrent', 0, 1 ) || ''; | ||||||
|  |     my $enums = ( | ||||||
|  |         ( ref {} eq ref $SNMP::MIB{$oid}{'enums'} ) | ||||||
|  |         ? $SNMP::MIB{$oid}{'enums'} | ||||||
|  |         : {} | ||||||
|  |     ); | ||||||
|  |     my %r_enums = reverse %$enums; | ||||||
|  | 
 | ||||||
|  |     my %lldp_cap; | ||||||
|  |     foreach my $key ( keys %$lldp_caps ) { | ||||||
|  |         my $cap_bits = $lldp_caps->{$key}; | ||||||
|  |         next unless $cap_bits; | ||||||
|  | 
 | ||||||
|  |         my $count = 0; | ||||||
|  |         foreach my $bit ( split //, $cap_bits ) { | ||||||
|  |             if ($bit) { | ||||||
|  |                 push( @{ $lldp_cap{$key} }, $r_enums{$count} ); | ||||||
|  |             } | ||||||
|  |             $count++; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |     return \%lldp_cap; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| #sub root_ip { | #sub root_ip { | ||||||
| #    my $lldp = shift; | #    my $lldp = shift; | ||||||
| # | # | ||||||
| @@ -435,6 +492,8 @@ None. | |||||||
| 
 | 
 | ||||||
| =item F<LLDP-MIB> | =item F<LLDP-MIB> | ||||||
| 
 | 
 | ||||||
|  | =item F<LLDP-EXT-MED-MIB> | ||||||
|  | 
 | ||||||
| =item F<LLDP-EXT-DOT1-MIB> | =item F<LLDP-EXT-DOT1-MIB> | ||||||
| 
 | 
 | ||||||
| =item F<LLDP-EXT-DOT3-MIB> | =item F<LLDP-EXT-DOT3-MIB> | ||||||
| @@ -567,6 +626,12 @@ Returns hash of arrays with each array containing the system capabilities | |||||||
| supported by the remote system.  Possible elements in the array are | supported by the remote system.  Possible elements in the array are | ||||||
| enumerated from C<LldpSystemCapabilitiesMap>. | enumerated from C<LldpSystemCapabilitiesMap>. | ||||||
| 
 | 
 | ||||||
|  | =item  $lldp->lldp_media_cap()  | ||||||
|  | 
 | ||||||
|  | Returns hash of arrays with each array containing the media capabilities | ||||||
|  | supported by the remote system.  Possible elements in the array are | ||||||
|  | enumerated from C<LldpXMedCapabilities>. | ||||||
|  | 
 | ||||||
| =back | =back | ||||||
| 
 | 
 | ||||||
| =head2 LLDP Remote Table (C<lldpRemTable>) | =head2 LLDP Remote Table (C<lldpRemTable>) | ||||||
| @@ -628,6 +693,65 @@ Nulls are removed before the value is returned. | |||||||
| 
 | 
 | ||||||
| (C<lldpRemSysDesc>) | (C<lldpRemSysDesc>) | ||||||
| 
 | 
 | ||||||
|  | =item $lldp->lldp_rem_hw_rev() | ||||||
|  | 
 | ||||||
|  | Returns the string value used to identify the hardware revision of the | ||||||
|  | remote system. Nulls are removed before the value is returned.  | ||||||
|  | 
 | ||||||
|  | (C<lldpXMedRemHardwareRev>) | ||||||
|  | 
 | ||||||
|  | =item $lldp->lldp_rem_fw_rev() | ||||||
|  | 
 | ||||||
|  | Returns the string value used to identify the firmware revision of the | ||||||
|  | remote system. Nulls are removed before the value is returned.  | ||||||
|  | 
 | ||||||
|  | (C<lldpXMedRemHardwareRev>) | ||||||
|  | 
 | ||||||
|  | =item $lldp->lldp_rem_sw_rev() | ||||||
|  | 
 | ||||||
|  | Returns the string value used to identify the software revision of the | ||||||
|  | remote system. Nulls are removed before the value is returned.  | ||||||
|  | 
 | ||||||
|  | (C<lldpXMedRemSoftwareRev>) | ||||||
|  | 
 | ||||||
|  | =item $lldp->lldp_rem_serial() | ||||||
|  | 
 | ||||||
|  | Returns the string value used to identify the serial number of the | ||||||
|  | remote system. Nulls are removed before the value is returned.  | ||||||
|  | 
 | ||||||
|  | (C<lldpXMedRemSerialNum>) | ||||||
|  | 
 | ||||||
|  | =item $lldp->lldp_rem_vendor() | ||||||
|  | 
 | ||||||
|  | Returns the string value used to identify the manufacturer of the | ||||||
|  | remote system. Nulls are removed before the value is returned.  | ||||||
|  | 
 | ||||||
|  | (C<lldpXMedRemMfgName>) | ||||||
|  | 
 | ||||||
|  | =item $lldp->lldp_rem_asset() | ||||||
|  | 
 | ||||||
|  | Returns the string value used to identify the asset number of the | ||||||
|  | remote system. Nulls are removed before the value is returned.  | ||||||
|  | 
 | ||||||
|  | (C<lldpXMedRemAssetID>) | ||||||
|  | 
 | ||||||
|  | =item $lldp->lldp_rem_model() | ||||||
|  | 
 | ||||||
|  | Returns the string value used to identify the model of the | ||||||
|  | remote system. Nulls are removed before the value is returned.  | ||||||
|  | 
 | ||||||
|  | (C<lldpXMedRemModelName>) | ||||||
|  | 
 | ||||||
|  | =item  $lldp->lldp_rem_media_cap_spt()  | ||||||
|  | 
 | ||||||
|  | Returns which media capabilities are supported on the remote system. Results | ||||||
|  | are munged into an ascii binary string, LSB. | ||||||
|  | 
 | ||||||
|  | =item  $lldp->lldp_rem_media_cap()  | ||||||
|  | 
 | ||||||
|  | Returns which media capabilities are enabled on the remote system. Results | ||||||
|  | are munged into an ascii binary string, LSB. | ||||||
|  | 
 | ||||||
| =item  $lldp->lldp_rem_sys_cap()  | =item  $lldp->lldp_rem_sys_cap()  | ||||||
| 
 | 
 | ||||||
| Returns which system capabilities are enabled on the remote system.  Results | Returns which system capabilities are enabled on the remote system.  Results | ||||||
| @@ -41,7 +41,7 @@ use SNMP::Info; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %PORTSTAT %MUNGE/; | use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %PORTSTAT %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( %SNMP::Info::MIBS, 'SNMP-REPEATER-MIB' => 'rptrPortGroupIndex' ); | %MIBS = ( %SNMP::Info::MIBS, 'SNMP-REPEATER-MIB' => 'rptrPortGroupIndex' ); | ||||||
| 
 | 
 | ||||||
| @@ -41,7 +41,7 @@ use SNMP::Info::Layer1; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| # Set for No CDP | # Set for No CDP | ||||||
| %GLOBALS = ( %SNMP::Info::Layer1::GLOBALS, 'root_ip' => 'actualIPAddr', ); | %GLOBALS = ( %SNMP::Info::Layer1::GLOBALS, 'root_ip' => 'actualIPAddr', ); | ||||||
| @@ -78,7 +78,7 @@ sub model { | |||||||
| 
 | 
 | ||||||
|     my $desc = $allied->description(); |     my $desc = $allied->description(); | ||||||
| 
 | 
 | ||||||
|     if ( $desc =~ /(AT-\d{4}\S{1}?)/ ) { |     if ( $desc =~ /(AT-\d{4}\S{1})/ ) { | ||||||
|         return $1; |         return $1; | ||||||
|     } |     } | ||||||
|     return; |     return; | ||||||
| @@ -41,7 +41,7 @@ use SNMP::Info::Layer1; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| # Set for No CDP | # Set for No CDP | ||||||
| %GLOBALS = ( %SNMP::Info::Layer1::GLOBALS, ); | %GLOBALS = ( %SNMP::Info::Layer1::GLOBALS, ); | ||||||
| @@ -42,7 +42,7 @@ use SNMP::Info::Layer2; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
|     %SNMP::Info::Layer2::MIBS, |     %SNMP::Info::Layer2::MIBS, | ||||||
| @@ -39,7 +39,7 @@ use SNMP::Info::Layer1; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE $AUTOLOAD/; | use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE $AUTOLOAD/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
|     %SNMP::Info::Layer1::MIBS, |     %SNMP::Info::Layer1::MIBS, | ||||||
| @@ -39,7 +39,7 @@ use SNMP::Info::Layer2; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
|     %SNMP::Info::Layer2::MIBS, |     %SNMP::Info::Layer2::MIBS, | ||||||
| @@ -46,7 +46,7 @@ use SNMP::Info::LLDP; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %PORTSTAT %MUNGE/; | use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %PORTSTAT %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
|     %SNMP::Info::MIBS,         %SNMP::Info::Bridge::MIBS, |     %SNMP::Info::MIBS,         %SNMP::Info::Bridge::MIBS, | ||||||
| @@ -11,7 +11,7 @@ use SNMP::Info::CDP; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE $AUTOLOAD/; | use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE $AUTOLOAD/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
|     %SNMP::Info::LLDP::MIBS, |     %SNMP::Info::LLDP::MIBS, | ||||||
| @@ -73,6 +73,8 @@ sub model { | |||||||
|     my $descr = $dsmodel->description(); |     my $descr = $dsmodel->description(); | ||||||
|     if ( $descr =~ /^([\S ]+) Software.*/){ |     if ( $descr =~ /^([\S ]+) Software.*/){ | ||||||
|         return $1; |         return $1; | ||||||
|  |     } else { | ||||||
|  |         return $descr; | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
							
								
								
									
										286
									
								
								lib/SNMP/Info/Layer2/Adtran.pm
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										286
									
								
								lib/SNMP/Info/Layer2/Adtran.pm
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,286 @@ | |||||||
|  | package SNMP::Info::Layer2::Adtran; | ||||||
|  |  | ||||||
|  | use strict; | ||||||
|  | use Exporter; | ||||||
|  | use SNMP::Info::LLDP; | ||||||
|  | use SNMP::Info::Layer2; | ||||||
|  | use SNMP::Info::Layer3; | ||||||
|  |  | ||||||
|  | @SNMP::Info::Layer2::Adtran::ISA       = qw/SNMP::Info::LLDP SNMP::Info::Layer2 Exporter/; | ||||||
|  | @SNMP::Info::Layer2::Adtran::EXPORT_OK = qw//; | ||||||
|  |  | ||||||
|  | use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %MUNGE/; | ||||||
|  |  | ||||||
|  | $VERSION = '3.53'; | ||||||
|  |  | ||||||
|  | # This will be filled in with the device's index into the EntPhysicalEntry | ||||||
|  | # table by the serial() function. | ||||||
|  | our $index = undef; | ||||||
|  |  | ||||||
|  | %MIBS = (  | ||||||
|  |     %SNMP::Info::Layer2::MIBS, | ||||||
|  |     %SNMP::Info::Layer3::MIBS, | ||||||
|  |     'ADTRAN-GENEVC-MIB'     => 'adGenEVCMIB', | ||||||
|  |     'ADTRAN-GENMEF-MIB'     => 'adGenMEFMIB', | ||||||
|  |     'ADTRAN-GENPORT-MIB'    => 'adGenPort', | ||||||
|  |     'ADTRAN-MIB'            => 'adtran', | ||||||
|  |     'ADTRAN-AOSUNIT'     => 'adGenAOSUnitMib', | ||||||
|  |  ); | ||||||
|  |  | ||||||
|  | %GLOBALS = ( | ||||||
|  |     %SNMP::Info::Layer2::GLOBALS,  | ||||||
|  |     %SNMP::Info::Layer3::GLOBALS,  | ||||||
|  |     %SNMP::Info::LLDP::GLOBALS, | ||||||
|  |     'serial'    => 'adProdSerialNumber', | ||||||
|  |     'ad_mgmtevcvid' => 'adGenEVCSysMgmtEVCSTagVID', | ||||||
|  | ); | ||||||
|  |  | ||||||
|  | %FUNCS = ( %SNMP::Info::Layer2::FUNCS, | ||||||
|  |            %SNMP::Info::Layer3::FUNCS, | ||||||
|  |            %SNMP::Info::LLDP::FUNCS,  | ||||||
|  |            'ad_evcstag' => 'adGenEVCLookupName', | ||||||
|  |            'ad_menport' => 'adGenMenPortRowStatus', | ||||||
|  |            'ad_evcnamevid' => 'adGenEVCSTagVID', | ||||||
|  |            'ad_mgmtevcports' => 'adGenSysMgmtEVCInterfaceConnectionType', | ||||||
|  |            'ad_evcmapuniport' => 'adGenMEFMapUNIPort', | ||||||
|  |            'ad_evcmapevc' => 'adGenMEFMapAssociatedEVCAlias', | ||||||
|  |            'ad_genportcustuse' => 'adGenPortCustomerUse', | ||||||
|  | ); | ||||||
|  |  | ||||||
|  | %MUNGE = ( %SNMP::Info::Layer2::MUNGE, %SNMP::Info::LLDP::MUNGE, %SNMP::Info::Layer3::MUNGE ); | ||||||
|  |  | ||||||
|  | sub vendor { | ||||||
|  |     return 'adtran'; | ||||||
|  | } | ||||||
|  | sub os { | ||||||
|  |     return 'aos'; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | sub layers { | ||||||
|  |     my $adtran = shift; | ||||||
|  |      | ||||||
|  |     my $layers = $adtran->SUPER::layers(); | ||||||
|  |     # Some netvantas don't report L2 properly  | ||||||
|  |     my $macs   = $adtran->fw_mac(); | ||||||
|  |      | ||||||
|  |     if (keys %$macs) { | ||||||
|  |         my $l = substr $layers, 6, 1, "1"; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     return $layers; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | sub os_ver { | ||||||
|  |     my $adtran = shift; | ||||||
|  |     my $ver = $adtran->adProdSwVersion() || undef; | ||||||
|  |     return $ver if (defined $ver); | ||||||
|  |     my $aos_ver = $adtran->adAOSDeviceVersion(); | ||||||
|  |     return $aos_ver; | ||||||
|  | } | ||||||
|  | sub model {  | ||||||
|  |     my $adtran = shift; | ||||||
|  |     my $id = $adtran->id(); | ||||||
|  |     my $mod = $adtran->adProdName() || undef; | ||||||
|  |     return $mod if (defined $mod); | ||||||
|  |     my $model = $adtran->adAOSDeviceProductName() || undef; | ||||||
|  |     return $model; | ||||||
|  | } | ||||||
|  | sub serial {  | ||||||
|  |     my $adtran = shift; | ||||||
|  |     my $e_serial = $adtran->e_serial() || {}; | ||||||
|  |     my $serial2 = $e_serial->{1} || undef; | ||||||
|  |     return $serial2 if ( defined $serial2 ); | ||||||
|  |     return $adtran->orig_serial(); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | sub i_name { | ||||||
|  |     my $adtran = shift; | ||||||
|  |     my $partial = shift; | ||||||
|  |     my $i_name = $adtran->SUPER::i_alias() || undef;  | ||||||
|  |     return $i_name if (defined $i_name); | ||||||
|  |     $i_name = {}; | ||||||
|  |     my $adname = $adtran->ad_genportcustuse() || undef; | ||||||
|  |     if (defined $adname) {   | ||||||
|  |         foreach my $port (keys %$adname) {  | ||||||
|  |             my @split = split(/\./,$port); | ||||||
|  |             $i_name->{@split[1]} = $adname->{$port}; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |     return $i_name; | ||||||
|  | } | ||||||
|  | sub i_vlan {  | ||||||
|  |     my $adtran = shift; | ||||||
|  |     my $partial = shift; | ||||||
|  |     my $uniports = $adtran->ad_evcmapuniport() || undef; | ||||||
|  |     my $evcmaps = $adtran->ad_evcmapevc() || undef; | ||||||
|  |     my $v_names = $adtran->ad_evcnamevid() || undef; | ||||||
|  |     if (defined $uniports) { | ||||||
|  |         my $vlans = {}; | ||||||
|  |         foreach my $oid (keys %$v_names) { | ||||||
|  |             my $name = pack("C*", split(/\./,$oid)); | ||||||
|  |             $vlans->{$name} = $v_names->{$oid}; | ||||||
|  |         } | ||||||
|  |         my $i_vlan = {}; | ||||||
|  |         foreach my $evcmap (keys %$evcmaps) { | ||||||
|  |             $i_vlan->{$uniports->{$evcmap}} = $vlans->{$evcmaps->{$evcmap}}; | ||||||
|  |         } | ||||||
|  |         return $i_vlan; | ||||||
|  |     } | ||||||
|  |     return {}; | ||||||
|  |          | ||||||
|  | } | ||||||
|  |          | ||||||
|  | sub i_vlan_membership {          | ||||||
|  |     my $adtran  = shift; | ||||||
|  |     my $partial = shift; | ||||||
|  |     my $i_vlan = $adtran->ad_menport(); | ||||||
|  |     if (defined $i_vlan) {  | ||||||
|  |         my $vlans = {}; | ||||||
|  |         my $v_name = $adtran->v_name(); | ||||||
|  |         foreach my $vid (keys %$v_name) { | ||||||
|  |             $vlans->{$v_name->{$vid}} = $vid; | ||||||
|  |         } | ||||||
|  |         my $if_vlans = {}; | ||||||
|  |         foreach my $entry (keys %$i_vlan) { | ||||||
|  |             my @split = split(/(\.0)+\./,$entry); | ||||||
|  |             my $name = pack("C*", split(/\./,@split[0])); | ||||||
|  |             push @{$if_vlans->{@split[2]}}, $vlans->{$name}; | ||||||
|  |         } | ||||||
|  |         my $mgmtevcports = $adtran->ad_mgmtevcports(); | ||||||
|  |         my $mgmtevcid = $adtran->ad_mgmtevcvid(); | ||||||
|  |         foreach my $port (keys %$mgmtevcports) { | ||||||
|  |            push @{$if_vlans->{$port}}, $mgmtevcid; | ||||||
|  |         } | ||||||
|  |         return $if_vlans; | ||||||
|  |     } | ||||||
|  |     return {}; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | sub v_name { | ||||||
|  |     my $adtran = shift; | ||||||
|  |     my $partial = shift; | ||||||
|  |     my $v_index = $adtran->ad_evcstag(); | ||||||
|  |     return {} unless defined $v_index; | ||||||
|  |     $v_index->{$adtran->ad_mgmtevcvid()} = 'system-management-evc'; | ||||||
|  |     return $v_index; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | 1; | ||||||
|  | __END__ | ||||||
|  |  | ||||||
|  | =head1 NAME | ||||||
|  |  | ||||||
|  | SNMP::Info::Layer2::Adtran - SNMP Interface to Adtran Devices | ||||||
|  |  | ||||||
|  | =head1 SYNOPSIS | ||||||
|  |  | ||||||
|  |  # Let SNMP::Info determine the correct subclass for you.  | ||||||
|  |  my $adtran = new SNMP::Info( | ||||||
|  |                           AutoSpecify => 1, | ||||||
|  |                           Debug       => 1, | ||||||
|  |                           DestHost    => 'myrouter', | ||||||
|  |                           Community   => 'public', | ||||||
|  |                           Version     => 2 | ||||||
|  |                         )  | ||||||
|  |     or die "Can't connect to DestHost.\n"; | ||||||
|  |  | ||||||
|  |  my $class      = $adtran->class(); | ||||||
|  |  print "SNMP::Info determined this device to fall under subclass : $class\n"; | ||||||
|  |  | ||||||
|  | =head1 DESCRIPTION | ||||||
|  |  | ||||||
|  | Subclass for adtran Devices running JUNOS | ||||||
|  |  | ||||||
|  | =head2 Inherited Classes | ||||||
|  |  | ||||||
|  | =over | ||||||
|  |  | ||||||
|  | =item SNMP::Info::Layer3 | ||||||
|  |  | ||||||
|  | =item SNMP::Info::LLDP | ||||||
|  |  | ||||||
|  | =back | ||||||
|  |  | ||||||
|  | =head2 Inherited Classes' MIBs | ||||||
|  |  | ||||||
|  | See L<SNMP::Info::Layer3/"Required MIBs"> for its own MIB requirements. | ||||||
|  |  | ||||||
|  | See L<SNMP::Info::LLDP/"Required MIBs"> for its own MIB requirements. | ||||||
|  |  | ||||||
|  | =head1 GLOBALS | ||||||
|  |  | ||||||
|  | These are methods that return scalar value from SNMP | ||||||
|  |  | ||||||
|  | =over | ||||||
|  |  | ||||||
|  | =item $adtran->vendor() | ||||||
|  |  | ||||||
|  | Returns 'adtran' | ||||||
|  |  | ||||||
|  | =item $adtran->os() | ||||||
|  |  | ||||||
|  | Returns 'aos' | ||||||
|  |  | ||||||
|  | =item $adtran->layers() | ||||||
|  |  | ||||||
|  | Ensures that layer two is reported, at least. | ||||||
|  |  | ||||||
|  | =item $adtran->os_ver() | ||||||
|  |  | ||||||
|  | Returns the software version extracted first from C<adProdSwVersion> or | ||||||
|  | C<adAOSDeviceVersion>. | ||||||
|  |  | ||||||
|  | =item $adtran->model() | ||||||
|  |  | ||||||
|  | Returns the model extracted first from C<adProdName> or | ||||||
|  | C<adAOSDeviceProductName>. | ||||||
|  |  | ||||||
|  | =item $adtran->serial() | ||||||
|  |  | ||||||
|  | Returns serial number. | ||||||
|  |  | ||||||
|  | =back | ||||||
|  |  | ||||||
|  | =head2 Globals imported from SNMP::Info::Layer3 | ||||||
|  |  | ||||||
|  | See documentation in L<SNMP::Info::Layer3/"GLOBALS"> for details. | ||||||
|  |  | ||||||
|  | =head2 Global Methods imported from SNMP::Info::LLDP | ||||||
|  |  | ||||||
|  | See documentation in L<SNMP::Info::LLDP/"GLOBALS"> for details. | ||||||
|  |  | ||||||
|  | =head1 TABLE METHODS | ||||||
|  |  | ||||||
|  | These are methods that return tables of information in the form of a reference | ||||||
|  | to a hash. | ||||||
|  |  | ||||||
|  | =over | ||||||
|  |  | ||||||
|  | =item $adtran->v_name() | ||||||
|  |  | ||||||
|  | VLAN names table. | ||||||
|  |  | ||||||
|  | =item $adtran->i_name() | ||||||
|  |  | ||||||
|  | Interface names table. | ||||||
|  |  | ||||||
|  | =item $adtran->i_vlan() | ||||||
|  |  | ||||||
|  | Returns a mapping between C<ifIndex> and the PVID or default VLAN. | ||||||
|  |  | ||||||
|  | =item $adtran->i_vlan_membership() | ||||||
|  |  | ||||||
|  | Returns reference to hash of arrays: key = C<ifIndex>, value = array of VLAN | ||||||
|  | IDs.  These are the VLANs which are members of the egress list for the port. | ||||||
|  |  | ||||||
|  | =back | ||||||
|  |  | ||||||
|  | =head2 Table Methods imported from SNMP::Info::Layer3 | ||||||
|  |  | ||||||
|  | See documentation in L<SNMP::Info::Layer3/"TABLE METHODS"> for details. | ||||||
|  |  | ||||||
|  | =head2 Table Methods imported from SNMP::Info::LLDP | ||||||
|  |  | ||||||
|  | See documentation in L<SNMP::Info::LLDP/"TABLE METHODS"> for details. | ||||||
|  |  | ||||||
|  | =cut | ||||||
| @@ -40,7 +40,7 @@ use SNMP::Info::Airespace; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
|     %SNMP::Info::MIBS,      %SNMP::Info::Bridge::MIBS, |     %SNMP::Info::MIBS,      %SNMP::Info::Bridge::MIBS, | ||||||
| @@ -97,6 +97,14 @@ my $mcs_index = { | |||||||
| 	m13 => '104', | 	m13 => '104', | ||||||
| 	m14 => '117', | 	m14 => '117', | ||||||
| 	m15 => '130', | 	m15 => '130', | ||||||
|  | 	m16 => '19.5', | ||||||
|  | 	m17 => '39', | ||||||
|  | 	m18 => '58.5', | ||||||
|  | 	m19 => '78', | ||||||
|  | 	m20 => '117', | ||||||
|  | 	m21 => '156', | ||||||
|  | 	m22 => '175.5', | ||||||
|  | 	m23 => '195', | ||||||
| 	# This is a cheat for 802.11a bonded | 	# This is a cheat for 802.11a bonded | ||||||
| 	m108 => '108', | 	m108 => '108', | ||||||
|     }, |     }, | ||||||
| @@ -117,6 +125,14 @@ my $mcs_index = { | |||||||
| 	m13 => '240', | 	m13 => '240', | ||||||
| 	m14 => '270', | 	m14 => '270', | ||||||
| 	m15 => '300', | 	m15 => '300', | ||||||
|  | 	m16 => '45', | ||||||
|  | 	m17 => '90', | ||||||
|  | 	m18 => '135', | ||||||
|  | 	m19 => '180', | ||||||
|  | 	m20 => '270', | ||||||
|  | 	m21 => '360', | ||||||
|  | 	m22 => '405', | ||||||
|  | 	m23 => '450', | ||||||
|     } |     } | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| @@ -165,6 +181,7 @@ sub cd11_txrate { | |||||||
| 	elsif ( $rate =~ /^m/ ) { | 	elsif ( $rate =~ /^m/ ) { | ||||||
| 	    my $band = $protos->{$idx}; | 	    my $band = $protos->{$idx}; | ||||||
| 	    my $bw   = $bws->{$band}; | 	    my $bw   = $bws->{$band}; | ||||||
|  | 	    # FIXME throw some kind of error if we get an index/rate that we haven't implemented yet? Now we simply return "0.0"... | ||||||
| 	    $cd11_txrate->{$idx} = [ $mcs_index->{$bw}->{$rate} || '0.0' ]; | 	    $cd11_txrate->{$idx} = [ $mcs_index->{$bw}->{$rate} || '0.0' ]; | ||||||
| 	} | 	} | ||||||
| 	else { | 	else { | ||||||
| @@ -49,7 +49,7 @@ use SNMP::Info::IEEE802dot11; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %GLOBALS = ( | %GLOBALS = ( | ||||||
|     %SNMP::Info::IEEE802dot11::GLOBALS, |     %SNMP::Info::IEEE802dot11::GLOBALS, | ||||||
| @@ -40,7 +40,7 @@ use SNMP::Info::Layer1; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %GLOBALS = ( %SNMP::Info::Layer2::GLOBALS ); | %GLOBALS = ( %SNMP::Info::Layer2::GLOBALS ); | ||||||
| 
 | 
 | ||||||
| @@ -46,7 +46,7 @@ use SNMP::Info::Layer3; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
|     %SNMP::Info::Layer3::MIBS,    %SNMP::Info::LLDP::MIBS, |     %SNMP::Info::Layer3::MIBS,    %SNMP::Info::LLDP::MIBS, | ||||||
| @@ -229,7 +229,7 @@ sub index_factor { | |||||||
|         if ( ( $model =~ /(470)/ ) |         if ( ( $model =~ /(470)/ ) | ||||||
|         or ( $os =~ m/(boss|bes)/ ) and ( $op_mode eq 'pure' ) ); |         or ( $os =~ m/(boss|bes)/ ) and ( $op_mode eq 'pure' ) ); | ||||||
|     $index_factor = 128 |     $index_factor = 128 | ||||||
|         if ( ( $model =~ /(5[56]\d\d)|VSP/ ) |         if ( ( $model =~ /(5[56]\d\d)|VSP|4950|59100/ ) | ||||||
|         and ( $os_ver >= 6 ) ); |         and ( $os_ver >= 6 ) ); | ||||||
| 
 | 
 | ||||||
|     return $index_factor; |     return $index_factor; | ||||||
| @@ -48,7 +48,7 @@ use SNMP::Info::Layer2; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %GLOBALS = ( | %GLOBALS = ( | ||||||
|     %SNMP::Info::Layer2::GLOBALS, |     %SNMP::Info::Layer2::GLOBALS, | ||||||
| @@ -41,7 +41,7 @@ use SNMP::Info::Layer2::Cisco; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %GLOBALS = ( | %GLOBALS = ( | ||||||
|     %SNMP::Info::Layer2::Cisco::GLOBALS, |     %SNMP::Info::Layer2::Cisco::GLOBALS, | ||||||
| @@ -42,7 +42,7 @@ use SNMP::Info::Layer2::Cisco; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %MUNGE/; | use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
|     %SNMP::Info::Layer2::Cisco::MIBS, |     %SNMP::Info::Layer2::Cisco::MIBS, | ||||||
| @@ -43,7 +43,7 @@ use SNMP::Info::SONMP; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
|     %SNMP::Info::MIBS, |     %SNMP::Info::MIBS, | ||||||
| @@ -52,7 +52,7 @@ use SNMP::Info::Layer2; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %MUNGE/; | use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
|     %SNMP::Info::Layer2::MIBS, |     %SNMP::Info::Layer2::MIBS, | ||||||
| @@ -50,7 +50,7 @@ use SNMP::Info::CDP; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %GLOBALS = ( | %GLOBALS = ( | ||||||
|     %SNMP::Info::Layer2::GLOBALS, |     %SNMP::Info::Layer2::GLOBALS, | ||||||
| @@ -121,7 +121,7 @@ sub os_ver { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|    | 
 | ||||||
| # Grab e_model from Entity and tag on e_hwver | # Grab e_model from Entity and tag on e_hwver | ||||||
| sub model { | sub model { | ||||||
|     my $ciscosb = shift; |     my $ciscosb = shift; | ||||||
| @@ -130,8 +130,9 @@ sub model { | |||||||
| 
 | 
 | ||||||
|     foreach my $e ( sort keys %$e_model ) { |     foreach my $e ( sort keys %$e_model ) { | ||||||
|         if (defined $e_model->{$e} and $e_model->{$e} !~ /^\s*$/) { |         if (defined $e_model->{$e} and $e_model->{$e} !~ /^\s*$/) { | ||||||
|             my $model = "$e_model->{$e} $e_hwver->{$e}"; |             return $e_model->{$e}; | ||||||
|             return $model; |             #my $model = "$e_model->{$e} $e_hwver->{$e}"; | ||||||
|  |             #return $model; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     return $ciscosb->description(); |     return $ciscosb->description(); | ||||||
| @@ -162,14 +163,14 @@ Nic Bernstein (shamelessly stolen from Max Baker's Aironet code) | |||||||
| 
 | 
 | ||||||
| =head1 SYNOPSIS | =head1 SYNOPSIS | ||||||
| 
 | 
 | ||||||
|  # Let SNMP::Info determine the correct subclass for you.  |  # Let SNMP::Info determine the correct subclass for you. | ||||||
|  my $ciscosb = new SNMP::Info( |  my $ciscosb = new SNMP::Info( | ||||||
|                           AutoSpecify => 1, |                           AutoSpecify => 1, | ||||||
|                           Debug       => 1, |                           Debug       => 1, | ||||||
|                           DestHost    => 'myswitch', |                           DestHost    => 'myswitch', | ||||||
|                           Community   => 'public', |                           Community   => 'public', | ||||||
|                           Version     => 2 |                           Version     => 2 | ||||||
|                         )  |                         ) | ||||||
|     or die "Can't connect to DestHost.\n"; |     or die "Can't connect to DestHost.\n"; | ||||||
| 
 | 
 | ||||||
|  my $class      = $ciscosb->class(); |  my $class      = $ciscosb->class(); | ||||||
| @@ -216,6 +217,10 @@ These are methods that return scalar value from SNMP | |||||||
| 
 | 
 | ||||||
| Returns 'cisco' | Returns 'cisco' | ||||||
| 
 | 
 | ||||||
|  | =item $ciscosb->os() | ||||||
|  | 
 | ||||||
|  | Returns 'ros' | ||||||
|  | 
 | ||||||
| =item $ciscosb->os_ver() | =item $ciscosb->os_ver() | ||||||
| 
 | 
 | ||||||
| Returns software version (C<entPhysicalSoftwareRev>) | Returns software version (C<entPhysicalSoftwareRev>) | ||||||
| @@ -37,7 +37,7 @@ use Exporter; | |||||||
| use SNMP::Info::Layer3; | use SNMP::Info::Layer3; | ||||||
| use SNMP::Info::MAU; | use SNMP::Info::MAU; | ||||||
| use SNMP::Info::CDP; | use SNMP::Info::CDP; | ||||||
| use SNMP::Info::Aggregate; | use SNMP::Info::Aggregate 'agg_ports_ifstack'; | ||||||
| 
 | 
 | ||||||
| @SNMP::Info::Layer2::HP::ISA = qw/ | @SNMP::Info::Layer2::HP::ISA = qw/ | ||||||
|     SNMP::Info::Aggregate |     SNMP::Info::Aggregate | ||||||
| @@ -50,7 +50,7 @@ use SNMP::Info::Aggregate; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %PORTSTAT %MODEL_MAP %MUNGE/; | use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %PORTSTAT %MODEL_MAP %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
|     %SNMP::Info::Layer3::MIBS, |     %SNMP::Info::Layer3::MIBS, | ||||||
| @@ -215,6 +215,7 @@ $VERSION = '3.31'; | |||||||
|     'J9085A' => '2610-24', |     'J9085A' => '2610-24', | ||||||
|     'J8762A' => '2600-8-PWR', |     'J8762A' => '2600-8-PWR', | ||||||
|     'J9780A' => '2530-8-PoE+', |     'J9780A' => '2530-8-PoE+', | ||||||
|  |     'J9774A' => '2530-8G-PoEP', | ||||||
|     'J9777A' => '2530-8G', |     'J9777A' => '2530-8G', | ||||||
|     'J9783A' => '2530-8', |     'J9783A' => '2530-8', | ||||||
|     'J9778A' => '2530-48-PoE+', |     'J9778A' => '2530-48-PoE+', | ||||||
| @@ -44,7 +44,7 @@ use SNMP::Info::CDP; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %PORTSTAT %MODEL_MAP %MUNGE/; | use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %PORTSTAT %MODEL_MAP %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
|     %SNMP::Info::Layer3::MIBS, |     %SNMP::Info::Layer3::MIBS, | ||||||
| @@ -41,7 +41,7 @@ use SNMP::Info::LLDP; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %MUNGE/; | use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
|     %SNMP::Info::Layer2::MIBS, |     %SNMP::Info::Layer2::MIBS, | ||||||
| @@ -36,7 +36,7 @@ use SNMP::Info::Layer2; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE $AUTOLOAD/; | use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE $AUTOLOAD/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
|     %SNMP::Info::Layer2::MIBS, |     %SNMP::Info::Layer2::MIBS, | ||||||
| @@ -43,7 +43,7 @@ use SNMP::Info::Airespace; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE $AUTOLOAD $INIT $DEBUG/; | use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE $AUTOLOAD $INIT $DEBUG/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
|     %SNMP::Info::MIBS,        %SNMP::Info::Bridge::MIBS, |     %SNMP::Info::MIBS,        %SNMP::Info::Bridge::MIBS, | ||||||
| @@ -42,7 +42,7 @@ use SNMP::Info::Layer2; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
|     %SNMP::Info::Layer2::MIBS, %SNMP::Info::IEEE802dot11::MIBS, |     %SNMP::Info::Layer2::MIBS, %SNMP::Info::IEEE802dot11::MIBS, | ||||||
| @@ -39,7 +39,7 @@ use SNMP::Info::Bridge; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
|     %SNMP::Info::MIBS, |     %SNMP::Info::MIBS, | ||||||
| @@ -40,7 +40,7 @@ use SNMP::Info::LLDP; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %MUNGE/; | use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| # This will be filled in with the device's index into the EntPhysicalEntry | # This will be filled in with the device's index into the EntPhysicalEntry | ||||||
| # table by the serial() function. | # table by the serial() function. | ||||||
| @@ -89,7 +89,7 @@ sub serial { | |||||||
| 
 | 
 | ||||||
|     # Without Enitity-MIB, we've got to work our way through a bunch of |     # Without Enitity-MIB, we've got to work our way through a bunch of | ||||||
|     # different locales... |     # different locales... | ||||||
|     return $netgear->ng_gsmserial() if defined $netgear->model and $netgear->model =~ m/GSM\d/i;; |     return $netgear->ng_gsmserial() if defined $netgear->model and $netgear->model =~ m/[FG]SM\d/i;; | ||||||
|     return 'none'; |     return 'none'; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @@ -139,7 +139,7 @@ sub interfaces { | |||||||
|     return $interfaces; |     return $interfaces; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| # these seem to work for GSM models but not GS | # these seem to work for GSM/FSM models but not GS | ||||||
| # https://sourceforge.net/tracker/?func=detail&aid=3085413&group_id=70362&atid=527529 | # https://sourceforge.net/tracker/?func=detail&aid=3085413&group_id=70362&atid=527529 | ||||||
| sub os_ver { | sub os_ver { | ||||||
|     my $netgear = shift; |     my $netgear = shift; | ||||||
| @@ -148,7 +148,7 @@ sub os_ver { | |||||||
|         my $os_ver  = $netgear->e_swver(); |         my $os_ver  = $netgear->e_swver(); | ||||||
|         return $os_ver->{$index} if defined $os_ver; |         return $os_ver->{$index} if defined $os_ver; | ||||||
|     } |     } | ||||||
|     return $netgear->ng_gsmosver() if defined  $netgear->model and $netgear->model =~ m/GSM\d/i; |     return $netgear->ng_gsmosver() if defined  $netgear->model and $netgear->model =~ m/[FG]SM\d/i; | ||||||
|     return $netgear->ng_fsosver() if defined  $netgear->model and $netgear->model =~ m/FS\d/i; |     return $netgear->ng_fsosver() if defined  $netgear->model and $netgear->model =~ m/FS\d/i; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @@ -41,7 +41,7 @@ use SNMP::Info::Layer2; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
|     %SNMP::Info::Layer2::MIBS, |     %SNMP::Info::Layer2::MIBS, | ||||||
| @@ -40,7 +40,7 @@ use SNMP::Info::LLDP; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
|     %SNMP::Info::MIBS, |     %SNMP::Info::MIBS, | ||||||
							
								
								
									
										377
									
								
								lib/SNMP/Info/Layer2/Ubiquiti.pm
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										377
									
								
								lib/SNMP/Info/Layer2/Ubiquiti.pm
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,377 @@ | |||||||
|  | # SNMP::Info::Layer2::Ubiquiti | ||||||
|  | # $Id$ | ||||||
|  | # | ||||||
|  |  | ||||||
|  | package SNMP::Info::Layer2::Ubiquiti; | ||||||
|  |  | ||||||
|  | use strict; | ||||||
|  | use Exporter; | ||||||
|  | use SNMP::Info::IEEE802dot11; | ||||||
|  | use SNMP::Info::Layer2; | ||||||
|  | use SNMP::Info::Layer3;  # only used in sub mac() | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | @SNMP::Info::Layer2::Ubiquiti::ISA | ||||||
|  |     = qw/SNMP::Info::IEEE802dot11 SNMP::Info::Layer2 Exporter/; | ||||||
|  | @SNMP::Info::Layer2::Ubiquiti::EXPORT_OK = qw//; | ||||||
|  |  | ||||||
|  | use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | ||||||
|  |  | ||||||
|  | $VERSION = '3.53'; | ||||||
|  |  | ||||||
|  | %MIBS = ( | ||||||
|  |     %SNMP::Info::Layer2::MIBS, | ||||||
|  |     %SNMP::Info::IEEE802dot11::MIBS, | ||||||
|  |  | ||||||
|  | ); | ||||||
|  |  | ||||||
|  | %GLOBALS | ||||||
|  |     = ( %SNMP::Info::Layer2::GLOBALS, %SNMP::Info::IEEE802dot11::GLOBALS, ); | ||||||
|  |  | ||||||
|  | %FUNCS = ( | ||||||
|  |     %SNMP::Info::Layer2::FUNCS, | ||||||
|  |     %SNMP::Info::IEEE802dot11::FUNCS, | ||||||
|  |  | ||||||
|  | ); | ||||||
|  |  | ||||||
|  | %MUNGE = ( %SNMP::Info::Layer2::MUNGE, %SNMP::Info::IEEE802dot11::MUNGE, ); | ||||||
|  |  | ||||||
|  | sub os { | ||||||
|  |     my $ubnt = shift; | ||||||
|  |  | ||||||
|  |     my $names = $ubnt->dot11_prod_name(); | ||||||
|  |  | ||||||
|  |     foreach my $iid ( keys %$names ) { | ||||||
|  |         my $prod = $names->{$iid}; | ||||||
|  |         next unless defined $prod; | ||||||
|  |         # Product names that match AirOS products | ||||||
|  |                 if((lc $prod) =~ /station/ or (lc $prod) =~ /beam/ or (lc $prod) =~ /grid/){ | ||||||
|  |                         return 'AirOS'; | ||||||
|  |                 # Product names that match UAP | ||||||
|  |                 }elsif((lc $prod) =~ /uap/){ | ||||||
|  |                         return 'UniFi'; | ||||||
|  |                 }else{ | ||||||
|  |                     # Continue below to find OS name | ||||||
|  |                 } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     ## EdgeMAX OS (EdgeSwitch and EdgeRouter) name is first field split by space | ||||||
|  |     my $ver = $ubnt->description() || ''; | ||||||
|  |  | ||||||
|  |     my @myver = split(/ /, $ver); | ||||||
|  |  | ||||||
|  |     return $myver[0]; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | sub os_ver { | ||||||
|  |     my $dot11 = shift; | ||||||
|  |  | ||||||
|  |     my $versions = $dot11->dot11_prod_ver(); | ||||||
|  |  | ||||||
|  |     foreach my $iid ( keys %$versions ) { | ||||||
|  |         my $ver = $versions->{$iid}; | ||||||
|  |         next unless defined $ver; | ||||||
|  |         return $ver; | ||||||
|  |         ## Not sure what this function does, it seems to be extraneous being in the same code block after a return statement? | ||||||
|  |         if ( $ver =~ /([\d\.]+)/ ) { | ||||||
|  |             return $1; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |     my $ver = $dot11->description() || ''; | ||||||
|  |     if($ver =~ /^edgeswitch/){ | ||||||
|  |         ## EdgeSwitch OS version is second field split by comma | ||||||
|  |         my @myver = split(/, /, $ver); | ||||||
|  |  | ||||||
|  |         return $myver[1]; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     ## EdgeRouter OS version is second field split by space | ||||||
|  |     my @myver = split(/ /, $ver); | ||||||
|  |  | ||||||
|  |     return $myver[1]; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | sub vendor { | ||||||
|  |     return 'Ubiquiti Networks, Inc.'; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | sub model { | ||||||
|  |     my $ubnt = shift; | ||||||
|  |  | ||||||
|  |     my $names = $ubnt->dot11_prod_name(); | ||||||
|  |  | ||||||
|  |     foreach my $iid ( keys %$names ) { | ||||||
|  |         my $prod = $names->{$iid}; | ||||||
|  |         next unless defined $prod; | ||||||
|  |         return $prod; | ||||||
|  |     } | ||||||
|  |      | ||||||
|  |     my $desc = $ubnt->description() || ''; | ||||||
|  |      | ||||||
|  |     ## Pull Model from beginning of description, separated by comma (EdgeSwitch) | ||||||
|  |     if((lc $desc) =~ /^edgeswitch/){     | ||||||
|  |         my @mydesc = split(/, /, $desc); | ||||||
|  |         return $mydesc[0]; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if(!((lc $desc) =~ /edgeos/)){ | ||||||
|  |         # Not sure what type of device this is to get Model | ||||||
|  |         # Wireless devices report dot11_prod_name | ||||||
|  |         # EdgeSwitch includes mode directly and edgeos logic is in else statement | ||||||
|  |         return ; | ||||||
|  |     }else{ | ||||||
|  |         ## do some logic to determine ER model based on tech specs from ubnt: | ||||||
|  |         ## https://help.ubnt.com/hc/en-us/articles/219652227--EdgeRouter-Which-EdgeRouter-Should-I-Use-#tech%20specs | ||||||
|  |         ## Would be nice if UBNT simply adds the model string to their SNMP daemon directly | ||||||
|  |         my $ethCount = 0; | ||||||
|  |         my $switchCount = 0; | ||||||
|  |         #my $sfpCount = 0; | ||||||
|  |         #my $poeCount = 0;   | ||||||
|  |         my $memTotalReal = $ubnt->memTotalReal;    | ||||||
|  |         my $cpuLoad = $ubnt->hrProcessorLoad; | ||||||
|  |         my $cpuCount = 0; | ||||||
|  |         ## My perl is lacking. Not sure if there's a more efficient way to find the cpu count | ||||||
|  |         foreach my $iid ( keys %$cpuLoad ) { | ||||||
|  |             $cpuCount++; | ||||||
|  |         } | ||||||
|  |          | ||||||
|  |         my $ifDescs = $ubnt->ifDescr; | ||||||
|  |         foreach my $iid ( keys %$ifDescs ) { | ||||||
|  |             my $ifDesc = $ifDescs->{$iid}; | ||||||
|  |             next unless defined $ifDesc; | ||||||
|  |  | ||||||
|  |             if((lc $ifDesc) =~ /^eth\d+$/){ # exclude vlan interfaces. Ex: eth1.5 | ||||||
|  |                 $ethCount++; | ||||||
|  |             }elsif((lc $ifDesc) =~ /^switch/){ | ||||||
|  |                 $switchCount++; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         ## If people have other models to further fine-tune this logic that would be great.  | ||||||
|  |         if($ethCount eq 9){ | ||||||
|  |             ## Should be ER Infinity | ||||||
|  |             return "EdgeRouter Infinity" | ||||||
|  |         }if($ethCount eq 8){ | ||||||
|  |             ## Could be ER-8 Pro, ER-8, or EP-R8 | ||||||
|  |             return "EdgeRouter 8-Port" | ||||||
|  |         }elsif($ethCount eq 5 and $cpuCount eq 4){ | ||||||
|  |             ## Could be ER-X or ER-X-SFP | ||||||
|  |             return "EdgeRouter X 5-Port" | ||||||
|  |         }elsif($ethCount eq 5){ | ||||||
|  |             return "EdgeRouter PoE 5-Port" | ||||||
|  |         }elsif($ethCount eq 3 and $cpuCount eq 2){ | ||||||
|  |             return "EdgeRouter LITE 3-Port" | ||||||
|  |         }else{ | ||||||
|  |             ## failback string | ||||||
|  |             return "EdgeRouter eth-$ethCount switch-$switchCount mem-$memTotalReal cpuNum-$cpuCount"; | ||||||
|  |         } | ||||||
|  |          | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | ## simply take the MAC and clean it up | ||||||
|  | sub serial { | ||||||
|  |     my $ubnt = shift; | ||||||
|  |  | ||||||
|  |     my $serial = $ubnt->mac(); | ||||||
|  |     if($serial){ | ||||||
|  |         $serial =~ s/://g; | ||||||
|  |         return uc $serial; | ||||||
|  |     } | ||||||
|  |     return ; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | ## UBNT doesn't put the primary-mac interface at index 1 | ||||||
|  | sub mac { | ||||||
|  |     my $ubnt = shift; | ||||||
|  |     my $ifDescs = $ubnt->ifDescr; | ||||||
|  |  | ||||||
|  |     foreach my $iid ( keys %$ifDescs ) { | ||||||
|  |         my $ifDesc = $ifDescs->{$iid}; | ||||||
|  |         next unless defined $ifDesc; | ||||||
|  |         ## CPU Interface will have the primary MAC for EdgeSwitch | ||||||
|  |         ## eth0 will have primary MAC for linux-based UBNT devices | ||||||
|  |         if($ifDesc =~ /CPU/ or $ifDesc eq 'eth0'){ | ||||||
|  |             my $mac = $ubnt->ifPhysAddress->{$iid}; | ||||||
|  |  | ||||||
|  |             # syntax stolen from sub munge_mac in SNMP::Info | ||||||
|  |             $mac = lc join( ':', map { sprintf "%02x", $_ } unpack( 'C*', $mac ) ); | ||||||
|  |             return $mac if $mac =~ /^([0-9A-F][0-9A-F]:){5}[0-9A-F][0-9A-F]$/i;   | ||||||
|  |              | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |      | ||||||
|  |     # MAC malformed or missing | ||||||
|  |     return; | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  | ||||||
|  | sub interfaces { | ||||||
|  |     my $netgear = shift; | ||||||
|  |     my $partial = shift; | ||||||
|  |  | ||||||
|  |     my $interfaces = $netgear->i_index($partial)       || {}; | ||||||
|  |     my $i_descr    = $netgear->i_description($partial) || {}; | ||||||
|  |     my $return = {}; | ||||||
|  |  | ||||||
|  |     foreach my $iid ( keys %$i_descr ) { | ||||||
|  |         # Slot: 0 Port: 4 Gigabit - Level | ||||||
|  |         if ($i_descr->{$iid} =~ m/([0-9]+)[^0-9]+([0-9]+)/) { | ||||||
|  |             $return->{$iid} = $1 .'/'. $2; | ||||||
|  |             next; | ||||||
|  |         } | ||||||
|  |         # Link Aggregate 4 | ||||||
|  |         if ($i_descr->{$iid} =~ m/Link Aggregate (\d+)/) { | ||||||
|  |             $return->{$iid} = '3/'. $1; | ||||||
|  |             next; | ||||||
|  |         } | ||||||
|  |         # else | ||||||
|  |         $return->{$iid} = $i_descr->{$iid}; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     return $return; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | sub i_ignore { | ||||||
|  |     my $l2      = shift; | ||||||
|  |     my $partial = shift; | ||||||
|  |  | ||||||
|  |     my $interfaces = $l2->interfaces($partial) || {}; | ||||||
|  |     my $i_descr    = $l2->i_description($partial) || {}; | ||||||
|  |  | ||||||
|  |     my %i_ignore; | ||||||
|  |     foreach my $if ( keys %$interfaces ) { | ||||||
|  |  | ||||||
|  |         # CPU Interface | ||||||
|  |         if ( $i_descr->{$if} =~ /CPU Interface/i ) { | ||||||
|  |             $i_ignore{$if}++; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |     return \%i_ignore; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | 1; | ||||||
|  | __END__ | ||||||
|  |  | ||||||
|  | =head1 NAME | ||||||
|  |  | ||||||
|  | SNMP::Info::Layer2::Ubiquiti - SNMP Interface to Ubiquiti Access Points | ||||||
|  |  | ||||||
|  | =head1 AUTHOR | ||||||
|  |  | ||||||
|  | Max Kosmach | ||||||
|  |  | ||||||
|  | =head1 SYNOPSIS | ||||||
|  |  | ||||||
|  |  # Let SNMP::Info determine the correct subclass for you.  | ||||||
|  |  my $ubnt = new SNMP::Info( | ||||||
|  |                           AutoSpecify => 1, | ||||||
|  |                           Debug       => 1, | ||||||
|  |                           DestHost    => 'myswitch', | ||||||
|  |                           Community   => 'public', | ||||||
|  |                           Version     => 2 | ||||||
|  |                         )  | ||||||
|  |     or die "Can't connect to DestHost.\n"; | ||||||
|  |  | ||||||
|  |  my $class = $ubnt->class(); | ||||||
|  |  print "SNMP::Info determined this device to fall under subclass : $class\n"; | ||||||
|  |  | ||||||
|  | =head1 DESCRIPTION | ||||||
|  |  | ||||||
|  | Provides abstraction to the configuration information obtainable from | ||||||
|  | Ubiquiti Access Point through SNMP. | ||||||
|  |  | ||||||
|  | For speed or debugging purposes you can call the subclass directly, but not | ||||||
|  | after determining a more specific class using the method above.  | ||||||
|  |  | ||||||
|  |  my $ubnt = new SNMP::Info::Layer2::Ubiquiti(...); | ||||||
|  |  | ||||||
|  | =head2 Inherited Classes | ||||||
|  |  | ||||||
|  | =over | ||||||
|  |  | ||||||
|  | =item SNMP::Info::Layer2 | ||||||
|  |  | ||||||
|  | =item SNMP::Info::IEEE802dot11 | ||||||
|  |  | ||||||
|  | =back | ||||||
|  |  | ||||||
|  | =head2 Required MIBs | ||||||
|  |  | ||||||
|  | None. | ||||||
|  |  | ||||||
|  | =head2 Inherited MIBs | ||||||
|  |  | ||||||
|  | See L<SNMP::Info::Layer2/"Required MIBs"> for its MIB requirements. | ||||||
|  |  | ||||||
|  | See L<SNMP::Info::IEEE802dot11/"Required MIBs"> for its MIB requirements. | ||||||
|  |  | ||||||
|  | =head1 GLOBALS | ||||||
|  |  | ||||||
|  | These are methods that return scalar value from SNMP | ||||||
|  |  | ||||||
|  | =over | ||||||
|  |  | ||||||
|  | =item $ubnt->vendor() | ||||||
|  |  | ||||||
|  | Returns 'Ubiquiti Networks, Inc.' | ||||||
|  |  | ||||||
|  | =item $ubnt->model() | ||||||
|  |  | ||||||
|  | Returns the model extracted from C<dot11manufacturerProductName>, with failback to some complex logic for EdgeMax devices | ||||||
|  |  | ||||||
|  | =item $ubnt->serial() | ||||||
|  |  | ||||||
|  | Serial Number. | ||||||
|  |  | ||||||
|  | =item $ubnt->mac() | ||||||
|  |  | ||||||
|  | Bridge MAC address. | ||||||
|  |  | ||||||
|  | =item $ubnt->os() | ||||||
|  |  | ||||||
|  | Returns 'Ubiquiti Networks, Inc.' | ||||||
|  |  | ||||||
|  | =item $ubnt->os_ver() | ||||||
|  |  | ||||||
|  | Returns the software version extracted from C<dot11manufacturerProductVersion>, with failback to description splitting for EdgeMax devices | ||||||
|  |  | ||||||
|  | =back | ||||||
|  |  | ||||||
|  | =head2 Global Methods imported from SNMP::Info::Layer2 | ||||||
|  |  | ||||||
|  | See L<SNMP::Info::Layer2/"GLOBALS"> for details. | ||||||
|  |  | ||||||
|  | =head2 Global Methods imported from SNMP::Info::IEEE802dot11 | ||||||
|  |  | ||||||
|  | See L<SNMP::Info::IEEE802dot11/"GLOBALS"> for details. | ||||||
|  |  | ||||||
|  | =head1 TABLE METHODS | ||||||
|  |  | ||||||
|  | These are methods that return tables of information in the form of a reference | ||||||
|  | to a hash. | ||||||
|  |  | ||||||
|  | =head2 Overrides | ||||||
|  |  | ||||||
|  | =over | ||||||
|  |  | ||||||
|  | =item $ubiquiti->interfaces() | ||||||
|  |  | ||||||
|  | Uses the i_name() field. | ||||||
|  |  | ||||||
|  | =item $ubiquiti->i_ignore() | ||||||
|  |  | ||||||
|  | Ignores interfaces with "CPU Interface" in them. | ||||||
|  |  | ||||||
|  | =back | ||||||
|  |  | ||||||
|  | =head2 Table Methods imported from SNMP::Info::Layer2 | ||||||
|  |  | ||||||
|  | See L<SNMP::Info::Layer2/"TABLE METHODS"> for details. | ||||||
|  |  | ||||||
|  | =head2 Table Methods imported from SNMP::Info::IEEE802dot11 | ||||||
|  |  | ||||||
|  | See L<SNMP::Info::IEEE802dot11/"TABLE METHODS"> for details. | ||||||
|  |  | ||||||
|  | =cut | ||||||
| @@ -39,7 +39,7 @@ use SNMP::Info::Layer2; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| # Set for No CDP | # Set for No CDP | ||||||
| %GLOBALS = ( %SNMP::Info::Layer2::GLOBALS ); | %GLOBALS = ( %SNMP::Info::Layer2::GLOBALS ); | ||||||
| @@ -53,7 +53,7 @@ use SNMP::Info::LLDP; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %GLOBALS %FUNCS %MIBS %MUNGE/; | use vars qw/$VERSION %GLOBALS %FUNCS %MIBS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
|     %SNMP::Info::MIBS, |     %SNMP::Info::MIBS, | ||||||
| @@ -196,12 +196,15 @@ sub serial { | |||||||
| 
 | 
 | ||||||
|     my $serial1 = $l3->serial1(); |     my $serial1 = $l3->serial1(); | ||||||
|     my $e_parent = $l3->e_parent() || {}; |     my $e_parent = $l3->e_parent() || {}; | ||||||
|  |     my $e_class  = $l3->e_class() || {}; | ||||||
| 
 | 
 | ||||||
|     foreach my $iid ( keys %$e_parent ) { |     foreach my $iid ( keys %$e_parent ) { | ||||||
|         my $parent = $e_parent->{$iid}; |         my $parent = $e_parent->{$iid}; | ||||||
|         if ( $parent eq '0' ) { |         my $class = $e_class->{$iid} || ''; | ||||||
|  |         # Only consider serial numbers for entries without a parent, or if they are of type "chassis" | ||||||
|  |         if ( $parent eq '0' or $class eq 'chassis') { | ||||||
|             my $serial = $l3->e_serial($iid); |             my $serial = $l3->e_serial($iid); | ||||||
|             if ( $serial ) { |             if ( $serial && $serial->{$iid} ) { | ||||||
|                 return $serial->{$iid}; |                 return $serial->{$iid}; | ||||||
|             } |             } | ||||||
|             else { |             else { | ||||||
| @@ -41,7 +41,7 @@ use SNMP::Info::Layer3; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %MIBS %FUNCS %GLOBALS %MUNGE/; | use vars qw/$VERSION %MIBS %FUNCS %GLOBALS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
|     %SNMP::Info::Layer3::MIBS, |     %SNMP::Info::Layer3::MIBS, | ||||||
| @@ -49,7 +49,7 @@ use SNMP::Info::LLDP; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %MUNGE/; | use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
|     %SNMP::Info::Layer3::MIBS, |     %SNMP::Info::Layer3::MIBS, | ||||||
| @@ -39,7 +39,7 @@ use SNMP::Info::Layer3; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %GLOBALS %FUNCS %MIBS %MUNGE/; | use vars qw/$VERSION %GLOBALS %FUNCS %MIBS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
|     %SNMP::Info::Layer3::MIBS, |     %SNMP::Info::Layer3::MIBS, | ||||||
| @@ -40,7 +40,7 @@ use SNMP::Info::Layer3; | |||||||
| use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %MUNGE  | use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %MUNGE  | ||||||
|             $int_include_vpn $fake_idx $type_class/; |             $int_include_vpn $fake_idx $type_class/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
|             %SNMP::Info::Layer3::MIBS, |             %SNMP::Info::Layer3::MIBS, | ||||||
| @@ -36,7 +36,7 @@ use Exporter; | |||||||
| use SNMP::Info::Layer3; | use SNMP::Info::Layer3; | ||||||
| use SNMP::Info::MAU; | use SNMP::Info::MAU; | ||||||
| use SNMP::Info::LLDP; | use SNMP::Info::LLDP; | ||||||
| use SNMP::Info::Aggregate; | use SNMP::Info::Aggregate 'agg_ports_ifstack'; | ||||||
| 
 | 
 | ||||||
| @SNMP::Info::Layer3::Arista::ISA = qw/ | @SNMP::Info::Layer3::Arista::ISA = qw/ | ||||||
|     SNMP::Info::Aggregate |     SNMP::Info::Aggregate | ||||||
| @@ -48,7 +48,7 @@ use SNMP::Info::Aggregate; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %MUNGE/; | use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
|     %SNMP::Info::Layer3::MIBS, |     %SNMP::Info::Layer3::MIBS, | ||||||
| @@ -40,7 +40,7 @@ use SNMP::Info::LLDP; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | use vars qw/$VERSION %FUNCS %GLOBALS %MIBS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
|     %SNMP::Info::Layer3::MIBS, |     %SNMP::Info::Layer3::MIBS, | ||||||
| @@ -43,7 +43,7 @@ use SNMP::Info::Bridge; | |||||||
| use vars qw/$VERSION %GLOBALS %FUNCS %MIBS %MUNGE %MODEL_MAP | use vars qw/$VERSION %GLOBALS %FUNCS %MIBS %MUNGE %MODEL_MAP | ||||||
|     %MODID_MAP %PROCID_MAP/; |     %MODID_MAP %PROCID_MAP/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
|     %SNMP::Info::MIBS, |     %SNMP::Info::MIBS, | ||||||
| @@ -36,7 +36,7 @@ use SNMP::Info::Layer3; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %MUNGE/; | use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
|     %SNMP::Info::Layer2::MIBS, %SNMP::Info::Layer3::MIBS, |     %SNMP::Info::Layer2::MIBS, %SNMP::Info::Layer3::MIBS, | ||||||
| @@ -47,7 +47,7 @@ use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %MUNGE/; | |||||||
| 
 | 
 | ||||||
| @SNMP::Info::Layer3::C3550::EXPORT_OK = qw//; | @SNMP::Info::Layer3::C3550::EXPORT_OK = qw//; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| # NOTE: Order creates precedence | # NOTE: Order creates precedence | ||||||
| #       Example: v_name exists in Bridge.pm and CiscoVTP.pm | #       Example: v_name exists in Bridge.pm and CiscoVTP.pm | ||||||
| @@ -44,7 +44,7 @@ use SNMP::Info::MAU; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %MUNGE/; | use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
|     %SNMP::Info::MAU::MIBS, |     %SNMP::Info::MAU::MIBS, | ||||||
| @@ -51,7 +51,7 @@ use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %MUNGE/; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %MUNGE/; | use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| # NOTE: Order creates precedence | # NOTE: Order creates precedence | ||||||
| #       Example: v_name exists in Bridge.pm and CiscoVTP.pm | #       Example: v_name exists in Bridge.pm and CiscoVTP.pm | ||||||
							
								
								
									
										330
									
								
								lib/SNMP/Info/Layer3/CheckPoint.pm
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										330
									
								
								lib/SNMP/Info/Layer3/CheckPoint.pm
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,330 @@ | |||||||
|  | # SNMP::Info::Layer3::CheckPoint | ||||||
|  | # $Id$ | ||||||
|  | # | ||||||
|  | # Copyright (c) 2008 Bill Fenner | ||||||
|  | # 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::CheckPoint; | ||||||
|  |  | ||||||
|  | use strict; | ||||||
|  | use Exporter; | ||||||
|  | use SNMP::Info::Layer3; | ||||||
|  | use SNMP::Info::LLDP; | ||||||
|  |  | ||||||
|  | @SNMP::Info::Layer3::CheckPoint::ISA       = qw/SNMP::Info::LLDP SNMP::Info::Layer3 Exporter/; | ||||||
|  | @SNMP::Info::Layer3::CheckPoint::EXPORT_OK = qw//; | ||||||
|  |  | ||||||
|  | use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %MUNGE/; | ||||||
|  |  | ||||||
|  | $VERSION = '3.53'; | ||||||
|  |  | ||||||
|  | %MIBS = ( | ||||||
|  |     %SNMP::Info::Layer3::MIBS, | ||||||
|  |     %SNMP::Info::LLDP::MIBS, | ||||||
|  |     'CHECKPOINT-MIB'      => 'fwProduct', | ||||||
|  |     'UCD-SNMP-MIB'        => 'versionTag', | ||||||
|  |     'NET-SNMP-TC'         => 'netSnmpAgentOIDs', | ||||||
|  |     'NET-SNMP-EXTEND-MIB' => 'nsExtendNumEntries', | ||||||
|  |     'HOST-RESOURCES-MIB'  => 'hrSystem', | ||||||
|  | ); | ||||||
|  |  | ||||||
|  | %GLOBALS = ( | ||||||
|  |     %SNMP::Info::Layer3::GLOBALS, | ||||||
|  |     %SNMP::Info::LLDP::GLOBALS, | ||||||
|  |     'netsnmp_vers'   => 'versionTag', | ||||||
|  |     'hrSystemUptime' => 'hrSystemUptime', | ||||||
|  |      | ||||||
|  | ); | ||||||
|  |  | ||||||
|  | %FUNCS = ( | ||||||
|  |     %SNMP::Info::Layer3::FUNCS, | ||||||
|  |     %SNMP::Info::LLDP::FUNCS, | ||||||
|  |  | ||||||
|  |     # Net-SNMP Extend table that could but customize to add a the CheckPoint version | ||||||
|  |     'extend_output_table' => 'nsExtendOutputFull', | ||||||
|  | ); | ||||||
|  |  | ||||||
|  | %MUNGE = ( | ||||||
|  |     %SNMP::Info::Layer3::MUNGE, | ||||||
|  |     %SNMP::Info::LLDP::MUNGE, | ||||||
|  | ); | ||||||
|  |  | ||||||
|  | sub vendor { | ||||||
|  |     return 'checkpoint'; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | sub model { | ||||||
|  |     my $ckp = shift; | ||||||
|  |     my $id = $ckp->id; | ||||||
|  |  | ||||||
|  |     my $model = &SNMP::translateObj($id); | ||||||
|  |  | ||||||
|  |     if (defined $model) { | ||||||
|  |         $model =~ s/^checkPoint//; | ||||||
|  |         return $model; | ||||||
|  |     } else { | ||||||
|  |         return $id; | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | sub os { | ||||||
|  |     return 'checkpoint'; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | sub os_ver { | ||||||
|  |     my $ckp = shift; | ||||||
|  |     my $extend_table = $ckp->extend_output_table() || {}; | ||||||
|  |  | ||||||
|  |     my $descr   = $ckp->description(); | ||||||
|  |     my $vers    = $ckp->netsnmp_vers(); | ||||||
|  |     my $os_ver  = undef; | ||||||
|  |  | ||||||
|  |     foreach my $ex (keys %$extend_table) { | ||||||
|  |         (my $name = pack('C*',split(/\./,$ex))) =~ s/[^[:print:]]//g; | ||||||
|  |         if ($name eq 'ckpVersion') { | ||||||
|  |             return $1 if ($extend_table->{$ex} =~ /^This is Check Point's software version (.*)$/); | ||||||
|  |             last; | ||||||
|  |         } | ||||||
|  |     }  | ||||||
|  |  | ||||||
|  |     $os_ver = $1 if ( $descr =~ /^\S+\s+\S+\s+(\S+)\s+/ ); | ||||||
|  |     if ($vers) { | ||||||
|  |         $os_ver = "???" unless defined($os_ver); | ||||||
|  |         $os_ver .= " / Net-SNMP " . $vers; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     return $os_ver; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | sub serial { | ||||||
|  |     my $ckp = shift; | ||||||
|  |     my $extend_table = $ckp->extend_output_table() || {}; | ||||||
|  |  | ||||||
|  |     foreach my $ex (keys %$extend_table) { | ||||||
|  |         (my $name = pack('C*',split(/\./,$ex))) =~ s/[^[:print:]]//g; | ||||||
|  |         if ($name eq 'ckpAsset') { | ||||||
|  |             return $1 if ($extend_table->{$ex} =~ /Serial Number: (\S+)/); | ||||||
|  |             last; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     return ''; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | sub layers { | ||||||
|  |     return '01001100'; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | # sysUptime gives us the time since the SNMP daemon has restarted, | ||||||
|  | # so return the system uptime since that's probably what the user | ||||||
|  | # wants.  (Caution: this could cause trouble if using | ||||||
|  | # sysUptime-based discontinuity timers or other TimeStamp | ||||||
|  | # objects. | ||||||
|  | sub uptime { | ||||||
|  |     my $ckp = shift; | ||||||
|  |     my $uptime; | ||||||
|  |  | ||||||
|  |     $uptime = $ckp->hrSystemUptime(); | ||||||
|  |     return $uptime if defined $uptime; | ||||||
|  |  | ||||||
|  |     return $ckp->SUPER::uptime(); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | sub i_ignore { | ||||||
|  |     my $l3      = shift; | ||||||
|  |     my $partial = shift; | ||||||
|  |  | ||||||
|  |     my $interfaces = $l3->interfaces($partial) || {}; | ||||||
|  |  | ||||||
|  |     my %i_ignore; | ||||||
|  |     foreach my $if ( keys %$interfaces ) { | ||||||
|  |  | ||||||
|  |         # lo0 etc | ||||||
|  |         if ( $interfaces->{$if} =~ /\blo\d*\b/i ) { | ||||||
|  |             $i_ignore{$if}++; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |     return \%i_ignore; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | 1; | ||||||
|  | __END__ | ||||||
|  |  | ||||||
|  | =head1 NAME | ||||||
|  |  | ||||||
|  | SNMP::Info::Layer3::CheckPoint - SNMP Interface to CheckPoint Devices | ||||||
|  |  | ||||||
|  | =head1 AUTHORS | ||||||
|  |  | ||||||
|  | Ambroise Rosset | ||||||
|  |  | ||||||
|  | =head1 SYNOPSIS | ||||||
|  |  | ||||||
|  |  # Let SNMP::Info determine the correct subclass for you.  | ||||||
|  |  my $ckp = new SNMP::Info( | ||||||
|  |                           AutoSpecify => 1, | ||||||
|  |                           Debug       => 1, | ||||||
|  |                           DestHost    => 'myrouter', | ||||||
|  |                           Community   => 'public', | ||||||
|  |                           Version     => 2 | ||||||
|  |                         )  | ||||||
|  |     or die "Can't connect to DestHost.\n"; | ||||||
|  |  | ||||||
|  |  my $class      = $ckp->class(); | ||||||
|  |  print "SNMP::Info determined this device to fall under subclass : $class\n"; | ||||||
|  |  | ||||||
|  | =head1 DESCRIPTION | ||||||
|  |  | ||||||
|  | Subclass for Generic Net-SNMP devices | ||||||
|  |  | ||||||
|  | =head2 WARNING | ||||||
|  |  | ||||||
|  | To correctly and completelly work, you should add the following line in the file C</etc/snmp/snmpd.local.conf> on each of your CheckPoint devices: | ||||||
|  |  | ||||||
|  |  # Netdisco SNMP configuration | ||||||
|  |  extend  ckpVersion /opt/CPsuite-R77/fw1/bin/fw ver | ||||||
|  |  extend  ckpAsset /bin/clish -c 'show asset all' | ||||||
|  |  | ||||||
|  | =head2 Inherited Classes | ||||||
|  |  | ||||||
|  | =over | ||||||
|  |  | ||||||
|  | =item SNMP::Info::Layer3 | ||||||
|  |  | ||||||
|  | =back | ||||||
|  |  | ||||||
|  | =head2 Required MIBs | ||||||
|  |  | ||||||
|  | =over | ||||||
|  |  | ||||||
|  | =item F<UCD-SNMP-MIB> | ||||||
|  |  | ||||||
|  | =item F<NET-SNMP-TC> | ||||||
|  |  | ||||||
|  | =item F<HOST-RESOURCES-MIB> | ||||||
|  |  | ||||||
|  | =item Inherited Classes' MIBs | ||||||
|  |  | ||||||
|  | See L<SNMP::Info::Layer3> for its own MIB requirements. | ||||||
|  |  | ||||||
|  | See L<SNMP::Info::LLDP> for its own MIB requirements. | ||||||
|  |  | ||||||
|  | =back | ||||||
|  |  | ||||||
|  | =head1 GLOBALS | ||||||
|  |  | ||||||
|  | These are methods that return scalar value from SNMP | ||||||
|  |  | ||||||
|  | =over | ||||||
|  |  | ||||||
|  | =item $ckp->vendor() | ||||||
|  |  | ||||||
|  | Returns 'checkpoint'. | ||||||
|  |  | ||||||
|  | =item $ckp->model() | ||||||
|  |  | ||||||
|  | Return the model type of the CheckPoint device (Based on the sysObjectOID translation). | ||||||
|  |  | ||||||
|  | =item $ckp->os() | ||||||
|  |  | ||||||
|  | Returns the OS extracted from C<sysDescr>. | ||||||
|  |  | ||||||
|  | =item $ckp->os_ver() | ||||||
|  |  | ||||||
|  | Returns the software version extracted from C<sysDescr>, along | ||||||
|  | with the Net-SNMP version. | ||||||
|  |  | ||||||
|  | =item $ckp->uptime() | ||||||
|  |  | ||||||
|  | Returns the system uptime instead of the agent uptime. | ||||||
|  | NOTE: discontinuity timers and other Time Stamp based objects | ||||||
|  | are based on agent uptime, so use orig_uptime(). | ||||||
|  |  | ||||||
|  | =item $ckp->serial() | ||||||
|  |  | ||||||
|  | Return the serial number of the device if the SNMP server is configured as indicated previously. | ||||||
|  | Return '' in other case. | ||||||
|  |  | ||||||
|  | =item $ckp->layers() | ||||||
|  |  | ||||||
|  | Return '01001100'. | ||||||
|  |  | ||||||
|  | =back | ||||||
|  |  | ||||||
|  | =head2 Globals imported from SNMP::Info::Layer3 | ||||||
|  |  | ||||||
|  | See documentation in L<SNMP::Info::Layer3> for details. | ||||||
|  |  | ||||||
|  | =head2 Globals imported from SNMP::Info::LLDP | ||||||
|  |  | ||||||
|  | See documentation in L<SNMP::Info::LLDP> 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 $ckp->i_ignore() | ||||||
|  |  | ||||||
|  | Returns reference to hash.  Increments value of IID if port is to be ignored. | ||||||
|  |  | ||||||
|  | Ignores loopback | ||||||
|  |  | ||||||
|  | =back | ||||||
|  |  | ||||||
|  | =head2 Table Methods imported from SNMP::Info::Layer3 | ||||||
|  |  | ||||||
|  | See documentation in L<SNMP::Info::Layer3> for details. | ||||||
|  |  | ||||||
|  | =head2 Table Methods imported from SNMP::Info::LLDP | ||||||
|  |  | ||||||
|  | See documentation in L<SNMP::Info::LLDP> for details. | ||||||
|  |  | ||||||
|  | =head1 NOTES | ||||||
|  |  | ||||||
|  | In order to cause SNMP::Info to classify your device into this class, it | ||||||
|  | may be necessary to put a configuration line into your F<snmpd.conf> | ||||||
|  | similar to | ||||||
|  |  | ||||||
|  |   sysobjectid .1.3.6.1.4.1.8072.3.2.N | ||||||
|  |  | ||||||
|  | where N is the object ID for your OS from the C<NET-SNMP-TC> MIB (or | ||||||
|  | 255 if not listed).  Some Net-SNMP installations default to an | ||||||
|  | incorrect return value for C<system.sysObjectId>. | ||||||
|  |  | ||||||
|  | In order to recognize a Net-SNMP device as Layer3, it may be necessary | ||||||
|  | to put a configuration line similar to | ||||||
|  |  | ||||||
|  |   sysservices 76 | ||||||
|  |  | ||||||
|  | in your F<snmpd.conf>. | ||||||
|  |  | ||||||
|  | =cut | ||||||
| @@ -55,7 +55,7 @@ use SNMP::Info::Layer3; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %MUNGE/; | use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
|     %SNMP::Info::Layer3::MIBS, |     %SNMP::Info::Layer3::MIBS, | ||||||
| @@ -45,7 +45,7 @@ use SNMP::Info::Layer3; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %MUNGE/; | use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( %SNMP::Info::Layer3::MIBS, %SNMP::Info::CiscoStats::MIBS, ); | %MIBS = ( %SNMP::Info::Layer3::MIBS, %SNMP::Info::CiscoStats::MIBS, ); | ||||||
| 
 | 
 | ||||||
| @@ -73,8 +73,8 @@ sub b_mac { | |||||||
|     foreach my $i ( keys %$macs ) { |     foreach my $i ( keys %$macs ) { | ||||||
|         my $mac = $macs->{$i}; |         my $mac = $macs->{$i}; | ||||||
| 
 | 
 | ||||||
|         # don't catch the bad macs with zeroed OUI |         # don't catch the bad macs with bogus OUI | ||||||
|         if ( $mac !~ m/(0{1,2}:){3}/ ) { |         if ( $mac !~ m/(0{1,2}:){2}(00|01)/ ) { | ||||||
|             push( @macs, $mac ); |             push( @macs, $mac ); | ||||||
|         } |         } | ||||||
|         @macs = sort(@macs); |         @macs = sort(@macs); | ||||||
| @@ -43,7 +43,7 @@ use SNMP::Info::Layer3; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %MUNGE/; | use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( %SNMP::Info::Layer3::MIBS, %SNMP::Info::CiscoStats::MIBS, ); | %MIBS = ( %SNMP::Info::Layer3::MIBS, %SNMP::Info::CiscoStats::MIBS, ); | ||||||
| 
 | 
 | ||||||
| @@ -50,7 +50,7 @@ use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %MUNGE/; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %MUNGE/; | use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
|     %SNMP::Info::Layer3::Cisco::MIBS, |     %SNMP::Info::Layer3::Cisco::MIBS, | ||||||
| @@ -42,7 +42,7 @@ use SNMP::Info::Entity; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %GLOBALS %FUNCS %MIBS %MUNGE/; | use vars qw/$VERSION %GLOBALS %FUNCS %MIBS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
|     %SNMP::Info::MIBS, %SNMP::Info::Layer3::MIBS, %SNMP::Info::Entity::MIBS, |     %SNMP::Info::MIBS, %SNMP::Info::Layer3::MIBS, %SNMP::Info::Entity::MIBS, | ||||||
							
								
								
									
										306
									
								
								lib/SNMP/Info/Layer3/Cumulus.pm
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										306
									
								
								lib/SNMP/Info/Layer3/Cumulus.pm
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,306 @@ | |||||||
|  | # SNMP::Info::Layer3::Cumulus | ||||||
|  | # $Id$ | ||||||
|  | # | ||||||
|  | # Copyright (c) 2018 Bill Fenner and Oliver Gorwits | ||||||
|  | # 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::Cumulus; | ||||||
|  |  | ||||||
|  | use strict; | ||||||
|  | use Exporter; | ||||||
|  | use SNMP::Info::Layer3; | ||||||
|  | use SNMP::Info::LLDP; | ||||||
|  | use SNMP::Info::IEEE802dot3ad 'agg_ports_lag'; | ||||||
|  |  | ||||||
|  | @SNMP::Info::Layer3::Cumulus::ISA = qw/ | ||||||
|  |   SNMP::Info::IEEE802dot3ad | ||||||
|  |   SNMP::Info::LLDP | ||||||
|  |   SNMP::Info::Layer3 | ||||||
|  |   Exporter | ||||||
|  | /; | ||||||
|  | @SNMP::Info::Layer3::Cumulus::EXPORT_OK = qw/ agg_ports /; | ||||||
|  |  | ||||||
|  | use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %MUNGE/; | ||||||
|  |  | ||||||
|  | $VERSION = '3.53'; | ||||||
|  |  | ||||||
|  | %MIBS = ( | ||||||
|  |     %SNMP::Info::Layer3::MIBS, | ||||||
|  |     %SNMP::Info::LLDP::MIBS, | ||||||
|  |     %SNMP::Info::IEEE802dot3ad::MIBS, | ||||||
|  |     'UCD-SNMP-MIB'       => 'versionTag', | ||||||
|  |     'NET-SNMP-TC'        => 'netSnmpAgentOIDs', | ||||||
|  |     'HOST-RESOURCES-MIB' => 'hrSystem', | ||||||
|  | ); | ||||||
|  |  | ||||||
|  | %GLOBALS = ( | ||||||
|  |     %SNMP::Info::Layer3::GLOBALS, | ||||||
|  |     %SNMP::Info::LLDP::GLOBALS, | ||||||
|  |     'netsnmp_vers'   => 'versionTag', | ||||||
|  |     'hrSystemUptime' => 'hrSystemUptime', | ||||||
|  |     'chassis'    => 'entPhysicalDescr.1', | ||||||
|  | ); | ||||||
|  |  | ||||||
|  | %FUNCS = ( | ||||||
|  |     %SNMP::Info::Layer3::FUNCS, | ||||||
|  |     %SNMP::Info::LLDP::FUNCS, | ||||||
|  |     %SNMP::Info::IEEE802dot3ad::FUNCS, | ||||||
|  | ); | ||||||
|  |  | ||||||
|  | %MUNGE = ( | ||||||
|  |     %SNMP::Info::Layer3::MUNGE, | ||||||
|  |     %SNMP::Info::LLDP::MUNGE, | ||||||
|  |     %SNMP::Info::IEEE802dot3ad::MUNGE, | ||||||
|  | ); | ||||||
|  |  | ||||||
|  | sub vendor { return 'Cumulus Networks' } | ||||||
|  |  | ||||||
|  | sub os { return 'cumulus' } | ||||||
|  |  | ||||||
|  | sub os_ver { | ||||||
|  |     my $netsnmp = shift; | ||||||
|  |     my $descr   = $netsnmp->description(); | ||||||
|  |  | ||||||
|  | # STRING: "Cumulus Linux version 3.5.1 running on innotek GmbH VirtualBox" | ||||||
|  |     return $1 if ( $descr =~ /^Cumulus Linux (\S+)\s+/ ); | ||||||
|  |     return; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | sub model { | ||||||
|  |     my $netsnmp = shift; | ||||||
|  |     my $chassis = $netsnmp->chassis(); | ||||||
|  |  | ||||||
|  | # STRING: "Cumulus Networks  VX Chassis" | ||||||
|  |     return $1 if ( $chassis =~ /^Cumulus Networks\s+(.+)/ ); | ||||||
|  |     return $netsnmp->SUPER::model(); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | # sysUptime gives us the time since the SNMP daemon has restarted, | ||||||
|  | # so return the system uptime since that's probably what the user | ||||||
|  | # wants.  (Caution: this could cause trouble if using | ||||||
|  | # sysUptime-based discontinuity timers or other TimeStamp | ||||||
|  | # objects. | ||||||
|  | sub uptime { | ||||||
|  |     my $netsnmp = shift; | ||||||
|  |     my $uptime; | ||||||
|  |  | ||||||
|  |     $uptime = $netsnmp->hrSystemUptime(); | ||||||
|  |     return $uptime if defined $uptime; | ||||||
|  |  | ||||||
|  |     return $netsnmp->SUPER::uptime(); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | # ifDescr is the same for all interfaces in a class, but the ifName is | ||||||
|  | # unique, so let's use that for port name.  If all else fails,  | ||||||
|  | # concatentate ifDesc and ifIndex. | ||||||
|  | # (code from SNMP/Info/Layer2/Netgear.pm) | ||||||
|  | sub interfaces { | ||||||
|  |     my $netsnmp = shift; | ||||||
|  |     my $partial = shift; | ||||||
|  |  | ||||||
|  |     my $interfaces = $netsnmp->i_index($partial)       || {}; | ||||||
|  |     my $i_descr    = $netsnmp->i_description($partial) || {}; | ||||||
|  |     my $i_name     = $netsnmp->i_name($partial); | ||||||
|  |     my $i_isset    = (); | ||||||
|  |     # Replace the description with the ifName field, if set | ||||||
|  |     foreach my $iid ( keys %$i_name ) { | ||||||
|  |         my $name = $i_name->{$iid}; | ||||||
|  |         next unless defined $name; | ||||||
|  |         if (defined $name and $name !~ /^\s*$/) { | ||||||
|  |             $interfaces->{$iid} = $name; | ||||||
|  |             $i_isset->{$iid} = 1; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |     # Replace the Index with the ifDescr field, appended with index | ||||||
|  |     # number, to deal with devices with non-unique ifDescr. | ||||||
|  |     foreach my $iid ( keys %$i_descr ) { | ||||||
|  |         my $port = $i_descr->{$iid} . '-' . $iid; | ||||||
|  |         next unless defined $port; | ||||||
|  |         next if (defined $i_isset->{$iid} and $i_isset->{$iid} == 1); | ||||||
|  |         $interfaces->{$iid} = $port; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     return $interfaces; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | sub i_ignore { | ||||||
|  |     my $l3      = shift; | ||||||
|  |     my $partial = shift; | ||||||
|  |  | ||||||
|  |     my $interfaces = $l3->interfaces($partial) || {}; | ||||||
|  |  | ||||||
|  |     my %i_ignore; | ||||||
|  |     foreach my $if ( keys %$interfaces ) { | ||||||
|  |  | ||||||
|  |         # vlan1@br0 or peerlink.4094@peerlink | ||||||
|  |         if ( $interfaces->{$if} =~ /@/i ) { | ||||||
|  |             $i_ignore{$if}++; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |     return \%i_ignore; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | sub agg_ports { return agg_ports_lag(@_) } | ||||||
|  |  | ||||||
|  | 1; | ||||||
|  | __END__ | ||||||
|  |  | ||||||
|  | =head1 NAME | ||||||
|  |  | ||||||
|  | SNMP::Info::Layer3::Cumulus - SNMP Interface to Cumulus Networks Devices | ||||||
|  |  | ||||||
|  | =head1 AUTHORS | ||||||
|  |  | ||||||
|  | Oliver Gorwits - based on Layer3::NetSNMP implementation | ||||||
|  |  | ||||||
|  | =head1 SYNOPSIS | ||||||
|  |  | ||||||
|  |  # Let SNMP::Info determine the correct subclass for you.  | ||||||
|  |  my $cumulus = new SNMP::Info( | ||||||
|  |                           AutoSpecify => 1, | ||||||
|  |                           Debug       => 1, | ||||||
|  |                           DestHost    => 'myrouter', | ||||||
|  |                           Community   => 'public', | ||||||
|  |                           Version     => 2 | ||||||
|  |                         )  | ||||||
|  |     or die "Can't connect to DestHost.\n"; | ||||||
|  |  | ||||||
|  |  my $class      = $cumulus->class(); | ||||||
|  |  print "SNMP::Info determined this device to fall under subclass : $class\n"; | ||||||
|  |  | ||||||
|  | =head1 DESCRIPTION | ||||||
|  |  | ||||||
|  | Subclass for Cumulus Networks devices | ||||||
|  |  | ||||||
|  | =head2 Inherited Classes | ||||||
|  |  | ||||||
|  | =over | ||||||
|  |  | ||||||
|  | =item SNMP::Info::Layer3 | ||||||
|  |  | ||||||
|  | =back | ||||||
|  |  | ||||||
|  | =head2 Required MIBs | ||||||
|  |  | ||||||
|  | =over | ||||||
|  |  | ||||||
|  | =item F<UCD-SNMP-MIB> | ||||||
|  |  | ||||||
|  | =item F<NET-SNMP-TC> | ||||||
|  |  | ||||||
|  | =item F<HOST-RESOURCES-MIB> | ||||||
|  |  | ||||||
|  | =item Inherited Classes' MIBs | ||||||
|  |  | ||||||
|  | See L<SNMP::Info::Layer3> for its own MIB requirements. | ||||||
|  |  | ||||||
|  | See L<SNMP::Info::LLDP> for its own MIB requirements. | ||||||
|  |  | ||||||
|  | See L<SNMP::Info::IEEE802dot3ad> for its own MIB requirements. | ||||||
|  |  | ||||||
|  | =back | ||||||
|  |  | ||||||
|  | =head1 GLOBALS | ||||||
|  |  | ||||||
|  | These are methods that return scalar value from SNMP | ||||||
|  |  | ||||||
|  | =over | ||||||
|  |  | ||||||
|  | =item $cumulus->vendor() | ||||||
|  |  | ||||||
|  | Returns 'Cumulus Networks'. | ||||||
|  |  | ||||||
|  | =item $cumulus->os() | ||||||
|  |  | ||||||
|  | Returns 'cumulus'. | ||||||
|  |  | ||||||
|  | =item $cumulus->os_ver() | ||||||
|  |  | ||||||
|  | Returns the software version extracted from C<sysDescr>. | ||||||
|  |  | ||||||
|  | =item $cumulus->uptime() | ||||||
|  |  | ||||||
|  | Returns the system uptime instead of the agent uptime. | ||||||
|  | NOTE: discontinuity timers and other Time Stamp based objects | ||||||
|  | are based on agent uptime, so use orig_uptime(). | ||||||
|  |  | ||||||
|  | =item $l3->model() | ||||||
|  |  | ||||||
|  | Returns the chassis type. | ||||||
|  |  | ||||||
|  | =back | ||||||
|  |  | ||||||
|  | =head2 Globals imported from SNMP::Info::Layer3 | ||||||
|  |  | ||||||
|  | See documentation in L<SNMP::Info::Layer3> for details. | ||||||
|  |  | ||||||
|  | =head2 Globals imported from SNMP::Info::LLDP | ||||||
|  |  | ||||||
|  | See documentation in L<SNMP::Info::LLDP> for details. | ||||||
|  |  | ||||||
|  | =head2 Globals imported from SNMP::Info::IEEE802dot3ad | ||||||
|  |  | ||||||
|  | See documentation in L<SNMP::Info::IEEE802dot3ad> 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 $cumulus->interfaces() | ||||||
|  |  | ||||||
|  | Uses the i_name() field. | ||||||
|  |  | ||||||
|  | =item $cumulus->i_ignore() | ||||||
|  |  | ||||||
|  | Ignores interfaces with an "@" in them. | ||||||
|  |  | ||||||
|  | =item C<agg_ports> | ||||||
|  |  | ||||||
|  | Returns a HASH reference mapping from slave to master port for each member of | ||||||
|  | a port bundle on the device. Keys are ifIndex of the slave ports, Values are | ||||||
|  | ifIndex of the corresponding master ports. | ||||||
|  |  | ||||||
|  | =back | ||||||
|  |  | ||||||
|  | =head2 Table Methods imported from SNMP::Info::Layer3 | ||||||
|  |  | ||||||
|  | See documentation in L<SNMP::Info::Layer3> for details. | ||||||
|  |  | ||||||
|  | =head2 Table Methods imported from SNMP::Info::LLDP | ||||||
|  |  | ||||||
|  | See documentation in L<SNMP::Info::LLDP> for details. | ||||||
|  |  | ||||||
|  | =head2 Table Methods imported from SNMP::Info::IEEE802dot3ad | ||||||
|  |  | ||||||
|  | See documentation in L<SNMP::Info::IEEE802dot3ad> for details. | ||||||
|  |  | ||||||
|  | =cut | ||||||
							
								
								
									
										213
									
								
								lib/SNMP/Info/Layer3/DLink.pm
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										213
									
								
								lib/SNMP/Info/Layer3/DLink.pm
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,213 @@ | |||||||
|  | package SNMP::Info::Layer3::DLink; | ||||||
|  |  | ||||||
|  | use strict; | ||||||
|  | use Exporter; | ||||||
|  | use SNMP::Info::Layer3; | ||||||
|  | use SNMP::Info::LLDP; | ||||||
|  |  | ||||||
|  | @SNMP::Info::Layer3::DLink::ISA       = qw/SNMP::Info::LLDP SNMP::Info::Layer3 Exporter/; | ||||||
|  | @SNMP::Info::Layer3::DLink::EXPORT_OK = qw//; | ||||||
|  |  | ||||||
|  | use vars qw/$VERSION %GLOBALS %FUNCS %MIBS %MUNGE/; | ||||||
|  |  | ||||||
|  | $VERSION = '3.53'; | ||||||
|  |  | ||||||
|  | %MIBS = ( | ||||||
|  |     %SNMP::Info::Layer3::MIBS, | ||||||
|  |     %SNMP::Info::LLDP::MIBS, | ||||||
|  |     'DLINK-ID-REC-MIB' => 'dlink', | ||||||
|  |     'SWPRIMGMT-DES3200-MIB' => 'dlink-des3200SeriesProd', | ||||||
|  |     'SWPRIMGMT-DES30XXP-MIB' => 'dlink-des30xxproductProd', | ||||||
|  |     'SWPRIMGMT-DES1228ME-MIB' => 'dlink-des1228MEproductProd', | ||||||
|  |     'SWDES3528-52PRIMGMT-MIB' => 'dlink-Des3500Series',  | ||||||
|  |     'DES-1210-28-AX' => 'des-1210-28ax', | ||||||
|  |     'DES-1210-10MEbx' => 'des-1210-10mebx', | ||||||
|  |     'DES-1210-26MEbx' => 'des-1210-26mebx', | ||||||
|  |     'DES-1210-52-BX' => 'des-1210-52bx', | ||||||
|  |     'DES-1210-52-CX' => 'des-1210-52-cx', | ||||||
|  |     'DGS-1210-24-AX' => 'dgs-1210-24ax', | ||||||
|  |  | ||||||
|  | ); | ||||||
|  |  | ||||||
|  | %GLOBALS = ( | ||||||
|  |     %SNMP::Info::Layer3::GLOBALS, | ||||||
|  |     %SNMP::Info::LLDP::GLOBALS, | ||||||
|  | ); | ||||||
|  |  | ||||||
|  | %FUNCS = ( | ||||||
|  |     %SNMP::Info::Layer3::FUNCS, | ||||||
|  |     %SNMP::Info::LLDP::FUNCS, | ||||||
|  |     'dlink_fw' => 'probeSoftwareRev', | ||||||
|  |     'dlink_hw' => 'probeHardwareRev', | ||||||
|  |     'dlink_stp_i_root_port' => 'MSTP_MIB__swMSTPInstRootPort', | ||||||
|  |     'dlink_serial_no' => 'AGENT_GENERAL_MIB__agentSerialNumber', | ||||||
|  | ); | ||||||
|  |  | ||||||
|  | %MUNGE = ( %SNMP::Info::Layer3::MUNGE, %SNMP::Info::LLDP::MUNGE, ); | ||||||
|  |  | ||||||
|  | sub model { | ||||||
|  |     my $dlink=shift; | ||||||
|  |     my $id = $dlink->id(); | ||||||
|  |     my $model = &SNMP::translateObj($id); | ||||||
|  |     return $id unless defined $model; | ||||||
|  |     if (defined $model && $model !~ /dlink-products/) { | ||||||
|  | 	return $model; | ||||||
|  |     } else { | ||||||
|  |     	#If don't have a device MIB | ||||||
|  | 	return $dlink->description(); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | sub vendor { | ||||||
|  |     return 'dlink'; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | sub serial { | ||||||
|  |     my $dlink = shift; | ||||||
|  |     my $model = $dlink->model(); | ||||||
|  |     my $id = $dlink->id(); | ||||||
|  |     my $serial; | ||||||
|  |     if ($model =~ /1210/) { | ||||||
|  | 	#Due to the zoo of MIB from DLink by 1210 series | ||||||
|  | 	$serial->{0} = $dlink->session()->get($id.'.1.30.0'); | ||||||
|  |     } else { | ||||||
|  | 	$serial = $dlink->dlink_serial_no(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     return $serial->{0} if ( defined $serial->{0} and $serial->{0} !~ /^\s*$/ and $serial->{0} !~ 'NOSUCHOBJECT' ); | ||||||
|  |     return $dlink->SUPER::serial(); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | sub fwver { | ||||||
|  |     my $dlink=shift; | ||||||
|  |     my $model = $dlink->model(); | ||||||
|  |     my $id = $dlink->id(); | ||||||
|  |     my $fw; | ||||||
|  |     if ($model =~ /1210/) { | ||||||
|  | 	#Due to the zoo of MIB from DLink by 1210 series | ||||||
|  | 	$fw->{0} = $dlink->session()->get($id.'.1.3.0'); | ||||||
|  |     } else { | ||||||
|  | 	$fw = $dlink->dlink_fw(); | ||||||
|  |     } | ||||||
|  |     return $fw->{0} if ( defined $fw->{0} and $fw->{0} !~ /^\s*$/ and $fw->{0} !~ 'NOSUCHOBJECT'); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | sub hwver { | ||||||
|  |     my $dlink=shift; | ||||||
|  |     my $model = $dlink->model(); | ||||||
|  |     my $id = $dlink->id(); | ||||||
|  |     my $hw; | ||||||
|  |     if ($model =~ /1210/) { | ||||||
|  | 	#Due to the zoo of MIB from DLink by 1210 series | ||||||
|  | 	$hw->{0} = $dlink->session()->get($id.'.1.2.0'); | ||||||
|  |     } else { | ||||||
|  | 	$hw = $dlink->dlink_hw(); | ||||||
|  |     } | ||||||
|  |     return $hw->{0} if ( defined $hw->{0} and $hw->{0} !~ /^\s*$/ and $hw->{0} !~ 'NOSUCHOBJECT'); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | sub stp_i_root_port { | ||||||
|  |     my $dlink=shift; | ||||||
|  |     my $model = $dlink->model(); | ||||||
|  |     my $id = $dlink->id(); | ||||||
|  |     my $stp_i_root_port; | ||||||
|  |     if ($model =~ /1210-(?:10|26)/) { | ||||||
|  | 	#Due to the zoo of MIB from DLink by 1210 series | ||||||
|  | 	$stp_i_root_port->{0} = $dlink->session()->get($id.'.6.1.13.0'); | ||||||
|  |     } else { | ||||||
|  | 	$stp_i_root_port = $dlink->dlink_stp_i_root_port(); | ||||||
|  |     } | ||||||
|  |     return $stp_i_root_port if ( defined $stp_i_root_port->{0} and $stp_i_root_port->{0} !~ /^\s*$/ and $stp_i_root_port->{0} !~ 'NOSUCHOBJECT'); | ||||||
|  |     return $dlink->SUPER::stp_i_root_port(); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | 1; | ||||||
|  | __END__ | ||||||
|  |  | ||||||
|  | =head1 NAME | ||||||
|  |  | ||||||
|  | SNMP::Info::Layer3::DLink - SNMP Interface to DLink Devices | ||||||
|  |  | ||||||
|  | =head1 SYNOPSIS | ||||||
|  |  | ||||||
|  |  # Let SNMP::Info determine the correct subclass for you.  | ||||||
|  |  my $dlink = new SNMP::Info( | ||||||
|  |                           AutoSpecify => 1, | ||||||
|  |                           Debug       => 1, | ||||||
|  |                           DestHost    => 'myrouter', | ||||||
|  |                           Community   => 'public', | ||||||
|  |                           Version     => 2 | ||||||
|  |                         )  | ||||||
|  |     or die "Can't connect to DestHost.\n"; | ||||||
|  |  | ||||||
|  |  my $class      = $dlink->class(); | ||||||
|  |  print "SNMP::Info determined this device to fall under subclass : $class\n"; | ||||||
|  |  | ||||||
|  | =head1 DESCRIPTION | ||||||
|  |  | ||||||
|  | Subclass for Vyatta Devices running dlink. | ||||||
|  |  | ||||||
|  | =head2 Inherited Classes | ||||||
|  |  | ||||||
|  | =over | ||||||
|  |  | ||||||
|  | =item SNMP::Info::Layer3 | ||||||
|  |  | ||||||
|  | =item SNMP::Info::LLDP | ||||||
|  |  | ||||||
|  | =back | ||||||
|  |  | ||||||
|  | =head2 Inherited Classes' MIBs | ||||||
|  |  | ||||||
|  | See L<SNMP::Info::Layer3/"Required MIBs"> for its own MIB requirements. | ||||||
|  |  | ||||||
|  | See L<SNMP::Info::LLDP/"Required MIBs"> for its own MIB requirements. | ||||||
|  |  | ||||||
|  | =head1 GLOBALS | ||||||
|  |  | ||||||
|  | These are methods that return scalar value from SNMP | ||||||
|  |  | ||||||
|  | =over | ||||||
|  |  | ||||||
|  | =item $dlink->model() | ||||||
|  |  | ||||||
|  | Returns the ID or else description. | ||||||
|  |  | ||||||
|  | =item $dlink->vendor() | ||||||
|  |  | ||||||
|  | Returns 'dlink'. | ||||||
|  |  | ||||||
|  | =item $dlink->serial() | ||||||
|  |  | ||||||
|  | Returns serial number. | ||||||
|  |  | ||||||
|  | =item $dlink->fwver() | ||||||
|  |  | ||||||
|  | Returns the firmware version. | ||||||
|  |  | ||||||
|  | =item $dlink->hwver() | ||||||
|  |  | ||||||
|  | Returns the hardware version. | ||||||
|  |  | ||||||
|  | =item $dlink->stp_i_root_port() | ||||||
|  |  | ||||||
|  | Returns the STP root port. | ||||||
|  |  | ||||||
|  | =back | ||||||
|  |  | ||||||
|  | =head2 Globals imported from SNMP::Info::Layer3 | ||||||
|  |  | ||||||
|  | See documentation in L<SNMP::Info::Layer3/"GLOBALS"> for details. | ||||||
|  |  | ||||||
|  | See documentation in L<SNMP::Info::LLDP/"GLOBALS"> for details. | ||||||
|  |  | ||||||
|  | =head1 TABLE METHODS | ||||||
|  |  | ||||||
|  | =head2 Table Methods imported from SNMP::Info::Layer3 | ||||||
|  |  | ||||||
|  | See documentation in L<SNMP::Info::Layer3/"TABLE METHODS"> for details. | ||||||
|  |  | ||||||
|  | See documentation in L<SNMP::Info::LLDP/"TABLE METHODS"> for details. | ||||||
|  |  | ||||||
|  | =cut | ||||||
| @@ -40,7 +40,7 @@ use SNMP::Info::LLDP; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION %GLOBALS %FUNCS %MIBS %MUNGE/; | use vars qw/$VERSION %GLOBALS %FUNCS %MIBS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
|     %SNMP::Info::Layer3::MIBS, |     %SNMP::Info::Layer3::MIBS, | ||||||
| @@ -44,7 +44,7 @@ use SNMP::Info::Layer3; | |||||||
| 
 | 
 | ||||||
| use vars qw/$VERSION $DEBUG %GLOBALS %FUNCS $INIT %MIBS %MUNGE/; | use vars qw/$VERSION $DEBUG %GLOBALS %FUNCS $INIT %MIBS %MUNGE/; | ||||||
| 
 | 
 | ||||||
| $VERSION = '3.31'; | $VERSION = '3.53'; | ||||||
| 
 | 
 | ||||||
| %MIBS = ( | %MIBS = ( | ||||||
|     %SNMP::Info::Layer3::MIBS, %SNMP::Info::CDP::MIBS, |     %SNMP::Info::Layer3::MIBS, %SNMP::Info::CDP::MIBS, | ||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user