Fix Eltex a lot model.
Add Telindus Add serial to Zixel
This commit is contained in:
		| @@ -25,7 +25,7 @@ our | |||||||
|     ($VERSION, %FUNCS, %GLOBALS, %MIBS, %MUNGE, $AUTOLOAD, $INIT, $DEBUG, %SPEED_MAP, |     ($VERSION, %FUNCS, %GLOBALS, %MIBS, %MUNGE, $AUTOLOAD, $INIT, $DEBUG, %SPEED_MAP, | ||||||
|      $NOSUCH, $BIGINT, $REPEATERS); |      $NOSUCH, $BIGINT, $REPEATERS); | ||||||
|  |  | ||||||
| $VERSION = '3.70-135.20.5.1'; | $VERSION = '3.70-135.20.5.2'; | ||||||
|  |  | ||||||
| =head1 NAME | =head1 NAME | ||||||
|  |  | ||||||
| @@ -1350,7 +1350,7 @@ sub new { | |||||||
|         delete $sess_args{Offline}; |         delete $sess_args{Offline}; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     if ( defined $args{Cache} and ref {} eq ref $args{Cache} ) { |     if ( defined $args{Cache} and ref({}) eq ref $args{Cache} ) { | ||||||
|         $new_obj->{$_} = $args{Cache}->{$_} for keys %{$args{Cache}}; |         $new_obj->{$_} = $args{Cache}->{$_} for keys %{$args{Cache}}; | ||||||
|         delete $sess_args{Cache}; |         delete $sess_args{Cache}; | ||||||
|     } |     } | ||||||
| @@ -1571,7 +1571,7 @@ sub cache { | |||||||
|     my $self = shift; |     my $self = shift; | ||||||
|     my $data = shift; |     my $data = shift; | ||||||
|  |  | ||||||
|     if ( defined $data and ref {} eq ref $data ) { |     if ( defined $data and ref({}) eq ref $data ) { | ||||||
|         $self->{$_} = $data->{$_} for keys %$data; |         $self->{$_} = $data->{$_} for keys %$data; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -1676,6 +1676,7 @@ sub device_type { | |||||||
|         655   => 'SNMP::Info::Layer2::Carelink', |         655   => 'SNMP::Info::Layer2::Carelink', | ||||||
|         664   => 'SNMP::Info::Layer2::Adtran', |         664   => 'SNMP::Info::Layer2::Adtran', | ||||||
|         674   => 'SNMP::Info::Layer3::Dell', |         674   => 'SNMP::Info::Layer3::Dell', | ||||||
|  |         776   => 'SNMP::Info::Layer2::Telindus', | ||||||
|         890   => 'SNMP::Info::Layer2::Zyxel', |         890   => 'SNMP::Info::Layer2::Zyxel', | ||||||
|         1588  => 'SNMP::Info::Layer3::Foundry', |         1588  => 'SNMP::Info::Layer3::Foundry', | ||||||
|         1872  => 'SNMP::Info::Layer3::AlteonAD', |         1872  => 'SNMP::Info::Layer3::AlteonAD', | ||||||
| @@ -1743,6 +1744,7 @@ sub device_type { | |||||||
|         655   => 'SNMP::Info::Layer2::Carelink', |         655   => 'SNMP::Info::Layer2::Carelink', | ||||||
|         664   => 'SNMP::Info::Layer2::Adtran', |         664   => 'SNMP::Info::Layer2::Adtran', | ||||||
|         674   => 'SNMP::Info::Layer3::Dell', |         674   => 'SNMP::Info::Layer3::Dell', | ||||||
|  |         776   => 'SNMP::Info::Layer2::Telindus', | ||||||
|         890   => 'SNMP::Info::Layer2::Zyxel', |         890   => 'SNMP::Info::Layer2::Zyxel', | ||||||
|         1872  => 'SNMP::Info::Layer3::AlteonAD', |         1872  => 'SNMP::Info::Layer3::AlteonAD', | ||||||
|         1890  => 'SNMP::Info::Layer3::Redlion', |         1890  => 'SNMP::Info::Layer3::Redlion', | ||||||
| @@ -2883,7 +2885,7 @@ sub ip_index { | |||||||
|  |  | ||||||
|     my $o_ip_idx = $self->old_ip_index(); |     my $o_ip_idx = $self->old_ip_index(); | ||||||
|     return $o_ip_idx |     return $o_ip_idx | ||||||
|         if ( ref {} eq ref $o_ip_idx and scalar keys %$o_ip_idx ); |         if ( ref({}) eq ref $o_ip_idx and scalar keys %$o_ip_idx ); | ||||||
|  |  | ||||||
|     # Since callers may be using the old iid to get the IP, strip protocol |     # Since callers may be using the old iid to get the IP, strip protocol | ||||||
|     # and length from the index |     # and length from the index | ||||||
| @@ -2909,7 +2911,7 @@ sub ip_table { | |||||||
|  |  | ||||||
|     my $o_ip_table = $self->old_ip_table(); |     my $o_ip_table = $self->old_ip_table(); | ||||||
|     return $o_ip_table |     return $o_ip_table | ||||||
|         if ( ref {} eq ref $o_ip_table and scalar keys %$o_ip_table ); |         if ( ref({}) eq ref $o_ip_table and scalar keys %$o_ip_table ); | ||||||
|  |  | ||||||
|     my $n_ip_idx  = $self->new_ip_index() || {}; |     my $n_ip_idx  = $self->new_ip_index() || {}; | ||||||
|     my $n_ip_type = $self->new_ip_type()  || {}; |     my $n_ip_type = $self->new_ip_type()  || {}; | ||||||
| @@ -2933,7 +2935,7 @@ sub ip_netmask { | |||||||
|  |  | ||||||
|     my $o_ip_mask = $self->old_ip_netmask(); |     my $o_ip_mask = $self->old_ip_netmask(); | ||||||
|     return $o_ip_mask |     return $o_ip_mask | ||||||
|         if ( ref {} eq ref $o_ip_mask and scalar keys %$o_ip_mask ); |         if ( ref({}) eq ref $o_ip_mask and scalar keys %$o_ip_mask ); | ||||||
|  |  | ||||||
|     my $n_ip_pfx  = $self->new_ip_prefix() || {}; |     my $n_ip_pfx  = $self->new_ip_prefix() || {}; | ||||||
|     my $n_ip_type = $self->new_ip_type()   || {}; |     my $n_ip_type = $self->new_ip_type()   || {}; | ||||||
| @@ -4814,7 +4816,7 @@ sub _cache { | |||||||
|     my ($attr, $data) = @_; |     my ($attr, $data) = @_; | ||||||
|     my $store = $self->store(); |     my $store = $self->store(); | ||||||
|  |  | ||||||
|     if (ref {} eq ref $data) { |     if (ref({}) eq ref $data) { | ||||||
|         $self->{"_${attr}"}++; |         $self->{"_${attr}"}++; | ||||||
|         $store->{$attr} = $data; |         $store->{$attr} = $data; | ||||||
|     } |     } | ||||||
| @@ -4842,7 +4844,7 @@ sub _munge { | |||||||
|  |  | ||||||
|     return $data unless defined $munge->{$attr}; |     return $data unless defined $munge->{$attr}; | ||||||
|  |  | ||||||
|     if (ref {} eq ref $data) { |     if (ref({}) eq ref $data) { | ||||||
|         my $subref = $munge->{$attr}; |         my $subref = $munge->{$attr}; | ||||||
|         my %munged; |         my %munged; | ||||||
|         foreach my $key ( keys %$data ) { |         foreach my $key ( keys %$data ) { | ||||||
|   | |||||||
							
								
								
									
										119
									
								
								lib/SNMP/Info/Layer2/Telindus.pm
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										119
									
								
								lib/SNMP/Info/Layer2/Telindus.pm
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,119 @@ | |||||||
|  | # SNMP::Info::Layer2::Telindus - SNMP Interface to Telindus Devices | ||||||
|  | # | ||||||
|  | # Copyright (c) 2020 by 135. | ||||||
|  |  | ||||||
|  | package SNMP::Info::Layer2::Telindus; | ||||||
|  |  | ||||||
|  | use strict; | ||||||
|  | use warnings; | ||||||
|  | use Exporter; | ||||||
|  | use SNMP::Info::Layer2; | ||||||
|  |  | ||||||
|  | @SNMP::Info::Layer2::Telindus::ISA       = qw/SNMP::Info::Layer2 Exporter/; | ||||||
|  | @SNMP::Info::Layer2::Telindus::EXPORT_OK = qw//; | ||||||
|  |  | ||||||
|  | our ($VERSION, %GLOBALS, %MIBS, %FUNCS, %MUNGE); | ||||||
|  |  | ||||||
|  | $VERSION = '3.70-135'; | ||||||
|  |  | ||||||
|  | # 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, ); | ||||||
|  |  | ||||||
|  | %GLOBALS = ( | ||||||
|  |     %SNMP::Info::Layer2::GLOBALS, | ||||||
|  | ); | ||||||
|  |  | ||||||
|  | %FUNCS = ( %SNMP::Info::Layer2::FUNCS, ); | ||||||
|  |  | ||||||
|  | %MUNGE = ( %SNMP::Info::Layer2::MUNGE, ); | ||||||
|  |  | ||||||
|  | sub vendor { | ||||||
|  |     return 'telindus'; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | sub os { | ||||||
|  |     return 'telind-os'; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | sub os_ver { | ||||||
|  |     my $obj = shift; | ||||||
|  |     $obj->description =~ /\$Telindus\s(\d+)(\$\s(.*)|\s(.*)\$)\s(T\d+\/\d+)/; | ||||||
|  |     return $5; | ||||||
|  | } | ||||||
|  | sub model { | ||||||
|  |     my $obj = shift; | ||||||
|  |     $obj->description =~ /\$Telindus\s(\d+)(\$\s(.*)|\s(.*)\$)\s(T\d+\/\d+)/; | ||||||
|  |     if (defined $3) { | ||||||
|  |         return $1 . ' ' . $3; | ||||||
|  |     } | ||||||
|  |     else { | ||||||
|  |         return $1 . ' ' . $4; | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | 1; | ||||||
|  | __END__ | ||||||
|  |  | ||||||
|  | =head1 NAME | ||||||
|  |  | ||||||
|  | SNMP::Info::Layer2::Telindus - SNMP Interface to Telindus Devices | ||||||
|  |  | ||||||
|  | =head1 SYNOPSIS | ||||||
|  |  | ||||||
|  |  # Let SNMP::Info determine the correct subclass for you. | ||||||
|  |  my $obj = new SNMP::Info( | ||||||
|  |                           AutoSpecify => 1, | ||||||
|  |                           Debug       => 1, | ||||||
|  |                           DestHost    => 'myrouter', | ||||||
|  |                           Community   => 'public', | ||||||
|  |                           Version     => 2 | ||||||
|  |                         ) | ||||||
|  |     or die "Can't connect to DestHost.\n"; | ||||||
|  |  | ||||||
|  |  my $class      = $obj->class(); | ||||||
|  |  print "SNMP::Info determined this device to fall under subclass : $class\n"; | ||||||
|  |  | ||||||
|  | =head1 DESCRIPTION | ||||||
|  |  | ||||||
|  | Subclass for Telindus Devices | ||||||
|  |  | ||||||
|  | =head2 Inherited Classes | ||||||
|  |  | ||||||
|  | =over | ||||||
|  |  | ||||||
|  | =item SNMP::Info::Layer2 | ||||||
|  |  | ||||||
|  | =back | ||||||
|  |  | ||||||
|  | =head1 GLOBALS | ||||||
|  |  | ||||||
|  | These are methods that return scalar value from SNMP | ||||||
|  |  | ||||||
|  | =over | ||||||
|  |  | ||||||
|  | =item $obj->vendor() | ||||||
|  |  | ||||||
|  | Returns 'zyxel' | ||||||
|  |  | ||||||
|  | =item $obj->os() | ||||||
|  |  | ||||||
|  | Returns 'zynos' | ||||||
|  |  | ||||||
|  | =item $obj->layers() | ||||||
|  |  | ||||||
|  | Ensures that layer two is reported, at least. | ||||||
|  |  | ||||||
|  | =item $obj->os_ver() | ||||||
|  |  | ||||||
|  | Returns the software version. | ||||||
|  |  | ||||||
|  | =item $obj->model | ||||||
|  |  | ||||||
|  | Returns the model extracted. | ||||||
|  |  | ||||||
|  | =cut | ||||||
|  |  | ||||||
|  | =back | ||||||
| @@ -24,6 +24,7 @@ $VERSION = '3.70-135'; | |||||||
|  |  | ||||||
| %GLOBALS = ( | %GLOBALS = ( | ||||||
|     %SNMP::Info::Layer2::GLOBALS, |     %SNMP::Info::Layer2::GLOBALS, | ||||||
|  |     'serial_oid' => 'transmission.94.1.1.2.1.1.1', | ||||||
| ); | ); | ||||||
|  |  | ||||||
| %FUNCS = ( %SNMP::Info::Layer2::FUNCS, ); | %FUNCS = ( %SNMP::Info::Layer2::FUNCS, ); | ||||||
| @@ -51,6 +52,11 @@ sub model { | |||||||
|     return 'unknown'; |     return 'unknown'; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | sub serial { | ||||||
|  |     my $obj = shift; | ||||||
|  |     return $obj->serial_oid; | ||||||
|  | } | ||||||
|  |  | ||||||
| 1; | 1; | ||||||
| __END__ | __END__ | ||||||
|  |  | ||||||
|   | |||||||
| @@ -8,7 +8,6 @@ package SNMP::Info::Layer3::Eltex; | |||||||
| use strict; | use strict; | ||||||
| use warnings; | use warnings; | ||||||
| use Exporter; | use Exporter; | ||||||
| #use SNMP::Info::Layer2; |  | ||||||
| use SNMP::Info::Layer3; | use SNMP::Info::Layer3; | ||||||
|  |  | ||||||
| @SNMP::Info::Layer3::Eltex::ISA       = qw/SNMP::Info::Layer3 Exporter/; | @SNMP::Info::Layer3::Eltex::ISA       = qw/SNMP::Info::Layer3 Exporter/; | ||||||
| @@ -21,18 +20,19 @@ $VERSION = '3.70-135'; | |||||||
| %MIBS = ( %SNMP::Info::Layer3::MIBS, ); | %MIBS = ( %SNMP::Info::Layer3::MIBS, ); | ||||||
|  |  | ||||||
| %GLOBALS = ( | %GLOBALS = ( | ||||||
|     #%SNMP::Info::Layer2::GLOBALS, |  | ||||||
|     %SNMP::Info::Layer3::GLOBALS, |     %SNMP::Info::Layer3::GLOBALS, | ||||||
|     'model_oid'       => 'mib-2.47.1.1.1.1.13.67108992', |     'model_oid_mes'  => 'mib-2.47.1.1.1.1.13.67108992', | ||||||
|     'hw_oid'          => 'mib-2.47.1.1.1.1.8.67108992', |     #'hw_oid'          => 'mib-2.47.1.1.1.1.8.67108992', | ||||||
|     'serial_oid'      => 'mib-2.47.1.1.1.1.11.67108992', |     'model_oid'      => 'iso.0.8802.1.1.2.1.3.4.0', | ||||||
|     'os_ver_oid'      => 'mib-2.47.1.1.1.1.10.67108992', |     'hw_oid'         => 'iso.0.8802.1.1.2.1.5.4795.1.2.2.0', | ||||||
|     'bootrom_oid'     => 'mib-2.47.1.1.1.1.9.67108992', |     'serial_oid'     => 'mib-2.47.1.1.1.1.11.67108992', | ||||||
|     #'model_oid_140'   => '', |     'serial_oid_22'  => 'enterprises.35265.1.22.1.18.4.0', | ||||||
|     'hw_oid_140'      => 'mib-2.47.1.1.1.1.8.1', |     'os_ver_oid'     => 'mib-2.47.1.1.1.1.10.67108992', | ||||||
|  |     'bootrom_oid'    => 'mib-2.47.1.1.1.1.9.67108992', | ||||||
|     #'serial_oid_140'  => '', |     #'serial_oid_140'  => '', | ||||||
|     'os_ver_oid_140'  => 'mib-2.47.1.1.1.1.9.1', |     'os_ver_oid_140' => 'mib-2.47.1.1.1.1.9.1', | ||||||
|     #'bootrom_oid_140' => '', |     #'bootrom_oid_140' => '', | ||||||
|  |     'descr_oid'      => 'iso.0.8802.1.1.2.1.3.4.0', | ||||||
|  |  | ||||||
| ); | ); | ||||||
|  |  | ||||||
| @@ -41,21 +41,28 @@ $VERSION = '3.70-135'; | |||||||
| %MUNGE = ( %SNMP::Info::Layer3::MUNGE, ); | %MUNGE = ( %SNMP::Info::Layer3::MUNGE, ); | ||||||
|  |  | ||||||
| sub model { | sub model { | ||||||
|     my $eltex = shift; |     my $obj = shift; | ||||||
|     my $model; my $hw; |     my $model; my $hw; | ||||||
|     my $id = $eltex->id(); |     my $id = $obj->id(); | ||||||
|     if ($id =~ /35265\.(140|158)$/) { |     $model = $obj->model_oid || undef; | ||||||
|         return; |     $hw = $obj->hw_oid || undef; | ||||||
|  |     if ( $id =~ /35265\.1\.22/ ) { | ||||||
|  |         my $descr = $obj->descr_oid; | ||||||
|  |         $descr =~ /Eltex\s(.*)\ssoftware\sversion\s(.*)\sbuild\s(\d+)/; | ||||||
|  |         return $1; | ||||||
|     } |     } | ||||||
|     # default behaviour for 35265.1.120 |     elsif ($model !~ /MES\d+/) { | ||||||
|     elsif ($id =~ /35265\.1\.(24|43|30|120|5[2,4]|74|8[1,9])$/) { |         $model = $obj->model_oid_mes . ' ' . $obj->model_oid || undef; | ||||||
|         $model = $eltex->model_oid; |     } | ||||||
|         $hw = $eltex->hw_oid; |     if (defined $model and defined $hw) { | ||||||
|  |         return $model . ' HW:' . $hw; | ||||||
|  |     } | ||||||
|  |     elsif (defined $model) { | ||||||
|  |         return $model; | ||||||
|     } |     } | ||||||
|     else { |     else { | ||||||
|         return 'unknown'; |         return 'unknown'; | ||||||
|     } |     } | ||||||
|     return $model . ' HW:' . $hw; |  | ||||||
| } | } | ||||||
|  |  | ||||||
| sub vendor { | sub vendor { | ||||||
| @@ -67,16 +74,21 @@ sub os { | |||||||
| } | } | ||||||
|  |  | ||||||
| sub os_ver { | sub os_ver { | ||||||
|     my $eltex = shift; |     my $obj = shift; | ||||||
|     my $os_ver; my $bootrom; |     my $os_ver; my $bootrom; | ||||||
|     my $id = $eltex->id(); |     my $id = $obj->id(); | ||||||
|     if ($id =~ /35265\.(140|158)$/) { |     if ($id =~ /35265\.(140|158)$/) { | ||||||
|         $os_ver = $eltex->os_ver_oid_140; |         $os_ver = $obj->os_ver_oid_140; | ||||||
|         return $os_ver; |         return $os_ver; | ||||||
|     } |     } | ||||||
|     elsif ($id =~ /35265\.1\.(24|43|30|120|5[2,4]|74|8[1,9])$/) { |     elsif ($id =~ /35265\.1\.(24|43|30|120|5[2,4]|74|8[1,9])$/) { | ||||||
|         $os_ver = $eltex->os_ver_oid; |         $os_ver = $obj->os_ver_oid; | ||||||
|         $bootrom = $eltex->bootrom_oid; |         $bootrom = $obj->bootrom_oid; | ||||||
|  |     } | ||||||
|  |     elsif ( $id =~ /35265\.1\.22/ ) { | ||||||
|  |         my $descr = $obj->descr_oid; | ||||||
|  |         $descr =~ /Eltex\s(.*)\ssoftware\sversion\s(.*)\sbuild\s(\d+)/; | ||||||
|  |         return $2; | ||||||
|     } |     } | ||||||
|     else { |     else { | ||||||
|         return 'unknown'; |         return 'unknown'; | ||||||
| @@ -85,14 +97,17 @@ sub os_ver { | |||||||
| } | } | ||||||
|  |  | ||||||
| sub serial { | sub serial { | ||||||
|     my $eltex = shift; |     my $obj = shift; | ||||||
|     my $serial; |     my $serial; | ||||||
|     my $id = $eltex->id(); |     my $id = $obj->id(); | ||||||
|     if ($id =~ /35265\.(140|158)$/) { |     if ($id =~ /35265\.(140|158)$/) { | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|     elsif ($id =~ /35265\.1\.(24|43|30|120|5[2,4]|74|8[1,9]])$/) { |     elsif ($id =~ /35265\.1\.(24|43|30|120|5[2,4]|74|8[1,9]])$/) { | ||||||
|         $serial = $eltex->serial_oid; |         $serial = $obj->serial_oid; | ||||||
|  |     } | ||||||
|  |     elsif ( $id =~ /35265\.1\.22/ ) { | ||||||
|  |         $serial = $obj->serial_oid_22; | ||||||
|     } |     } | ||||||
|     else { |     else { | ||||||
|         return 'unknown'; |         return 'unknown'; | ||||||
| @@ -110,7 +125,7 @@ SNMP::Info::Layer3::Eltex - SNMP Interface to Eltex Devices | |||||||
| =head1 SYNOPSIS | =head1 SYNOPSIS | ||||||
|  |  | ||||||
|  # Let SNMP::Info determine the correct subclass for you. |  # Let SNMP::Info determine the correct subclass for you. | ||||||
|  my $eltex = new SNMP::Info( |  my $obj = new SNMP::Info( | ||||||
|                           AutoSpecify => 1, |                           AutoSpecify => 1, | ||||||
|                           Debug       => 1, |                           Debug       => 1, | ||||||
|                           DestHost    => 'myrouter', |                           DestHost    => 'myrouter', | ||||||
| @@ -119,7 +134,7 @@ SNMP::Info::Layer3::Eltex - SNMP Interface to Eltex Devices | |||||||
|                         ) |                         ) | ||||||
|     or die "Can't connect to DestHost.\n"; |     or die "Can't connect to DestHost.\n"; | ||||||
|  |  | ||||||
|  my $class      = $eltex->class(); |  my $class      = $obj->class(); | ||||||
|  print "SNMP::Info determined this device to fall under subclass : $class\n"; |  print "SNMP::Info determined this device to fall under subclass : $class\n"; | ||||||
|  |  | ||||||
| =head1 DESCRIPTION | =head1 DESCRIPTION | ||||||
| @@ -144,27 +159,27 @@ These are methods that return scalar value from SNMP | |||||||
|  |  | ||||||
| =over | =over | ||||||
|  |  | ||||||
| =item $eltex->model() | =item $obj->model() | ||||||
|  |  | ||||||
| Returns the ID or else description. | Returns the ID or else description. | ||||||
|  |  | ||||||
| =item $eltex->vendor() | =item $obj->vendor() | ||||||
|  |  | ||||||
| Returns 'eltex'. | Returns 'eltex'. | ||||||
|  |  | ||||||
| =item $eltex->serial() | =item $obj->serial() | ||||||
|  |  | ||||||
| Returns serial number. | Returns serial number. | ||||||
|  |  | ||||||
| =item $eltex->fwver() | =item $obj->fwver() | ||||||
|  |  | ||||||
| Returns the firmware version. | Returns the firmware version. | ||||||
|  |  | ||||||
| =item $eltex->hwver() | =item $obj->hwver() | ||||||
|  |  | ||||||
| Returns the hardware version. | Returns the hardware version. | ||||||
|  |  | ||||||
| =item $eltex->stp_i_root_port() | =item $obj->stp_i_root_port() | ||||||
|  |  | ||||||
| Returns the STP root port. | Returns the STP root port. | ||||||
|  |  | ||||||
| @@ -181,7 +196,7 @@ to a hash. | |||||||
|  |  | ||||||
| =over | =over | ||||||
|  |  | ||||||
| =item $eltex->interfaces(); | =item $obj->interfaces(); | ||||||
|  |  | ||||||
| Returns the map between SNMP Interface Identifier (iid) and C<ifName>. | Returns the map between SNMP Interface Identifier (iid) and C<ifName>. | ||||||
|  |  | ||||||
|   | |||||||
| @@ -44,9 +44,9 @@ sub os { | |||||||
| } | } | ||||||
|  |  | ||||||
| sub os_ver { | sub os_ver { | ||||||
|     my $rcios = shift; |     my $obj = shift; | ||||||
|     my $os_ver = $rcios->os_ver_oid || undef; |     my $os_ver = $obj->os_ver_oid || undef; | ||||||
|     my $brom = $rcios->brom_oid || undef; |     my $brom = $obj->brom_oid || undef; | ||||||
|     if (defined $os_ver and defined $brom) { |     if (defined $os_ver and defined $brom) { | ||||||
|         return $os_ver . ' bootrom: ' . $brom; |         return $os_ver . ' bootrom: ' . $brom; | ||||||
|     } |     } | ||||||
| @@ -56,9 +56,9 @@ sub os_ver { | |||||||
|     return 'unknown'; |     return 'unknown'; | ||||||
| } | } | ||||||
| sub model { | sub model { | ||||||
|     my $rcios = shift; |     my $obj = shift; | ||||||
|     my $model = $rcios->model_oid || undef; |     my $model = $obj->model_oid || undef; | ||||||
|     my $hw = $rcios->hw_oid || undef; |     my $hw = $obj->hw_oid || undef; | ||||||
|     if (defined $model and defined $hw) { |     if (defined $model and defined $hw) { | ||||||
|         return $model . ' HW:' . $hw; |         return $model . ' HW:' . $hw; | ||||||
|     } |     } | ||||||
| @@ -69,8 +69,8 @@ sub model { | |||||||
| } | } | ||||||
|  |  | ||||||
| sub serial { | sub serial { | ||||||
|     my $rcios = shift; |     my $obj = shift; | ||||||
|     my $serial = $rcios->serial_oid || 'unknown'; |     my $serial = $obj->serial_oid || 'unknown'; | ||||||
|     return $serial; |     return $serial; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -84,7 +84,7 @@ SNMP::Info::Layer3::Raisecom - SNMP Interface to Raisecom Devices | |||||||
| =head1 SYNOPSIS | =head1 SYNOPSIS | ||||||
|  |  | ||||||
|  # Let SNMP::Info determine the correct subclass for you. |  # Let SNMP::Info determine the correct subclass for you. | ||||||
|  my $rcios = new SNMP::Info( |  my $obj = new SNMP::Info( | ||||||
|                           AutoSpecify => 1, |                           AutoSpecify => 1, | ||||||
|                           Debug       => 1, |                           Debug       => 1, | ||||||
|                           DestHost    => 'myrouter', |                           DestHost    => 'myrouter', | ||||||
| @@ -93,12 +93,12 @@ SNMP::Info::Layer3::Raisecom - SNMP Interface to Raisecom Devices | |||||||
|                         ) |                         ) | ||||||
|     or die "Can't connect to DestHost.\n"; |     or die "Can't connect to DestHost.\n"; | ||||||
|  |  | ||||||
|  my $class      = $rcios->class(); |  my $class      = $obj->class(); | ||||||
|  print "SNMP::Info determined this device to fall under subclass : $class\n"; |  print "SNMP::Info determined this device to fall under subclass : $class\n"; | ||||||
|  |  | ||||||
| =head1 DESCRIPTION | =head1 DESCRIPTION | ||||||
|  |  | ||||||
| Subclass for rcios Devices running IOS-like software | Subclass for Raisecom Devices | ||||||
|  |  | ||||||
| =head2 Inherited Classes | =head2 Inherited Classes | ||||||
|  |  | ||||||
| @@ -118,28 +118,30 @@ These are methods that return scalar value from SNMP | |||||||
|  |  | ||||||
| =over | =over | ||||||
|  |  | ||||||
| =item $rcios->vendor() | =item $obj->vendor() | ||||||
|  |  | ||||||
| Returns 'adtran' | Returns 'adtran' | ||||||
|  |  | ||||||
| =item $rcios->os() | =item $obj->os() | ||||||
|  |  | ||||||
| Returns 'caos' | Returns 'caos' | ||||||
|  |  | ||||||
| =item $rcios->layers() | =item $obj->layers() | ||||||
|  |  | ||||||
| Ensures that layer two is reported, at least. | Ensures that layer two is reported, at least. | ||||||
|  |  | ||||||
| =item $rcios->os_ver() | =item $obj->os_ver() | ||||||
|  |  | ||||||
| Returns the software version. | Returns the software version. | ||||||
|  |  | ||||||
| =item $rcios->model() | =item $obj->model() | ||||||
|  |  | ||||||
| Returns the model extracted. | Returns the model extracted. | ||||||
|  |  | ||||||
| =item $rcios->serial() | =item $obj->serial() | ||||||
|  |  | ||||||
| Returns serial number. | Returns serial number. | ||||||
|  |  | ||||||
| =cut | =cut | ||||||
|  |  | ||||||
|  | =back | ||||||
		Reference in New Issue
	
	Block a user