From b019f3fa066d317f46c700e958d3758a54baea8c Mon Sep 17 00:00:00 2001 From: Andrey Pazychev Date: Wed, 20 May 2020 21:08:14 +0300 Subject: [PATCH] WIP. Raisecom crap splitting --- lib/SNMP/Info/Layer2/ECI.pm | 6 --- lib/SNMP/Info/Layer3/Raisecom.pm | 71 ++++++++++++++++++-------------- 2 files changed, 40 insertions(+), 37 deletions(-) diff --git a/lib/SNMP/Info/Layer2/ECI.pm b/lib/SNMP/Info/Layer2/ECI.pm index c2008ae1..0e7d13a0 100755 --- a/lib/SNMP/Info/Layer2/ECI.pm +++ b/lib/SNMP/Info/Layer2/ECI.pm @@ -16,15 +16,10 @@ 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, - 'serial_oid' => 'transmission.94.1.1.2.1.1.1', ); %FUNCS = ( %SNMP::Info::Layer2::FUNCS, ); @@ -40,7 +35,6 @@ sub os { } sub os_ver { - my $obj = shift; return 'unknown'; } diff --git a/lib/SNMP/Info/Layer3/Raisecom.pm b/lib/SNMP/Info/Layer3/Raisecom.pm index f7faabb9..f10f39fd 100755 --- a/lib/SNMP/Info/Layer3/Raisecom.pm +++ b/lib/SNMP/Info/Layer3/Raisecom.pm @@ -9,6 +9,7 @@ use warnings; use Exporter; use SNMP::Info::Layer3; use SNMP::Info::Layer3::Rotek; +use Data::Dumper; @SNMP::Info::Layer3::Raisecom::ISA = qw/SNMP::Info::Layer3 Exporter/; @SNMP::Info::Layer3::Raisecom::EXPORT_OK = qw//; @@ -21,7 +22,7 @@ $VERSION = '3.70-135'; %GLOBALS = ( %SNMP::Info::Layer3::GLOBALS, - 'model_oid' => 'mib-2.47.1.1.1.1.13.1', + 'model_oid' => 'mib-2.47.1.1.1.1.13.1', #enterprises.8886.1.1.4.1.0 'model_oid_41752' => 'enterprises.41752.6.1.1.1.19.0', 'model_oid_8886_6_140' => 'enterprises.8886.6.1.1.1.19.0', 'serial_oid' => 'mib-2.47.1.1.1.1.11.1', @@ -46,23 +47,49 @@ $VERSION = '3.70-135'; sub vendor { my $obj = shift; - my $id = $obj->id(); - if ($id =~ /41752$/) { - return SNMP::Info::Layer3::Rotek::vendor($obj); - } - return 'raisecom'; + return $obj->main($obj)->{vendor}; } sub os { my $obj = shift; - my $id = $obj->id(); - if ($id =~ /41752\.26\.502/ or $id =~ /8886\.6/) { - return 'ros'; + return $obj->main($obj)->{os}; +} + +sub main { + my $obj = shift; + my $response = undef; my $serial = undef; my $model = undef; my $hw = undef; my $os_ver = undef; my $brom = undef; + my $vendor = 'raisecom'; my $os = 'rcios'; + my $id = $obj->id; + + #Rotek kostilyng + if ($id =~ /41752$/) { + my %rotek = ();#undef;#('vendor', 'os', 'model', 'os_ver', 'serial'); + for my $key ('vendor', 'os', 'model', 'os_ver', 'serial') { + no strict 'refs'; + my $sub = *{'SNMP::Info::Layer3::Rotek::'.$key}; + $rotek{$key} = &$sub($obj); + } + return %rotek; } - elsif ($id =~ /41752$/) { - return SNMP::Info::Layer3::Rotek::os($obj); + + if ( $id =~ /41752\.26\.502/ ) { + $model = $obj->model_oid_41752 || undef; + $hw = ($obj->hw_oid_41752 =~ /.*\sversion\s(.*)/)[0]; } - return 'rcios'; + elsif ($id =~ /8886\.6\.(140|191|150|21[3,4])$/) { + $model = $obj->model_oid_8886_6_140 || undef; + $model = $obj->session()->get('enterprises.8886.1.1.4.1.0') + if not defined($model); + $hw = $obj->hw_oid_8886_6_140; + $hw =~ s/.*\s[v,V]ersion\s(.*)/$1/ + if defined $1; + } + + + $model .= ' HW:' . $hw + if (defined($model) and defined($hw)); + + return { 'vendor' => $vendor, 'os' => $os, 'model' => $model, 'os_ver' => $os_ver, 'serial' => $serial }; } sub os_ver { @@ -111,25 +138,7 @@ sub os_ver { } sub model { my $obj = shift; - my $id = $obj->id(); - my $model = $obj->model_oid || undef; - my $hw = $obj->hw_oid || undef; - if (defined $model and defined $hw) { - return $model . ' HW:' . $hw; - } - elsif (defined $model) { - return $model; - } - elsif ($id =~ /41752\.26\.502/) { - return $obj->model_oid_41752 . ' HW:' . $obj->hvver; - } - elsif ($id =~ /8886\.6\.(140|191|150|21[3,4])$/) { - return $obj->model_oid_8886_6_140 . ' HW:' . $obj->hvver; - } - elsif ($id =~ /41752$/) { - return SNMP::Info::Layer3::Rotek::model($obj); - } - return $obj->SUPER::model(); + return $obj->main($obj)->{model}; } sub serial {