1655 lines
49 KiB
Perl
1655 lines
49 KiB
Perl
# SNMP::Info::Layer3::BayRS
|
|
# $Id$
|
|
#
|
|
# Copyright (c) 2008 Eric Miller
|
|
# 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::BayRS;
|
|
|
|
use strict;
|
|
use Exporter;
|
|
use SNMP::Info;
|
|
use SNMP::Info::Layer3;
|
|
use SNMP::Info::Bridge;
|
|
|
|
@SNMP::Info::Layer3::BayRS::ISA = qw/SNMP::Info SNMP::Info::Layer3
|
|
SNMP::Info::Bridge Exporter/;
|
|
@SNMP::Info::Layer3::BayRS::EXPORT_OK = qw//;
|
|
|
|
use vars qw/$VERSION %GLOBALS %FUNCS %MIBS %MUNGE %MODEL_MAP
|
|
%MODID_MAP %PROCID_MAP/;
|
|
|
|
$VERSION = '3.43';
|
|
|
|
%MIBS = (
|
|
%SNMP::Info::MIBS,
|
|
%SNMP::Info::Layer3::MIBS,
|
|
%SNMP::Info::Bridge::MIBS,
|
|
'Wellfleet-HARDWARE-MIB' => 'wfHwBpIdOpt',
|
|
'Wellfleet-OSPF-MIB' => 'wfOspfRouterId',
|
|
'Wellfleet-DOT1QTAG-CONFIG-MIB' => 'wfDot1qTagCfgVlanName',
|
|
'Wellfleet-CSMACD-MIB' => 'wfCSMACDCct',
|
|
'Wellfleet-MODULE-MIB' => 'wfHwModuleSlot',
|
|
);
|
|
|
|
%GLOBALS = (
|
|
%SNMP::Info::GLOBALS,
|
|
%SNMP::Info::Layer3::GLOBALS,
|
|
%SNMP::Info::Bridge::GLOBALS,
|
|
'bp_id' => 'wfHwBpIdOpt',
|
|
'bp_serial' => 'wfHwBpSerialNumber',
|
|
'ospf_rtr_id' => 'wfOspfRouterId',
|
|
);
|
|
|
|
%FUNCS = (
|
|
%SNMP::Info::FUNCS,
|
|
%SNMP::Info::Layer3::FUNCS,
|
|
%SNMP::Info::Bridge::FUNCS,
|
|
|
|
# From Wellfleet-CSMACD-MIB::wfCSMACDTable
|
|
'wf_csmacd_cct' => 'wfCSMACDCct',
|
|
'wf_csmacd_slot' => 'wfCSMACDSlot',
|
|
'wf_csmacd_conn' => 'wfCSMACDConnector',
|
|
'wf_csmacd_mtu' => 'wfCSMACDMtu',
|
|
'wf_duplex' => 'wfCSMACDLineCapability',
|
|
'wf_csmacd_line' => 'wfCSMACDLineNumber',
|
|
|
|
# From Wellfleet-CSMACD-MIB::wfCSMACDAutoNegTable
|
|
'wf_auto' => 'wfCSMACDAutoNegSpeedSelect',
|
|
|
|
# From Wellfleet-DOT1QTAG-CONFIG-MIB::wfDot1qTagConfigTable
|
|
'wf_vlan_name' => 'wfDot1qTagCfgVlanName',
|
|
'wf_local_vlan_id' => 'wfDot1qTagCfgLocalVlanId',
|
|
'wf_global_vlan_id' => 'wfDot1qTagCfgGlobalVlanId',
|
|
'wf_vlan_port' => 'wfDot1qTagCfgPhysicalPortId',
|
|
|
|
# From Wellfleet-HARDWARE-MIB::wfHwTable
|
|
'wf_hw_slot' => 'wfHwSlot',
|
|
'wf_hw_mod_id' => 'wfHwModIdOpt',
|
|
'wf_hw_mod_rev' => 'wfHwModRev',
|
|
'wf_hw_mod_ser' => 'wfHwModSerialNumber',
|
|
'wf_hw_mobo_id' => 'wfHwMotherBdIdOpt',
|
|
'wf_hw_mobo_rev' => 'wfHwMotherBdRev',
|
|
'wf_hw_mobo_ser' => 'wfHwMotherBdSerialNumber',
|
|
'wf_hw_diag' => 'wfHwDiagPromRev',
|
|
'wf_hw_boot' => 'wfHwBootPromRev',
|
|
'wf_hw_mobo_mem' => 'wfHwMotherBdMemorySize',
|
|
'wf_hw_cfg_time' => 'wfHwConfigDateAndTime',
|
|
'wf_hw_db_ser' => 'wfHwDaughterBdSerialNumber',
|
|
'wf_hw_bb_ser' => 'wfHwBabyBdSerialNumber',
|
|
'wf_hw_mm_ser' => 'wfHwModuleModSerialNumber',
|
|
'wf_hw_md1_ser' => 'wfHwModDaughterBd1SerialNumber',
|
|
'wf_hw_md2_ser' => 'wfHwModDaughterBd2SerialNumber',
|
|
);
|
|
|
|
%MUNGE = (
|
|
%SNMP::Info::MUNGE,
|
|
%SNMP::Info::Layer3::MUNGE,
|
|
%SNMP::Info::Bridge::MUNGE,
|
|
'wf_hw_boot' => \&munge_hw_rev,
|
|
'wf_hw_diag' => \&munge_hw_rev,
|
|
'wf_hw_mobo_ser' => \&munge_wf_serial,
|
|
'wf_hw_mod_ser' => \&munge_wf_serial,
|
|
'wf_hw_db_ser' => \&munge_wf_serial,
|
|
'wf_hw_bb_ser' => \&munge_wf_serial,
|
|
'wf_hw_mm_ser' => \&munge_wf_serial,
|
|
'wf_hw_md1_ser' => \&munge_wf_serial,
|
|
'wf_hw_md2_ser' => \&munge_wf_serial,
|
|
);
|
|
|
|
%MODEL_MAP = (
|
|
'acefn' => 'FN',
|
|
'aceln' => 'LN',
|
|
'acecn' => 'CN',
|
|
'afn' => 'AFN',
|
|
'in' => 'IN',
|
|
'an' => 'AN',
|
|
'arn' => 'ARN',
|
|
'sys5000' => '5000',
|
|
'freln' => 'BLN',
|
|
'frecn' => 'BCN',
|
|
'frerbln' => 'BLN-2',
|
|
'asn' => 'ASN',
|
|
'asnzcable' => 'ASN-Z',
|
|
'asnbcable' => 'ASN-B',
|
|
);
|
|
|
|
%MODID_MAP = (
|
|
1 => 'DUAL ENET',
|
|
8 => 'DUAL ENET',
|
|
16 => 'QSYNC',
|
|
24 => 'DUAL T1',
|
|
32 => 'SSE,DSE',
|
|
40 => 'TS 4/16 - 1x2',
|
|
44 => 'TS 4/16 - 1x1',
|
|
45 => 'TS 4/16 - 1x0',
|
|
48 => 'SYSTEM I/O',
|
|
49 => 'SYSTEM I/O',
|
|
56 => 'DUAL T1',
|
|
57 => 'DUAL T1 - 56K',
|
|
58 => 'T1 - SINGLE PORT',
|
|
60 => 'T1 56K - SINGLE PORT',
|
|
61 => 'E1 - 75 OHM',
|
|
80 => 'QSYNC',
|
|
112 => 'DSDE 4',
|
|
116 => 'DSE',
|
|
118 => 'SSE',
|
|
132 => 'ESA 2x0',
|
|
156 => 'ESA 2x2',
|
|
162 => 'QUAD ENET with CAM DAUGHTERCARD',
|
|
164 => 'QUAD ENET with CAM DAUGHTERCARD,QUAD ENET CAM DAUGHTER CARD',
|
|
168 => 'MCT1 - 2',
|
|
169 => 'MCT1 - 1',
|
|
176 => 'DUAL TOKEN',
|
|
184 => 'MCE1 - DUAL PORT',
|
|
185 => 'MCE1 - SINGLE PORT',
|
|
192 => 'MULTIMODE FDDI',
|
|
193 => 'SINGLEMODE FDDI PHY-B',
|
|
194 => 'SINGLEMODE FDDI PHY-A/B',
|
|
195 => 'SINGLEMODE FDDI PHY-A',
|
|
196 => 'MULTIMODE FDDI,FDDI CAM DAUGHTER CARD',
|
|
197 => 'SINGLEMODE FDDI PHY-B,FDDI CAM DAUGHTER CARD',
|
|
198 => 'SINGLEMODE FDDI PHY-A/B,FDDI CAM DAUGHTER CARD',
|
|
199 => 'SINGLEMODE FDDI PHY-A,FDDI CAM DAUGHTER CARD',
|
|
208 => {
|
|
0 =>
|
|
'AFNes - V.35,AFNes - X.21,AFNes - CCITT V.35,AFNes - RS449/RS422,AFNes - V.35 w/FLASH,AFNes - X.21 w/FLASH,AFNes-CCITT V.35 w/FL,AFNes - RS422 w/FLASH AFNes 16M - V.35,AFNes 16M - X.21,AFNes 16M - CCITT V.35,AFNes 16M - RS449/RS422,AFNes 16M V.35 w/Flash,AFNes 16M X.21 w/Flash,AFNes 16M CCITT V.35 w/Flash,AFNes 16M RS449/RS422 w/Flash',
|
|
4096 =>
|
|
'AFNes - V.35,AFNes - X.21,AFNes - CCITT V.35,AFNes - RS449/RS422,AFNes - V.35 w/FLASH,AFNes - X.21 w/FLASH,AFNes-CCITT V.35 w/FL,AFNes - RS422 w/FLASH',
|
|
16384 =>
|
|
'AFNes 16M - V.35,AFNes 16M - X.21,AFNes 16M - CCITT V.35,AFNes 16M - RS449/RS422,AFNes 16M V.35 w/Flash,AFNes 16M X.21 w/Flash,AFNes 16M CCITT V.35 w/Flash,AFNes 16M RS449/RS422 w/Flash',
|
|
},
|
|
216 => {
|
|
0 =>
|
|
'AFNts 2x2,AFNts 2x2 - w/FLASH,AFNTS 2X2 16MB,AFNTS 2X2 16MB FLASH',
|
|
4096 => 'AFNts 2x2,AFNts 2x2 - w/FLASH',
|
|
16384 => 'AFNTS 2X2 16MB,AFNTS 2X2 16MB FLASH',
|
|
},
|
|
217 => {
|
|
0 =>
|
|
'AFNts 1x2,AFNts 1x2 - w/FLASH,AFNTS 1X2 16MB,AFNTS 1X2 16MB FLASH',
|
|
4096 => 'AFNts 1x2,AFNts 1x2 - w/FLASH',
|
|
16384 => 'AFNTS 1X2 16MB,AFNTS 1X2 16MB FLASH',
|
|
},
|
|
225 => 'HSSI - SINGLE PORT',
|
|
232 => 'EASF 0 DEFA & 0 CAMS',
|
|
236 => 'ESAF w/DEFA & 2 CAMS,ESAF w/DEFA & 6 CAMS',
|
|
256 => 'QUAD TOKEN',
|
|
512 => 'SPX NET MODULE',
|
|
769 => 'HOT SWAP SPEX NET MOD',
|
|
1024 => {
|
|
4096 => 'AN-ENET 1X2 SPARE 4F/8D,BAYSTACK AN-ES 8MB',
|
|
8192 => 'AN-ENET 1X2 SPARE 4F/8D,BAYSTACK AN-ES 8MB',
|
|
16384 => 'AN-ENET 1X2 SPARE 4F/16D,BAYSTACK AN-ES 16MB',
|
|
},
|
|
1025 => {
|
|
4096 => 'AN-ENET/TOK 1X1X2 SPARE 4F/8D,BAYSTACK AN-ETS 8MB',
|
|
8192 => 'AN-ENET/TOK 1X1X2 SPARE 4F/8D,BAYSTACK AN-ETS 8MB',
|
|
16384 => 'AN-ENET/TOK 1X1X2 SPARE 4F/16D,BAYSTACK AN-ETS 16MB',
|
|
},
|
|
1026 => {
|
|
4096 => 'AN-HUB SPARE 4F/8D,BAYSTACK ANH-12 8MB',
|
|
8192 => 'AN-HUB SPARE 4F/8D,BAYSTACK ANH-12 8MB',
|
|
16384 => 'AN - HUB SPARE 4F/16D,BAYSTACK ANH-12 16MB',
|
|
},
|
|
1027 => {
|
|
4096 => 'AN-ENET 1X2 SPARE 4F/8D,AN ISDN BRI DAUGHTER CARD',
|
|
8192 => 'AN-ENET 1X2 SPARE 4F/8D,AN ISDN BRI DAUGHTER CARD',
|
|
16384 => 'AN-ENET 1X2 SPARE 4F/16D,AN ISDN BRI DAUGHTER CARD',
|
|
},
|
|
1028 => {
|
|
4096 => 'AN-ENET/TOK 1X1X2 SPARE 4F/8D,AN ISDN BRI DAUGHTER CARD',
|
|
8192 => 'AN-ENET/TOK 1X1X2 SPARE 4F/8D,AN ISDN BRI DAUGHTER CARD',
|
|
16384 => 'AN-ENET/TOK 1X1X2 SPARE 4F/16D,AN ISDN BRI DAUGHTER CARD',
|
|
},
|
|
1029 => {
|
|
4096 => 'AN-HUB SPARE 4F/8D,AN ISDN BRI DAUGHTER CARD',
|
|
8192 => 'AN-HUB SPARE 4F/8D,AN ISDN BRI DAUGHTER CARD',
|
|
16384 => 'AN - HUB SPARE 4F/16D,AN ISDN BRI DAUGHTER CARD',
|
|
},
|
|
1030 => {
|
|
4096 =>
|
|
'AN 3RD SYNC DAUGHTER CARD,AN-ENET 1X2 SPARE 4F/8D,BAYSTACK AN-ES 8MB',
|
|
8192 =>
|
|
'AN 3RD SYNC DAUGHTER CARD,AN-ENET 1X2 SPARE 4F/8D,BAYSTACK AN-ES 8MB',
|
|
16384 =>
|
|
'AN 3RD SYNC DAUGHTER CARD,AN-ENET 1X2 SPARE 4F/16D,BAYSTACK AN-ES 16MB',
|
|
},
|
|
1031 => {
|
|
4096 =>
|
|
'AN 3RD SYNC DAUGHTER CARD,AN-ENET/TOK 1X1X2 SPARE 4F/8D,BAYSTACK AN-ETS 8MB',
|
|
8192 =>
|
|
'AN 3RD SYNC DAUGHTER CARD,AN-ENET/TOK 1X1X2 SPARE 4F/8D,BAYSTACK AN-ETS 8MB',
|
|
16384 =>
|
|
'AN 3RD SYNC DAUGHTER CARD,AN-ENET/TOK 1X1X2 SPARE 4F/16D,BAYSTACK AN-ETS 16MB',
|
|
},
|
|
1032 => {
|
|
4096 =>
|
|
'AN 3RD SYNC DAUGHTER CARD,AN-HUB SPARE 4F/8D,BAYSTACK ANH-12 8MB',
|
|
8192 =>
|
|
'AN 3RD SYNC DAUGHTER CARD,AN-HUB SPARE 4F/8D,BAYSTACK ANH-12 8MB',
|
|
16384 =>
|
|
'AN 3RD SYNC DAUGHTER CARD,AN - HUB SPARE 4F/16D,BAYSTACK ANH-12 16MB',
|
|
},
|
|
1033 => {
|
|
4096 =>
|
|
'AN 2ND ENET DAUGHTER CARD,AN-ENET 1X2 SPARE 4F/8D,BAYSTACK AN-ES 8MB',
|
|
8192 =>
|
|
'AN 2ND ENET DAUGHTER CARD,AN-ENET 1X2 SPARE 4F/8D,BAYSTACK AN-ES 8MB',
|
|
16384 =>
|
|
'AN 2ND ENET DAUGHTER CARD,AN-ENET 1X2 SPARE 4F/16D,BAYSTACK AN-ES 16MB',
|
|
},
|
|
1035 => {
|
|
4096 =>
|
|
'AN 2ND ENET DAUGHTER CARD,AN-HUB SPARE 4F/8D,BAYSTACK ANH-12 8MB',
|
|
8192 =>
|
|
'AN 2ND ENET DAUGHTER CARD,AN-HUB SPARE 4F/8D,BAYSTACK ANH-12 8MB',
|
|
16384 =>
|
|
'AN 2ND ENET DAUGHTER CARD,AN - HUB SPARE 4F/16D,BAYSTACK ANH-12 16MB',
|
|
},
|
|
1037 => {
|
|
4096 => 'AN-TOK 1X2 SPARE 4F/8D,BAYSTACK AN-TS 8MB',
|
|
8192 => 'AN-TOK 1X2 SPARE 4F/8D,BAYSTACK AN-TS 8MB',
|
|
16384 => 'AN-TOK 1X2 SPARE 4F/16D,BAYSTACK AN-TS 16MB',
|
|
},
|
|
1038 => {
|
|
4096 => 'AN-TOK 1X2 SPARE 4F/8D,AN ISDN BRI DAUGHTER CARD',
|
|
8192 => 'AN-TOK 1X2 SPARE 4F/8D,AN ISDN BRI DAUGHTER CARD',
|
|
16384 => 'AN-TOK 1X2 SPARE 4F/16D,AN ISDN BRI DAUGHTER CARD',
|
|
},
|
|
1039 => {
|
|
4096 =>
|
|
'AN 3RD SYNC DAUGHTER CARD,AN-TOK 1X2 SPARE 4F/8D,BAYSTACK AN-TS 8MB',
|
|
8192 =>
|
|
'AN 3RD SYNC DAUGHTER CARD,AN-TOK 1X2 SPARE 4F/8D,BAYSTACK AN-TS 8MB',
|
|
16384 =>
|
|
'AN 3RD SYNC DAUGHTER CARD,AN-TOK 1X2 SPARE 4F/16D,BAYSTACK AN-TS 16MB',
|
|
},
|
|
1042 => {
|
|
4096 => 'BAYSTACK AN-ETS 8MB,BAYSTACK AN N11 DCM',
|
|
8192 => 'BAYSTACK AN-ETS 8MB,BAYSTACK AN N11 DCM',
|
|
16384 => 'BAYSTACK AN-ETS 16MB,BAYSTACK AN N11 DCM',
|
|
},
|
|
1043 => {
|
|
4096 => 'BAYSTACK AN-ES 8MB,AN ISDN BRI DAUGHTER CARD',
|
|
8192 => 'BAYSTACK AN-ES 8MB,AN ISDN BRI DAUGHTER CARD',
|
|
16384 => 'BAYSTACK AN-ES 16MB,AN ISDN BRI DAUGHTER CARD',
|
|
},
|
|
1044 => {
|
|
4096 => 'BAYSTACK AN-ETS 8MB,AN ISDN BRI DAUGHTER CARD',
|
|
8192 => 'BAYSTACK AN-ETS 8MB,AN ISDN BRI DAUGHTER CARD',
|
|
16384 => 'BAYSTACK AN-ETS 16MB,AN ISDN BRI DAUGHTER CARD',
|
|
},
|
|
1045 => {
|
|
4096 => 'BAYSTACK ANH-12 8MB,AN ISDN BRI DAUGHTER CARD',
|
|
8192 => 'BAYSTACK ANH-12 8MB,AN ISDN BRI DAUGHTER CARD',
|
|
16384 => 'BAYSTACK ANH-12 16MB,AN ISDN BRI DAUGHTER CARD',
|
|
},
|
|
1046 => {
|
|
4096 => 'BAYSTACK AN-TS 8MB,AN ISDN BRI DAUGHTER CARD',
|
|
8192 => 'BAYSTACK AN-TS 8MB,AN ISDN BRI DAUGHTER CARD',
|
|
16384 => 'BAYSTACK AN-TS 16MB,AN ISDN BRI DAUGHTER CARD',
|
|
},
|
|
1047 => {
|
|
4096 => 'BAYSTACK ANH-8 8MB',
|
|
8192 => 'BAYSTACK ANH-8 8MB',
|
|
16384 => 'BAYSTACK ANH-8 16MB',
|
|
},
|
|
1048 => {
|
|
4096 => 'BAYSTACK ANH-8 8MB,BAYSTACK ANH-8 N11 DCM',
|
|
8192 => 'BAYSTACK ANH-8 8MB,BAYSTACK ANH-8 N11 DCM',
|
|
16384 => 'BAYSTACK ANH-8 16MB,BAYSTACK ANH-8 N11 DCM',
|
|
},
|
|
1049 => {
|
|
4096 => 'BAYSTACK ANH-8 8MB,BAYSTACK ANH-8 3RD SYNC DAUGHTER CARD',
|
|
8192 => 'BAYSTACK ANH-8 8MB,BAYSTACK ANH-8 3RD SYNC DAUGHTER CARD',
|
|
16384 => 'BAYSTACK ANH-8 16MB,BAYSTACK ANH-8 3RD SYNC DAUGHTER CARD',
|
|
},
|
|
1050 => {
|
|
4096 => 'BAYSTACK ANH-8 8MB,BAYSTACK ANH-8 2ND ENET DAUGHTER CARD',
|
|
8192 => 'BAYSTACK ANH-8 8MB,BAYSTACK ANH-8 2ND ENET DAUGHTER CARD',
|
|
16384 => 'BAYSTACK ANH-8 16MB,BAYSTACK ANH-8 2ND ENET DAUGHTER CARD',
|
|
},
|
|
1051 => {
|
|
4096 => 'BAYSTACK ANH-8 8MB,BAYSTACK ANH-8 ISDN BRI DAUGHTER CARD',
|
|
8192 => 'BAYSTACK ANH-8 8MB,BAYSTACK ANH-8 ISDN BRI DAUGHTER CARD',
|
|
16384 => 'BAYSTACK ANH-8 16MB,BAYSTACK ANH-8 ISDN BRI DAUGHTER CARD',
|
|
},
|
|
1052 => {
|
|
4096 =>
|
|
'BAYSTACK ANH-8 8MB,BAYSTACK ANH-8 3RD SYNC DAUGHTER CARD,BAYSTACK ANH-8 N11 DCM',
|
|
8192 =>
|
|
'BAYSTACK ANH-8 8MB,BAYSTACK ANH-8 3RD SYNC DAUGHTER CARD,BAYSTACK ANH-8 N11 DCM',
|
|
16384 =>
|
|
'BAYSTACK ANH-8 16MB,BAYSTACK ANH-8 3RD SYNC DAUGHTER CARD,BAYSTACK ANH-8 N11 DCM',
|
|
},
|
|
1053 => {
|
|
4096 =>
|
|
'BAYSTACK ANH-8 8MB,BAYSTACK ANH-8 2ND ENET DAUGHTER CARD,BAYSTACK ANH-8 N11 DCM',
|
|
8192 =>
|
|
'BAYSTACK ANH-8 8MB,BAYSTACK ANH-8 2ND ENET DAUGHTER CARD,BAYSTACK ANH-8 N11 DCM',
|
|
16384 =>
|
|
'BAYSTACK ANH-8 16MB,BAYSTACK ANH-8 2ND ENET DAUGHTER CARD,BAYSTACK ANH-8 N11 DCM',
|
|
},
|
|
1054 => {
|
|
4096 =>
|
|
'BAYSTACK ANH-8 8MB,BAYSTACK ANH-8 ISDN BRI DAUGHTER CARD,BAYSTACK ANH-8 N11 DCM',
|
|
8192 =>
|
|
'BAYSTACK ANH-8 8MB,BAYSTACK ANH-8 ISDN BRI DAUGHTER CARD,BAYSTACK ANH-8 N11 DCM',
|
|
16384 =>
|
|
'BAYSTACK ANH-8 16MB,BAYSTACK ANH-8 ISDN BRI DAUGHTER CARD,BAYSTACK ANH-8 N11 DCM',
|
|
},
|
|
1055 => {
|
|
4096 => 'BAYSTACK AN-ES 8MB,BAYSTACK AN N11 DCM',
|
|
8192 => 'BAYSTACK AN-ES 8MB,BAYSTACK AN N11 DCM',
|
|
16384 => 'BAYSTACK AN-ES 16MB,BAYSTACK AN N11 DCM',
|
|
},
|
|
1056 => {
|
|
4096 =>
|
|
'BAYSTACK AN-ES 8MB,AN 3RD SYNC DAUGHTER CARD,BAYSTACK AN N11 DCM',
|
|
8192 =>
|
|
'BAYSTACK AN-ES 8MB,AN 3RD SYNC DAUGHTER CARD,BAYSTACK AN N11 DCM',
|
|
16384 =>
|
|
'BAYSTACK AN-ES 16MB,AN 3RD SYNC DAUGHTER CARD,BAYSTACK AN N11 DCM',
|
|
},
|
|
1057 => {
|
|
4096 =>
|
|
'BAYSTACK AN-ES 8MB,AN 2ND ENET DAUGHTER CARD,BAYSTACK AN N11 DCM',
|
|
8192 =>
|
|
'BAYSTACK AN-ES 8MB,AN 2ND ENET DAUGHTER CARD,BAYSTACK AN N11 DCM',
|
|
16384 =>
|
|
'BAYSTACK AN-ES 16MB,AN 2ND ENET DAUGHTER CARD,BAYSTACK AN N11 DCM',
|
|
},
|
|
1059 => {
|
|
4096 =>
|
|
'BAYSTACK AN-ETS 8MB,AN 3RD SYNC DAUGHTER CARD,BAYSTACK AN N11 DCM',
|
|
8192 =>
|
|
'BAYSTACK AN-ETS 8MB,AN 3RD SYNC DAUGHTER CARD,BAYSTACK AN N11 DCM',
|
|
16384 =>
|
|
'BAYSTACK AN-ETS 16MB,AN 3RD SYNC DAUGHTER CARD,BAYSTACK AN N11 DCM',
|
|
},
|
|
1062 => {
|
|
4096 =>
|
|
'BAYSTACK AN-ES 8MB,AN ISDN BRI DAUGHTER CARD,BAYSTACK AN N11 DCM',
|
|
8192 =>
|
|
'BAYSTACK AN-ES 8MB,AN ISDN BRI DAUGHTER CARD,BAYSTACK AN N11 DCM',
|
|
16384 =>
|
|
'BAYSTACK AN-ES 16MB,AN ISDN BRI DAUGHTER CARD,BAYSTACK AN N11 DCM',
|
|
},
|
|
1063 => {
|
|
4096 =>
|
|
'BAYSTACK AN-ETS 8MB,AN ISDN BRI DAUGHTER CARD,BAYSTACK AN N11 DCM',
|
|
8192 =>
|
|
'BAYSTACK AN-ETS 8MB,AN ISDN BRI DAUGHTER CARD,BAYSTACK AN N11 DCM',
|
|
16384 =>
|
|
'BAYSTACK AN-ETS 16MB,AN ISDN BRI DAUGHTER CARD,BAYSTACK AN N11 DCM',
|
|
},
|
|
1280 => 'DUAL ENET NET MODULE',
|
|
1536 => 'DUAL SYNC NET MODULE',
|
|
1537 => 'DUAL SYNC NET MODULE',
|
|
1538 => 'DUAL SYNC NET MODULE',
|
|
1540 => 'DUAL SYNC NET MODULE',
|
|
1541 => 'DUAL SYNC NET MODULE',
|
|
1542 => 'DUAL SYNC NET MODULE',
|
|
1544 => 'DUAL SYNC NET MODULE',
|
|
1545 => 'DUAL SYNC NET MODULE',
|
|
1546 => 'DUAL SYNC NET MODULE',
|
|
1584 => 'DUAL SYNC NET MODULE,ASN ISDN DAUGHTER CARD',
|
|
1585 => 'DUAL SYNC NET MODULE,ASN ISDN DAUGHTER CARD',
|
|
1586 => 'DUAL SYNC NET MODULE,ASN ISDN DAUGHTER CARD',
|
|
1588 => 'DUAL SYNC NET MODULE,ASN ISDN DAUGHTER CARD',
|
|
1589 => 'DUAL SYNC NET MODULE,ASN ISDN DAUGHTER CARD',
|
|
1590 => 'DUAL SYNC NET MODULE,ASN ISDN DAUGHTER CARD',
|
|
1592 => 'DUAL SYNC NET MODULE,ASN ISDN DAUGHTER CARD',
|
|
1593 => 'DUAL SYNC NET MODULE,ASN ISDN DAUGHTER CARD',
|
|
1594 => 'DUAL SYNC NET MODULE,ASN ISDN DAUGHTER CARD',
|
|
1793 => 'MUTLIMODE FDDI NET MODULE',
|
|
1801 => 'SINGLEMODE FDDI NET MODULE',
|
|
1825 => 'S.M. PHY A FDDI NET MODULE',
|
|
1833 => 'S.M. PHY B FDDI NET MODULE',
|
|
2048 => 'DUAL TOKEN NET MODULE',
|
|
2304 => '100 BASE-TX NET MODULE',
|
|
2560 => 'QUAD ISDN BRI NET MOD',
|
|
2816 => 'MCE1 NET MODULE',
|
|
3584 => 'SINGLE HSSI NET MODULE',
|
|
4098 => 'ATM LINK - OC3 MULTIMODE',
|
|
4099 => 'ATM LINK - OC3 SINGLEMODE',
|
|
4352 => 'OCTAL SYNC LINK MODULE',
|
|
4353 =>
|
|
'OCTAL SYNC LINK MODULE,32 CONTEXTS HARDWARE COMPRESSION DGHTR. CARD',
|
|
4354 =>
|
|
'OCTAL SYNC LINK MODULE,128 CONTEXTS HARDWARE COMPRESSION DGHTR. CARD',
|
|
4608 => 'SONET/SDH MMF LINK',
|
|
4609 => 'SONET/SDH SMF LINK',
|
|
4864 => '100 BASE-Tx ETHERNET',
|
|
5376 => 'QUAD PORT MULTICHANNEL T1 (QMCT1) RJ48',
|
|
5377 => 'QUAD PORT MULTICHANNEL T1 (QMCT1) DB15',
|
|
5378 => 'QUAD PORT MULTICHANNEL T1 DS0A (QMCT1 w/DS0A) DB15',
|
|
6144 => '4-PORT 10/100BASE-TX',
|
|
6145 => '4-PORT 100BASE-FX',
|
|
6400 => '1000BASE-SX',
|
|
6401 => '1000BASE-LX',
|
|
8448 => 'SRM-L',
|
|
8704 => 'ARN Motherboard Single Token Ring',
|
|
8720 => 'ARN Motherboard Single Ethernet',
|
|
8728 => 'ARN Motherboard Single 10/100BASE-TX',
|
|
8729 => 'ARN Motherboard Single 10/100BASE-FX',
|
|
8736 => 'ARN Serial Adapter Module',
|
|
8752 => 'ARN V.34 Modem Adapter Module',
|
|
8768 => 'ARN 56/64 DSU/CSU Adapter Module',
|
|
8784 => 'ARN ISDN BRI S/T Adapter Module',
|
|
8800 => 'ARN ISDN BRI U Adapter Module',
|
|
8816 => 'ARN Token Ring Expansion Module',
|
|
8832 => 'ARN Ethernet Expansion Module',
|
|
8848 => 'ARN Tri Serial Expansion Module',
|
|
8864 => 'ARN Ethernet and Tri-Serial Expansion Module',
|
|
8880 => 'ARN Token Ring and Tri-Serial Expansion Module',
|
|
8896 => 'arnmbenx10',
|
|
8912 => 'arnmbtrx10',
|
|
8928 => 'arnpbenx10',
|
|
8944 => 'arnpbtrx10',
|
|
8960 => 'arnpbtenx10',
|
|
8976 => 'arnpbttrx10',
|
|
);
|
|
|
|
%PROCID_MAP = (
|
|
1 => 'SYSTEM CONTROLLER',
|
|
2 => '5MEG ACE25',
|
|
3 => {
|
|
5120 => '5MEG ACE25',
|
|
8192 => '8MEG ACE25',
|
|
},
|
|
4 => {
|
|
4096 => 'ACE32',
|
|
8192 => '8MEG ACE32',
|
|
16384 => '16MEG ACE32',
|
|
},
|
|
5 => 'AFN',
|
|
6 => 'LN',
|
|
7 => 'FLASH SYSTEM CTRL.',
|
|
16384 => 'AN',
|
|
32 => {
|
|
4096 => 'ARN Ethernet - 4 MEG',
|
|
8192 => 'ARN Ethernet - 8 MEG',
|
|
16384 => 'ARN Ethernet - 16 MEG',
|
|
32768 => 'ARN Ethernet - 32 MEG',
|
|
},
|
|
256 => 'FAST ROUTING ENGINE',
|
|
768 => {
|
|
8192 => 'FRE2 - 8MEG',
|
|
16384 => 'FRE2 - 16MEG',
|
|
24576 => 'FRE2 - 24MEG',
|
|
32768 => 'FRE2 - 32MEG',
|
|
},
|
|
769 => {
|
|
8192 => 'FRE2 060 - 8MEG',
|
|
16384 => 'FRE2 060 - 16MEG',
|
|
32768 => 'FRE2 060 - 32MEG',
|
|
65536 => 'FRE2 060 - 64MEG',
|
|
},
|
|
1024 => {
|
|
8192 => 'ASN MOTHER BOARD - 8MB,ASN TRAY / POWER SUPPLY ASSEMBLY',
|
|
16384 => 'ASN MOTHER BOARD - 16MB,ASN TRAY / POWER SUPPLY ASSEMBLY',
|
|
32768 => 'ASN MOTHER BOARD - 32MB,ASN TRAY / POWER SUPPLY ASSEMBLY',
|
|
},
|
|
1025 => {
|
|
8192 => 'ASN2 MOTHER BOARD - 8MB,ASN TRAY / POWER SUPPLY ASSEMBLY',
|
|
16384 => 'ASN2 MOTHER BOARD - 16MB,ASN TRAY / POWER SUPPLY ASSEMBLY',
|
|
32768 => 'ASN2 MOTHER BOARD - 32MB,ASN TRAY / POWER SUPPLY ASSEMBLY',
|
|
},
|
|
1280 => {
|
|
9216 => 'ARE - 8MB DRAM & 1MB VBM',
|
|
19456 => 'ARE - 16MB DRAM & 3MB VBM',
|
|
38912 => 'ARE -32MB DRAM & 6MB VBM',
|
|
71680 => 'ARE -64MB DRAM & 6MB VBM',
|
|
},
|
|
8704 => 'SRM-F',
|
|
1536 => 'ARE5000',
|
|
1792 => 'ASN500',
|
|
6656 => {
|
|
49152 => 'FRE4-PPC - 32MEG',
|
|
81920 => 'FRE4-PPC - 64MEG',
|
|
147456 => 'FRE4-PPC - 128MEG',
|
|
},
|
|
);
|
|
|
|
sub model {
|
|
my $bayrs = shift;
|
|
my $bp_id = $bayrs->bp_id();
|
|
|
|
return defined $MODEL_MAP{$bp_id} ? $MODEL_MAP{$bp_id} : $bp_id;
|
|
}
|
|
|
|
sub vendor {
|
|
return 'avaya';
|
|
}
|
|
|
|
sub os {
|
|
return 'bayrs';
|
|
}
|
|
|
|
sub os_ver {
|
|
my $bayrs = shift;
|
|
my $descr = $bayrs->description();
|
|
return unless defined $descr;
|
|
|
|
if ( $descr =~ m/^\s*Image:\s+re[lv]\/((\d+\.){1,3}\d+)/ ) {
|
|
return $1;
|
|
}
|
|
return;
|
|
}
|
|
|
|
sub serial {
|
|
my $bayrs = shift;
|
|
my $serialnum = $bayrs->bp_serial();
|
|
$serialnum = hex(
|
|
join( '',
|
|
'0x', map { sprintf "%02X", $_ } unpack( "C*", $serialnum ) )
|
|
);
|
|
|
|
return $serialnum if defined $serialnum;
|
|
return;
|
|
}
|
|
|
|
sub interfaces {
|
|
my $bayrs = shift;
|
|
my $description = $bayrs->i_description();
|
|
my $vlan_ids = $bayrs->wf_global_vlan_id();
|
|
my $vlan_idx = $bayrs->wf_local_vlan_id();
|
|
|
|
my %interfaces = ();
|
|
foreach my $iid ( keys %$description ) {
|
|
my $desc = $description->{$iid};
|
|
next unless defined $desc;
|
|
|
|
$desc = $1 if $desc =~ /(^[A-Z]\d+)/;
|
|
|
|
$interfaces{$iid} = $desc;
|
|
}
|
|
foreach my $iid ( keys %$vlan_ids ) {
|
|
my $vlan = $vlan_ids->{$iid};
|
|
next unless defined $vlan;
|
|
my $vlan_if = $vlan_idx->{$iid};
|
|
next unless defined $vlan_if;
|
|
|
|
my $desc = 'Vlan' . $vlan;
|
|
|
|
$interfaces{$vlan_if} = $desc;
|
|
}
|
|
return \%interfaces;
|
|
}
|
|
|
|
sub i_name {
|
|
my $bayrs = shift;
|
|
my $i_index = $bayrs->i_index();
|
|
my $description = $bayrs->i_description();
|
|
my $v_name = $bayrs->wf_vlan_name();
|
|
my $vlan_idx = $bayrs->wf_local_vlan_id();
|
|
|
|
my %i_name;
|
|
foreach my $iid ( keys %$description ) {
|
|
my $name = $description->{$iid};
|
|
next unless defined $name;
|
|
$i_name{$iid} = $name;
|
|
}
|
|
|
|
# Get VLAN Virtual Router Interfaces
|
|
foreach my $vid ( keys %$v_name ) {
|
|
my $v_name = $v_name->{$vid};
|
|
next unless defined $v_name;
|
|
my $vlan_if = $vlan_idx->{$vid};
|
|
next unless defined $vlan_if;
|
|
|
|
$i_name{$vlan_if} = $v_name;
|
|
}
|
|
return \%i_name;
|
|
}
|
|
|
|
sub i_duplex {
|
|
my $bayrs = shift;
|
|
|
|
my $wf_cct = $bayrs->wf_csmacd_cct();
|
|
my $wf_duplex = $bayrs->wf_duplex();
|
|
|
|
my %i_duplex;
|
|
foreach my $if ( keys %$wf_cct ) {
|
|
my $idx = $wf_cct->{$if};
|
|
next unless defined $idx;
|
|
my $duplex = $wf_duplex->{$if};
|
|
next unless defined $duplex;
|
|
|
|
my $string = 'half';
|
|
$string = 'full' if $duplex =~ /duplex/i;
|
|
|
|
$i_duplex{$idx} = $string;
|
|
}
|
|
return \%i_duplex;
|
|
}
|
|
|
|
sub i_duplex_admin {
|
|
my $bayrs = shift;
|
|
|
|
my $wf_cct = $bayrs->wf_csmacd_cct();
|
|
my $wf_duplex = $bayrs->wf_duplex();
|
|
my $wf_auto = $bayrs->wf_auto();
|
|
my $wf_slot = $bayrs->wf_csmacd_slot();
|
|
my $wf_conn = $bayrs->wf_csmacd_conn();
|
|
|
|
my %i_duplex_admin;
|
|
foreach my $if ( keys %$wf_cct ) {
|
|
my $idx = $wf_cct->{$if};
|
|
next unless defined $idx;
|
|
my $duplex = $wf_duplex->{$if};
|
|
next unless defined $duplex;
|
|
my $slot = $wf_slot->{$if};
|
|
my $conn = $wf_conn->{$if};
|
|
my $auto_idx = "$slot.$conn";
|
|
my $auto = $wf_auto->{$auto_idx};
|
|
|
|
my $string = 'other';
|
|
if ($auto) {
|
|
$string = 'half';
|
|
$string = 'full' if $auto =~ /duplex/i;
|
|
$string = 'auto' if $auto =~ /nway/i;
|
|
}
|
|
elsif ($duplex) {
|
|
$string = 'half';
|
|
$string = 'full' if $duplex =~ /duplex/i;
|
|
}
|
|
|
|
$i_duplex_admin{$idx} = $string;
|
|
}
|
|
return \%i_duplex_admin;
|
|
}
|
|
|
|
sub i_vlan {
|
|
my $bayrs = shift;
|
|
|
|
my $wf_cct = $bayrs->wf_csmacd_cct();
|
|
my $wf_mtu = $bayrs->wf_csmacd_mtu();
|
|
my $wf_line = $bayrs->wf_csmacd_line();
|
|
my $wf_local_vid = $bayrs->wf_local_vlan_id();
|
|
my $wf_global_vid = $bayrs->wf_global_vlan_id();
|
|
my $wf_vport = $bayrs->wf_vlan_port();
|
|
|
|
my %i_vlan;
|
|
|
|
# Look for VLANs on Ethernet Interfaces
|
|
foreach my $if ( keys %$wf_cct ) {
|
|
my $idx = $wf_cct->{$if};
|
|
next unless defined $idx;
|
|
|
|
# Check MTU size, if unable to carry VLAN tag skip.
|
|
my $mtu = $wf_mtu->{$if};
|
|
next if ( ( $mtu =~ /default/i ) or ( $mtu < 1522 ) );
|
|
my $line = $wf_line->{$if};
|
|
my @vlans = ();
|
|
foreach my $v_idx ( keys %$wf_vport ) {
|
|
my $port = $wf_vport->{$v_idx};
|
|
next unless defined $port;
|
|
next if ( $port != $line );
|
|
|
|
my $vlan = $wf_global_vid->{$v_idx};
|
|
push( @vlans, $vlan );
|
|
}
|
|
my $vlans = join( ',', @vlans );
|
|
$i_vlan{$idx} = $vlans;
|
|
}
|
|
|
|
# Add VLAN on VLAN Interfaces
|
|
foreach my $idx ( keys %$wf_global_vid ) {
|
|
my $v_if = $wf_local_vid->{$idx};
|
|
next unless defined $v_if;
|
|
my $vlan = $wf_global_vid->{$idx};
|
|
next unless defined $vlan;
|
|
|
|
$i_vlan{$v_if} = $vlan;
|
|
}
|
|
return \%i_vlan;
|
|
}
|
|
|
|
sub i_pvid { goto &i_vlan }
|
|
|
|
sub root_ip {
|
|
my $bayrs = shift;
|
|
|
|
my $ip_index = $bayrs->ip_index();
|
|
my $ip_table = $bayrs->ip_table();
|
|
|
|
# Check for CLIP
|
|
foreach my $entry ( keys %$ip_index ) {
|
|
my $idx = $ip_index->{$entry};
|
|
next unless $idx == 0;
|
|
my $clip = $ip_table->{$entry};
|
|
next
|
|
unless ( ( defined $clip )
|
|
and ( $clip ne '0.0.0.0' )
|
|
and ( $bayrs->snmp_connect_ip($clip) ) );
|
|
print " SNMP::Layer3::BayRS::root_ip() using $clip\n"
|
|
if $bayrs->debug();
|
|
return $clip;
|
|
}
|
|
|
|
# Check for OSPF Router ID
|
|
my $ospf_ip = $bayrs->ospf_rtr_id();
|
|
if ( ( defined $ospf_ip )
|
|
and ( $ospf_ip ne '0.0.0.0' )
|
|
and ( $bayrs->snmp_connect_ip($ospf_ip) ) )
|
|
{
|
|
print " SNMP::Layer3::BayRS::root_ip() using $ospf_ip\n"
|
|
if $bayrs->debug();
|
|
return $ospf_ip;
|
|
}
|
|
|
|
return;
|
|
}
|
|
|
|
# Pseudo ENTITY-MIB methods
|
|
|
|
sub e_index {
|
|
my $bayrs = shift;
|
|
|
|
my $bp_id = $bayrs->bp_id();
|
|
|
|
# Don't like polling all these columns to build the index, can't think of
|
|
# a better way right now. Luckly all this data will be cached for the
|
|
# rest of the e_* methods
|
|
|
|
# Using mib leafs so we don't have to define everything in FUNCS
|
|
|
|
# Processor - All models should support these
|
|
my $wf_mb = $bayrs->wfHwMotherBdIdOpt() || {};
|
|
my $wf_db = $bayrs->wfHwDaughterBdIdOpt() || {};
|
|
my $wf_bb = $bayrs->wfHwBabyBdIdOpt() || {};
|
|
|
|
my ( $wf_mod, $wf_mod1, $wf_mod2, $wf_mm, $wf_dm ) = {};
|
|
|
|
# Only query objects we need
|
|
# Link Module
|
|
if ( $bp_id !~ /arn|asn/ ) {
|
|
$wf_mod = $bayrs->wfHwModIdOpt() || {};
|
|
$wf_mod1 = $bayrs->wfHwModDaughterBd1IdOpt() || {};
|
|
$wf_mod2 = $bayrs->wfHwModDaughterBd2IdOpt() || {};
|
|
}
|
|
|
|
# Hardware Module
|
|
if ( $bp_id =~ /arn|asn/ ) {
|
|
$wf_mm = $bayrs->wfHwModuleModIdOpt() || {};
|
|
$wf_dm = $bayrs->wfHwModuleDaughterBdIdOpt() || {};
|
|
}
|
|
|
|
my @slots = ( $wf_mb, $wf_db, $wf_bb, $wf_mod, $wf_mod1, $wf_mod2 );
|
|
my @mods = ( $wf_mm, $wf_dm );
|
|
|
|
# We're going to hack an index: Slot/Module/Postion
|
|
my %wf_e_index;
|
|
|
|
# Chassis on BN types
|
|
if ( $bp_id !~ /an|arn|asn/ ) {
|
|
$wf_e_index{1} = 1;
|
|
}
|
|
|
|
# Handle Processor / Link Modules first
|
|
foreach my $idx ( keys %$wf_mb ) {
|
|
my $index = "$idx" . "0000";
|
|
unless ( $bp_id =~ /an|arn|asn/ ) {
|
|
$wf_e_index{$index} = $index;
|
|
}
|
|
foreach my $slot (@slots) {
|
|
$index++;
|
|
$wf_e_index{$index} = $index if $slot->{$idx};
|
|
}
|
|
}
|
|
|
|
# Handle Hardware Modules
|
|
foreach my $iid ( keys %$wf_mm ) {
|
|
my $main_mod = $wf_mm->{$iid};
|
|
next unless $main_mod;
|
|
my $index = join( '', map { sprintf "%02d", $_ } split /\./, $iid );
|
|
$index = "$index" . "00";
|
|
$wf_e_index{$index} = $index;
|
|
foreach my $mod (@mods) {
|
|
$index++;
|
|
$wf_e_index{$index} = $index if $mod->{$iid};
|
|
}
|
|
}
|
|
return \%wf_e_index;
|
|
}
|
|
|
|
sub e_class {
|
|
my $bayrs = shift;
|
|
|
|
my $bp_id = $bayrs->bp_id();
|
|
|
|
my $wf_e_idx = $bayrs->e_index() || {};
|
|
|
|
my %wf_e_class;
|
|
foreach my $iid ( keys %$wf_e_idx ) {
|
|
if ( $iid == 1 ) {
|
|
$wf_e_class{$iid} = 'chassis';
|
|
}
|
|
elsif ( $bp_id =~ /an|arn|asn/ and $iid == '10001' ) {
|
|
$wf_e_class{$iid} = 'chassis';
|
|
}
|
|
elsif ( $iid =~ /(00){1,2}$/ ) {
|
|
$wf_e_class{$iid} = 'container';
|
|
}
|
|
else {
|
|
$wf_e_class{$iid} = 'module';
|
|
}
|
|
}
|
|
return \%wf_e_class;
|
|
}
|
|
|
|
sub e_name {
|
|
my $bayrs = shift;
|
|
|
|
my $bp_id = $bayrs->bp_id();
|
|
my $wf_e_idx = $bayrs->e_index() || {};
|
|
|
|
my %wf_e_name;
|
|
|
|
# Chassis
|
|
foreach my $iid ( keys %$wf_e_idx ) {
|
|
if ( $iid == 1 ) {
|
|
$wf_e_name{$iid} = 'Router';
|
|
next;
|
|
}
|
|
|
|
my $pos = substr( $iid, -1 );
|
|
my $sub = substr( $iid, -4, 2 );
|
|
$sub =~ s/^0//;
|
|
my $slot = substr( $iid, -6, 2 );
|
|
$slot =~ s/^0//;
|
|
|
|
if ( $bp_id =~ /an|arn|asn/ and $iid == '10001' ) {
|
|
$wf_e_name{$iid} = 'Router';
|
|
}
|
|
elsif ( $iid =~ /(00){2}$/ ) {
|
|
$wf_e_name{$iid} = "Slot $slot";
|
|
}
|
|
elsif ( $iid =~ /(00){1}$/ and $bp_id =~ /asn/ ) {
|
|
$wf_e_name{$iid} = "Module Container $slot $sub";
|
|
}
|
|
elsif ( $iid =~ /(00){1}$/ and $bp_id =~ /an|arn/ ) {
|
|
$sub--;
|
|
if ( $sub == 0 ) {
|
|
$wf_e_name{$iid} = "Motherboard Container";
|
|
}
|
|
else {
|
|
$wf_e_name{$iid} = "Module Container $sub";
|
|
}
|
|
}
|
|
elsif ( $bp_id !~ /an|arn|asn/ and $iid =~ /1$/ ) {
|
|
$wf_e_name{$iid} = "Processor Slot $slot";
|
|
}
|
|
elsif ( $bp_id =~ /asn/ and $iid =~ /1$/ ) {
|
|
$wf_e_name{$iid} = "Module $slot $sub";
|
|
}
|
|
elsif ( $bp_id =~ /an|arn/ and $iid =~ /1$/ ) {
|
|
$sub--;
|
|
if ( $sub == 0 ) {
|
|
$wf_e_name{$iid} = "Motherboard";
|
|
}
|
|
else {
|
|
$wf_e_name{$iid} = "Module $sub";
|
|
}
|
|
}
|
|
elsif ( $bp_id !~ /asn/ and $iid =~ /2$/ ) {
|
|
$wf_e_name{$iid} = "Processor Daughter Board Slot $slot";
|
|
}
|
|
elsif ( $bp_id !~ /an|arn/ and $iid =~ /2$/ ) {
|
|
$wf_e_name{$iid} = "Processor Daughter Board";
|
|
}
|
|
elsif ( $bp_id =~ /asn/ and $iid =~ /2$/ ) {
|
|
$wf_e_name{$iid} = "Module Daughter Board $slot $sub";
|
|
}
|
|
elsif ( $bp_id =~ /an|arn/ and $iid =~ /2$/ ) {
|
|
$sub--;
|
|
$wf_e_name{$iid} = "Module Daughter Board $sub";
|
|
}
|
|
elsif ( $iid =~ /3$/ ) {
|
|
$wf_e_name{$iid} = "Processor Baby Board Slot $slot";
|
|
}
|
|
elsif ( $iid =~ /4$/ ) {
|
|
$wf_e_name{$iid} = "Link Module Slot $slot";
|
|
}
|
|
elsif ( $iid =~ /5$/ ) {
|
|
$wf_e_name{$iid} = "Link Module Daughter Board 1 Slot $slot";
|
|
}
|
|
elsif ( $iid =~ /6$/ ) {
|
|
$wf_e_name{$iid} = "Link Module Daughter Board 2 Slot $slot";
|
|
}
|
|
else {
|
|
next;
|
|
}
|
|
}
|
|
return \%wf_e_name;
|
|
}
|
|
|
|
sub e_descr {
|
|
my $bayrs = shift;
|
|
|
|
my $bp_id = $bayrs->bp_id();
|
|
|
|
# Using mib leafs so we don't have to define everything in FUNCS
|
|
# We only have descriptions for the processors and modules
|
|
# Processor
|
|
my $wf_mb = $bayrs->wfHwMotherBdIdOpt() || {};
|
|
my $wf_mb_mem = $bayrs->wfHwMotherBdMemorySize() || {};
|
|
|
|
my ( $wf_mod, $wf_mm ) = {};
|
|
|
|
# Link Module
|
|
if ( $bp_id !~ /arn|asn/ ) {
|
|
$wf_mod = $bayrs->wfHwModIdOpt() || {};
|
|
}
|
|
|
|
# Hardware Module
|
|
if ( $bp_id =~ /arn|asn/ ) {
|
|
$wf_mm = $bayrs->wfHwModuleModIdOpt() || {};
|
|
}
|
|
|
|
my %wf_e_descr;
|
|
|
|
# Chassis
|
|
if ( $bp_id !~ /an|arn|asn/ ) {
|
|
$wf_e_descr{1} = $bayrs->model();
|
|
}
|
|
|
|
# Handle Processor / Link Modules first
|
|
foreach my $idx ( keys %$wf_mb ) {
|
|
unless ( $bp_id =~ /an|arn|asn/ ) {
|
|
$wf_e_descr{ "$idx" . "0000" } = 'Slot ' . $idx;
|
|
}
|
|
my $mb_id;
|
|
$mb_id = &SNMP::mapEnum( 'wfHwMotherBdIdOpt', $wf_mb->{$idx} )
|
|
if $wf_mb->{$idx};
|
|
my $mb_mem = $wf_mb_mem->{$idx};
|
|
my $mod_id;
|
|
$mod_id = &SNMP::mapEnum( 'wfHwModIdOpt', $wf_mod->{$idx} )
|
|
if $wf_mod->{$idx};
|
|
|
|
# Processor
|
|
if ($mb_id) {
|
|
if ( ref( $PROCID_MAP{$mb_id} ) =~ /HASH/ ) {
|
|
$wf_e_descr{ "$idx" . "0001" }
|
|
= defined $PROCID_MAP{$mb_id}{$mb_mem}
|
|
? $PROCID_MAP{$mb_id}{$mb_mem}
|
|
: $mb_id;
|
|
}
|
|
else {
|
|
$wf_e_descr{ "$idx" . "0001" }
|
|
= defined $PROCID_MAP{$mb_id}
|
|
? $PROCID_MAP{$mb_id}
|
|
: $mb_id;
|
|
}
|
|
}
|
|
|
|
# Link Module
|
|
if ($mod_id) {
|
|
if ( ref( $MODID_MAP{$mod_id} ) =~ /HASH/ ) {
|
|
$wf_e_descr{ "$idx" . "0004" }
|
|
= defined $MODID_MAP{$mod_id}{$mb_mem}
|
|
? $MODID_MAP{$mod_id}{$mb_mem}
|
|
: $mod_id;
|
|
}
|
|
else {
|
|
$wf_e_descr{ "$idx" . "0004" }
|
|
= defined $MODID_MAP{$mod_id}
|
|
? $MODID_MAP{$mod_id}
|
|
: $mod_id;
|
|
}
|
|
}
|
|
}
|
|
|
|
# Handle Hardware Modules
|
|
foreach my $iid ( keys %$wf_mm ) {
|
|
next unless ( $wf_mm->{$iid} );
|
|
my $idx = join( '', map { sprintf "%02d", $_ } split /\./, $iid );
|
|
my ( $slot, $mod ) = split /\./, $iid;
|
|
if ( $bp_id =~ /an|arn/ ) {
|
|
$mod--;
|
|
if ( $mod == 0 ) {
|
|
$wf_e_descr{ "$idx" . "00" } = "Motherboard Container";
|
|
}
|
|
else {
|
|
$wf_e_descr{ "$idx" . "00" } = "Module Container $mod";
|
|
}
|
|
}
|
|
else {
|
|
$wf_e_descr{ "$idx" . "00" } = "Module Container $slot $mod";
|
|
}
|
|
my $mm_id = &SNMP::mapEnum( 'wfHwModuleModIdOpt', $wf_mm->{$iid} );
|
|
my $index = join( '', map { sprintf "%02d", $_ } split /\./, $iid );
|
|
$wf_e_descr{ "$index" . "01" }
|
|
= defined $MODID_MAP{$mm_id} ? $MODID_MAP{$mm_id} : $mm_id;
|
|
}
|
|
return \%wf_e_descr;
|
|
}
|
|
|
|
sub e_type {
|
|
my $bayrs = shift;
|
|
|
|
my $bp_id = $bayrs->bp_id();
|
|
|
|
# Using mib leafs so we don't have to define everything in FUNCS
|
|
# Processor
|
|
my $wf_mb = $bayrs->wfHwMotherBdIdOpt() || {};
|
|
my $wf_db = $bayrs->wfHwDaughterBdIdOpt() || {};
|
|
my $wf_bb = $bayrs->wfHwBabyBdIdOpt() || {};
|
|
|
|
my ( $wf_mod, $wf_mod1, $wf_mod2, $wf_mm, $wf_dm ) = {};
|
|
|
|
# Link Module
|
|
if ( $bp_id !~ /arn|asn/ ) {
|
|
$wf_mod = $bayrs->wfHwModIdOpt() || {};
|
|
$wf_mod1 = $bayrs->wfHwModDaughterBd1IdOpt() || {};
|
|
$wf_mod2 = $bayrs->wfHwModDaughterBd2IdOpt() || {};
|
|
}
|
|
|
|
# Hardware Module
|
|
if ( $bp_id =~ /arn|asn/ ) {
|
|
$wf_mm = $bayrs->wfHwModuleModIdOpt() || {};
|
|
$wf_dm = $bayrs->wfHwModuleDaughterBdIdOpt() || {};
|
|
}
|
|
|
|
my @slots = ( $wf_mb, $wf_db, $wf_bb, $wf_mod, $wf_mod1, $wf_mod2 );
|
|
my @mods = ( $wf_mm, $wf_dm );
|
|
|
|
my %wf_e_type;
|
|
|
|
# Chassis
|
|
if ( $bp_id !~ /an|arn|asn/ ) {
|
|
$wf_e_type{1} = $bayrs->bp_id();
|
|
}
|
|
|
|
# Handle Processor / Link Modules first
|
|
foreach my $idx ( keys %$wf_mb ) {
|
|
my $index = "$idx" . "0000";
|
|
unless ( $bp_id =~ /an|arn|asn/ ) {
|
|
$wf_e_type{$index} = "zeroDotZero";
|
|
}
|
|
foreach my $slot (@slots) {
|
|
$index++;
|
|
$wf_e_type{$index} = $slot->{$idx} if $slot->{$idx};
|
|
}
|
|
}
|
|
|
|
# Handle Hardware Modules
|
|
foreach my $iid ( keys %$wf_mm ) {
|
|
my $main_mod = $wf_mm->{$iid};
|
|
next unless $main_mod;
|
|
my $index = join( '', map { sprintf "%02d", $_ } split /\./, $iid );
|
|
$index = "$index" . "00";
|
|
$wf_e_type{$index} = "zeroDotZero";
|
|
foreach my $mod (@mods) {
|
|
$index++;
|
|
$wf_e_type{$index} = $mod->{$iid} if $mod->{$iid};
|
|
}
|
|
}
|
|
return \%wf_e_type;
|
|
}
|
|
|
|
sub e_hwver {
|
|
my $bayrs = shift;
|
|
|
|
my $bp_id = $bayrs->bp_id();
|
|
|
|
# Using mib leafs so we don't have to define everything in FUNCS
|
|
# Processor
|
|
my $wf_mb = $bayrs->wfHwMotherBdRev() || {};
|
|
my $wf_db = $bayrs->wfHwDaughterBdRev() || {};
|
|
my $wf_bb = $bayrs->wfHwBabyBdRev() || {};
|
|
|
|
my ( $wf_mod, $wf_mod1, $wf_mod2, $wf_mm ) = {};
|
|
|
|
# Link Module
|
|
if ( $bp_id !~ /arn|asn/ ) {
|
|
$wf_mod = $bayrs->wfHwModRev() || {};
|
|
$wf_mod1 = $bayrs->wfHwModDaughterBd1Rev() || {};
|
|
$wf_mod2 = $bayrs->wfHwModDaughterBd2Rev() || {};
|
|
}
|
|
|
|
# Hardware Module
|
|
if ( $bp_id =~ /arn|asn/ ) {
|
|
$wf_mm = $bayrs->wfHwModuleModRev() || {};
|
|
}
|
|
|
|
my @slots = ( $wf_mb, $wf_db, $wf_bb, $wf_mod, $wf_mod1, $wf_mod2 );
|
|
|
|
my %wf_e_hwver;
|
|
|
|
# Chassis
|
|
if ( $bp_id !~ /an|arn|asn/ ) {
|
|
my $bp_rev = $bayrs->wfHwBpRev();
|
|
$bp_rev = hex(
|
|
join( '',
|
|
'0x', map { sprintf "%02X", $_ } unpack( "C*", $bp_rev ) )
|
|
);
|
|
|
|
$wf_e_hwver{1} = $bp_rev;
|
|
}
|
|
|
|
# Handle Processor / Link Modules first
|
|
foreach my $idx ( keys %$wf_mb ) {
|
|
my $index = "$idx" . "0000";
|
|
foreach my $slot (@slots) {
|
|
$index++;
|
|
next unless ( $slot->{$idx} );
|
|
my $mod;
|
|
$mod = hex(
|
|
join( '',
|
|
'0x',
|
|
map { sprintf "%02X", $_ } unpack( "C*", $slot->{$idx} ) )
|
|
) if $slot->{$idx};
|
|
$wf_e_hwver{$index} = $mod if $mod;
|
|
}
|
|
}
|
|
foreach my $iid ( keys %$wf_mm ) {
|
|
my $index = join( '', map { sprintf "%02d", $_ } split /\./, $iid );
|
|
my $mod;
|
|
$mod = hex(
|
|
join( '',
|
|
'0x',
|
|
map { sprintf "%02X", $_ } unpack( "C*", $wf_mm->{$iid} ) )
|
|
) if $wf_mm->{$iid};
|
|
$index = "$index" . "00";
|
|
$index++;
|
|
next unless ( $wf_mm->{$iid} );
|
|
$wf_e_hwver{$index} = $mod if $mod;
|
|
}
|
|
return \%wf_e_hwver;
|
|
}
|
|
|
|
sub e_vendor {
|
|
my $bayrs = shift;
|
|
|
|
my $wf_e_idx = $bayrs->e_index() || {};
|
|
|
|
my %wf_e_vendor;
|
|
foreach my $iid ( keys %$wf_e_idx ) {
|
|
$wf_e_vendor{$iid} = 'avaya';
|
|
}
|
|
return \%wf_e_vendor;
|
|
}
|
|
|
|
sub e_serial {
|
|
my $bayrs = shift;
|
|
|
|
my $bp_id = $bayrs->bp_id();
|
|
|
|
# Processor
|
|
my $wf_mb = $bayrs->wf_hw_mobo_ser() || {};
|
|
my $wf_db = $bayrs->wf_hw_db_ser() || {};
|
|
my $wf_bb = $bayrs->wf_hw_bb_ser() || {};
|
|
|
|
my ( $wf_mod, $wf_mod1, $wf_mod2, $wf_mm ) = {};
|
|
|
|
# Link Module
|
|
if ( $bp_id !~ /arn|asn/ ) {
|
|
$wf_mod = $bayrs->wf_hw_mod_ser() || {};
|
|
$wf_mod1 = $bayrs->wf_hw_md1_ser() || {};
|
|
$wf_mod2 = $bayrs->wf_hw_md2_ser() || {};
|
|
}
|
|
|
|
# Hardware Module
|
|
if ( $bp_id =~ /arn|asn/ ) {
|
|
$wf_mm = $bayrs->wf_hw_mm_ser() || {};
|
|
}
|
|
|
|
my @slots = ( $wf_mb, $wf_db, $wf_bb, $wf_mod, $wf_mod1, $wf_mod2 );
|
|
|
|
my %wf_e_serial;
|
|
|
|
# Chassis
|
|
if ( $bp_id !~ /an|arn|asn/ ) {
|
|
$wf_e_serial{1} = $bayrs->serial();
|
|
}
|
|
|
|
# Handle Processor / Link Modules first
|
|
foreach my $idx ( keys %$wf_mb ) {
|
|
my $index = "$idx" . "0000";
|
|
foreach my $slot (@slots) {
|
|
$index++;
|
|
my $mod = $slot->{$idx};
|
|
next unless ($mod);
|
|
$wf_e_serial{$index} = $mod if $mod;
|
|
}
|
|
}
|
|
|
|
# Handle Hardware Modules
|
|
foreach my $iid ( keys %$wf_mm ) {
|
|
my $index = join( '', map { sprintf "%02d", $_ } split /\./, $iid );
|
|
my $mod = $wf_mm->{$iid};
|
|
$index = "$index" . "00";
|
|
$index++;
|
|
next unless ($mod);
|
|
$wf_e_serial{$index} = $mod if $mod;
|
|
}
|
|
return \%wf_e_serial;
|
|
}
|
|
|
|
sub e_pos {
|
|
my $bayrs = shift;
|
|
|
|
my $wf_e_idx = $bayrs->e_index() || {};
|
|
my $bp_id = $bayrs->bp_id();
|
|
|
|
my %wf_e_pos;
|
|
foreach my $iid ( keys %$wf_e_idx ) {
|
|
if ( $iid == 1 ) {
|
|
$wf_e_pos{$iid} = -1;
|
|
next;
|
|
}
|
|
|
|
my $pos = substr( $iid, -1 );
|
|
my $sub = substr( $iid, -4, 2 );
|
|
my $slot = substr( $iid, -6, 2 );
|
|
|
|
if ( $bp_id =~ /an|arn|asn/ and $iid == '10001' ) {
|
|
$wf_e_pos{$iid} = -1;
|
|
}
|
|
elsif ( $iid =~ /(00){2}$/ ) {
|
|
$wf_e_pos{$iid} = $slot;
|
|
}
|
|
elsif ( $iid =~ /(00){1}$/ ) {
|
|
$wf_e_pos{$iid} = $sub;
|
|
}
|
|
else {
|
|
$wf_e_pos{$iid} = $pos;
|
|
}
|
|
}
|
|
return \%wf_e_pos;
|
|
}
|
|
|
|
sub e_fwver {
|
|
my $bayrs = shift;
|
|
|
|
# Only on Processor
|
|
my $wf_mb = $bayrs->wf_hw_boot() || {};
|
|
my %wf_e_hwver;
|
|
foreach my $idx ( keys %$wf_mb ) {
|
|
my $fw = $wf_mb->{$idx};
|
|
next unless $fw;
|
|
|
|
$wf_e_hwver{ "$idx" . "0001" } = $fw;
|
|
}
|
|
return \%wf_e_hwver;
|
|
}
|
|
|
|
sub e_swver {
|
|
my $bayrs = shift;
|
|
|
|
# Only on Processor
|
|
my $wf_mb = $bayrs->wfHwActiveImageSource() || {};
|
|
my %wf_e_swver;
|
|
foreach my $idx ( keys %$wf_mb ) {
|
|
my $sw = $wf_mb->{$idx};
|
|
next unless $sw;
|
|
|
|
$wf_e_swver{ "$idx" . "0001" } = $sw;
|
|
}
|
|
return \%wf_e_swver;
|
|
}
|
|
|
|
sub e_parent {
|
|
my $bayrs = shift;
|
|
|
|
my $wf_e_idx = $bayrs->e_index() || {};
|
|
my $bp_id = $bayrs->bp_id();
|
|
|
|
my %wf_e_parent;
|
|
foreach my $iid ( keys %$wf_e_idx ) {
|
|
if ( $iid == 1 ) {
|
|
$wf_e_parent{$iid} = 0;
|
|
next;
|
|
}
|
|
|
|
my $mod = substr( $iid, -4, 2 );
|
|
my $slot = substr( $iid, -6, 2 );
|
|
|
|
if ( $bp_id =~ /an|arn|asn/ and $iid == '10001' ) {
|
|
$wf_e_parent{$iid} = 0;
|
|
}
|
|
elsif ( $iid =~ /(00){1,2}$/ ) {
|
|
my $parent = 1;
|
|
$parent = '10001' if ( $bp_id =~ /an|arn|asn/ );
|
|
$wf_e_parent{$iid} = $parent;
|
|
}
|
|
elsif ( $mod != 0 ) {
|
|
$wf_e_parent{$iid} = "$slot" . "$mod" . "00";
|
|
}
|
|
else {
|
|
$wf_e_parent{$iid} = "$slot" . "0000";
|
|
}
|
|
}
|
|
return \%wf_e_parent;
|
|
}
|
|
|
|
sub munge_hw_rev {
|
|
my $hw_boot = shift;
|
|
|
|
my @bytes = map { sprintf "%02X", $_ } unpack( "C*", $hw_boot );
|
|
my $major = hex( "$bytes[0]" . "$bytes[1]" );
|
|
my $minor = hex( "$bytes[2]" . "$bytes[3]" );
|
|
|
|
my $rev = "$major.$minor";
|
|
return $rev if defined($rev);
|
|
return;
|
|
}
|
|
|
|
sub munge_wf_serial {
|
|
my $wf_serial = shift;
|
|
|
|
my $serial = hex(
|
|
join( '',
|
|
'0x', map { sprintf "%02X", $_ } unpack( "C*", $wf_serial ) )
|
|
);
|
|
|
|
return $serial if defined($serial);
|
|
return;
|
|
}
|
|
|
|
1;
|
|
__END__
|
|
|
|
=head1 NAME
|
|
|
|
SNMP::Info::Layer3::BayRS - SNMP Interface to Avaya/Nortel routers running
|
|
BayRS.
|
|
|
|
=head1 AUTHOR
|
|
|
|
Eric Miller
|
|
|
|
=head1 SYNOPSIS
|
|
|
|
# Let SNMP::Info determine the correct subclass for you.
|
|
my $bayrs = new SNMP::Info(
|
|
AutoSpecify => 1,
|
|
Debug => 1,
|
|
DestHost => 'myswitch',
|
|
Community => 'public',
|
|
Version => 2
|
|
)
|
|
or die "Can't connect to DestHost.\n";
|
|
|
|
my $class = $bayrs->class();
|
|
print "SNMP::Info determined this device to fall under subclass : $class\n";
|
|
|
|
=head1 DESCRIPTION
|
|
|
|
Abstraction subclass for routers running Avaya/Nortel BayRS.
|
|
|
|
For speed or debugging purposes you can call the subclass directly, but not
|
|
after determining a more specific class using the method above.
|
|
|
|
my $bayrs = new SNMP::Info::Layer3::BayRS(...);
|
|
|
|
=head2 Inherited Classes
|
|
|
|
=over
|
|
|
|
=item SNMP::Info
|
|
|
|
=item SNMP::Info::Bridge
|
|
|
|
=item SNMP::Info::Layer3
|
|
|
|
=back
|
|
|
|
=head2 Required MIBs
|
|
|
|
=over
|
|
|
|
=item F<Wellfleet-HARDWARE-MIB>
|
|
|
|
=item F<Wellfleet-MODULE-MIB>
|
|
|
|
=item F<Wellfleet-OSPF-MIB>
|
|
|
|
=item F<Wellfleet-DOT1QTAG-CONFIG-MIB>
|
|
|
|
=item F<Wellfleet-CSMACD-MIB>
|
|
|
|
=back
|
|
|
|
=head2 Inherited MIBs
|
|
|
|
See L<SNMP::Info/"Required MIBs"> for its own MIB requirements.
|
|
|
|
See L<SNMP::Info::Bridge/"Required MIBs"> for its own MIB requirements.
|
|
|
|
See L<SNMP::Info::Layer3/"Required MIBs"> for its own MIB requirements.
|
|
|
|
=head1 GLOBALS
|
|
|
|
These are methods that return scalar value from SNMP
|
|
|
|
=over
|
|
|
|
=item $bayrs->model()
|
|
|
|
Returns the model of the BayRS router. Will translate between the MIB model
|
|
and the common model with this map :
|
|
|
|
C<%MODEL_MAP = (
|
|
'acefn' => 'FN',
|
|
'aceln' => 'LN',
|
|
'acecn' => 'CN',
|
|
'afn' => 'AFN',
|
|
'in' => 'IN',
|
|
'an' => 'AN',
|
|
'arn' => 'ARN',
|
|
'sys5000' => '5000',
|
|
'freln' => 'BLN',
|
|
'frecn' => 'BCN',
|
|
'frerbln' => 'BLN-2',
|
|
'asn' => 'ASN',
|
|
'asnzcable' => 'ASN-Z',
|
|
'asnbcable' => 'ASN-B',
|
|
);>
|
|
|
|
=item $bayrs->vendor()
|
|
|
|
Returns 'avaya'
|
|
|
|
=item $bayrs->os()
|
|
|
|
Returns 'bayrs'
|
|
|
|
=item $bayrs->os_ver()
|
|
|
|
Returns the software version extracted from C<sysDescr>
|
|
|
|
=item $bayrs->serial()
|
|
|
|
Returns (C<wfHwBpSerialNumber>) after conversion to ASCII decimal
|
|
|
|
=item $bayrs->root_ip()
|
|
|
|
Returns the primary IP used to communicate with the router.
|
|
|
|
Returns the first found: CLIP (CircuitLess IP), (C<wfOspfRouterId>), or
|
|
undefined.
|
|
|
|
=back
|
|
|
|
=head2 Globals imported from SNMP::Info
|
|
|
|
See documentation in L<SNMP::Info/"GLOBALS"> for details.
|
|
|
|
=head2 Globals imported from SNMP::Info::Bridge
|
|
|
|
See documentation in L<SNMP::Info::Bridge/"GLOBALS"> for details.
|
|
|
|
=head2 Globals imported from SNMP::Info::Layer3
|
|
|
|
See documentation in L<SNMP::Info::Layer3/"GLOBALS"> for details.
|
|
|
|
=head1 TABLE METHODS
|
|
|
|
These are methods that return tables of information in the form of a reference
|
|
to a hash.
|
|
|
|
Note: These methods do not support partial table fetches, a partial can be
|
|
passed but the entire table will be returned.
|
|
|
|
=head2 Overrides
|
|
|
|
=over
|
|
|
|
=item $bayrs->interfaces()
|
|
|
|
Returns reference to the map between IID and physical Port.
|
|
|
|
The physical port name is stripped to letter and numbers to signify
|
|
port type and slot port (S11) if the default platform naming was
|
|
maintained. Otherwise the port is the interface description.
|
|
|
|
=item $bayrs->i_name()
|
|
|
|
Returns (C<ifDescr>) along with VLAN name (C<wfDot1qTagCfgVlanName>) for VLAN
|
|
interfaces.
|
|
|
|
=item $bayrs->i_duplex()
|
|
|
|
Returns reference to hash. Maps port operational duplexes to IIDs for
|
|
Ethernet interfaces.
|
|
|
|
=item $bayrs->i_duplex_admin()
|
|
|
|
Returns reference to hash. Maps port admin duplexes to IIDs for Ethernet
|
|
interfaces.
|
|
|
|
=item $bayrs->i_vlan()
|
|
|
|
Returns reference to hash. Maps port VLAN ID to IIDs.
|
|
|
|
=item $bayrs->i_pvid()
|
|
|
|
Returns reference to hash. Maps port VLAN ID to IIDs.
|
|
|
|
=back
|
|
|
|
=head2 Pseudo F<ENTITY-MIB> information
|
|
|
|
These methods emulate F<ENTITY-MIB> Physical Table methods using
|
|
F<Wellfleet-HARDWARE-MIB> and F<Wellfleet-MODULE-MIB>.
|
|
|
|
=over
|
|
|
|
=item $bayrs->e_index()
|
|
|
|
Returns reference to hash. Key and Value: Integer. The index is created by
|
|
combining the slot, module, and position into a five or six digit integer.
|
|
Slot can be either one or two digits while the module and position are each
|
|
two digits padded with leading zero if required.
|
|
|
|
=item $bayrs->e_class()
|
|
|
|
Returns reference to hash. Key: IID, Value: General hardware type. This
|
|
class only returns container and module types.
|
|
|
|
=item $bayrs->e_descr()
|
|
|
|
Returns reference to hash. Key: IID, Value: Human friendly name.
|
|
|
|
=item $bayrs->e_name()
|
|
|
|
Returns reference to hash. Key: IID, Value: Human friendly name.
|
|
|
|
=item $bayrs->e_hwver()
|
|
|
|
Returns reference to hash. Key: IID, Value: Hardware version.
|
|
|
|
=item $bayrs->e_vendor()
|
|
|
|
Returns reference to hash. Key: IID, Value: avaya.
|
|
|
|
=item $bayrs->e_serial()
|
|
|
|
Returns reference to hash. Key: IID, Value: Serial number.
|
|
|
|
=item $bayrs->e_pos()
|
|
|
|
Returns reference to hash. Key: IID, Value: The relative position among all
|
|
entities sharing the same parent.
|
|
|
|
=item $bayrs->e_type()
|
|
|
|
Returns reference to hash. Key: IID, Value: Type of component/sub-component
|
|
as defined in F<Wellfleet-HARDWARE-MIB> for processors and link modules or
|
|
F<Wellfleet-MODULE-MIB> for hardware modules.
|
|
|
|
=item $bayrs->e_fwver()
|
|
|
|
Returns reference to hash. Key: IID, Value: Firmware revision. Only
|
|
available on processors.
|
|
|
|
=item $bayrs->e_swver()
|
|
|
|
Returns reference to hash. Key: IID, Value: Software revision. Only
|
|
available on processors.
|
|
|
|
=item $bayrs->e_parent()
|
|
|
|
Returns reference to hash. Key: IID, Value: The value of e_index() for the
|
|
entity which 'contains' this entity. A value of zero indicates this entity
|
|
is not contained in any other entity.
|
|
|
|
=back
|
|
|
|
=head2 Table Methods imported from SNMP::Info
|
|
|
|
See documentation in L<SNMP::Info/"TABLE METHODS"> for details.
|
|
|
|
=head2 Table Methods imported from SNMP::Info::Bridge
|
|
|
|
See documentation in L<SNMP::Info::Bridge/"TABLE METHODS"> for details.
|
|
|
|
=head2 Table Methods imported from SNMP::Info::Layer3
|
|
|
|
See documentation in L<SNMP::Info::Layer3/"TABLE METHODS"> for details.
|
|
|
|
=head1 Data Munging Callback Subroutines
|
|
|
|
=over
|
|
|
|
=item $bayrs->munge_hw_rev()
|
|
|
|
Converts octets to a decimal major.minor string.
|
|
|
|
=item $bayrs->munge_wf_serial()
|
|
|
|
Coverts octets to a decimal string.
|
|
|
|
=back
|
|
|
|
=cut
|